{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8fad86df-77f1-4b92-b0fa-0c634387f9f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/dev/24/es-bench\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.10/dist-packages/IPython/core/magics/osm.py:417: UserWarning: using dhist requires you to install the `pickleshare` library.\n",
      "  self.shell.db['dhist'] = compress_dhist(dhist)[-100:]\n"
     ]
    }
   ],
   "source": [
    "%cd .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b46f6517-8342-4eef-aded-102616e88883",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "from datetime import datetime\n",
    "\n",
    "import yaml\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from scipy import stats\n",
    "from tqdm.auto import tqdm\n",
    "from IPython.display import display\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from cd import draw_cd_diagram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "bfd1d510-6636-4032-bf60-fe1f1ce02c3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "logs_root = Path(\"log\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9e01e1c3-96f6-441b-bdef-e3250a625a71",
   "metadata": {},
   "outputs": [],
   "source": [
    "METRIC_FOR_DS = {\n",
    "    \"mimic3\": \"MulticlassAUROC\",\n",
    "    \"physionet2012\": \"MulticlassAUROC\",\n",
    "    \"age\": \"MulticlassAccuracy\",\n",
    "    \"x5\": \"MulticlassAccuracy\",\n",
    "    \"pendulum\": \"R2Score\",\n",
    "    \"taobao\": \"MulticlassAUROC\",\n",
    "    \"mbd\": \"MultiLabelMeanAUROC\",\n",
    "}\n",
    "METRIC_PRETTY = {\n",
    "    \"MIMIC-III\": \"ROC AUC\",\n",
    "    \"PhysioNet2012\": \"ROC AUC\",\n",
    "    \"Age\": \"Accuracy\",\n",
    "    \"Retail\": \"Accuracy\",\n",
    "    \"Pendulum\": \"R2\",\n",
    "    \"Taobao\": \"ROC AUC\",\n",
    "    \"MBD\": \"Mean ROC AUC\",\n",
    "}\n",
    "METHODS = [\"gru\", \"coles\", \"mlem\", \"mlp\", \"mamba\", \"transformer\", \"mtand\", \"primenet\"]\n",
    "METHODS_PRETTY = {\n",
    "    \"mtand\": \"mTAND\",\n",
    "    \"gru\": \"GRU\",\n",
    "    \"mlp\": \"MLP\",\n",
    "    \"mamba\": \"Mamba\",\n",
    "    \"coles\": \"CoLES\",\n",
    "    \"primenet\": \"PrimeNet\",\n",
    "    \"mlem\": \"MLEM\",\n",
    "    \"transformer\": \"Transformer\",\n",
    "}\n",
    "DATASETS = [\n",
    "    \"x5\",\n",
    "    # \"mbd\",\n",
    "    \"age\",\n",
    "    \"physionet2012\",\n",
    "    \"mimic3\",\n",
    "    \"pendulum\",\n",
    "    \"taobao\",\n",
    "]\n",
    "DATASETS_PRETTY = {\n",
    "    \"x5\": \"Retail\",\n",
    "    \"age\": \"Age\",\n",
    "    \"physionet2012\": \"PhysioNet2012\",\n",
    "    \"pendulum\": \"Pendulum\",\n",
    "    \"mimic3\": \"MIMIC-III\",\n",
    "    \"mbd\": \"MBD\",\n",
    "    \"taobao\": \"Taobao\",\n",
    "}\n",
    "\n",
    "\n",
    "def print_latex(df):\n",
    "    df = df.copy()\n",
    "    df.columns = pd.MultiIndex.from_tuples(\n",
    "        [(f\"\\\\textbf{{{col}}}\", f\"\\\\footnotesize{{{METRIC_PRETTY[col]}}}\") for col in df.columns],\n",
    "        names=[\"Dataset\", \"\\\\footnotesize{Metric}\"],\n",
    "    )\n",
    "    df.index.name = None\n",
    "    print(df.to_latex(bold_rows=True, column_format=\"r\" + \"c\" * len(df.columns)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72551a9c-c3bf-4c91-add0-5a988cbdf275",
   "metadata": {},
   "source": [
    "# Pick config details"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f5844c0f-b2e4-40d0-9918-ba2649e6e848",
   "metadata": {},
   "outputs": [],
   "source": [
    "opts = []\n",
    "\n",
    "for d in DATASETS:\n",
    "    for m in METHODS:\n",
    "        path = logs_root / d / m / \"correlation\" / \"seed_0\" / \"config.yaml\"\n",
    "        with open(path) as f:\n",
    "            config = yaml.load(f, yaml.SafeLoader)\n",
    "        try:\n",
    "            opt = config[\"model\"][\"preprocess\"][\"params\"][\"time_process\"]\n",
    "        except KeyError:\n",
    "            opt = None\n",
    "            \n",
    "        opts.append(dict(\n",
    "            dataset=d,\n",
    "            method=m,\n",
    "            option=opt\n",
    "        ))\n",
    "\n",
    "df_options = (\n",
    "    pd.DataFrame(opts)\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "73a55288-2209-4e89-81af-f22ce013160f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLEM</th>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Transformer</th>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset       Age MIMIC-III Pendulum PhysioNet2012 Retail Taobao\n",
       "method                                                          \n",
       "CoLES         cat      diff      cat           cat   none   diff\n",
       "GRU           cat       cat      cat          none   diff   diff\n",
       "MLEM          cat      diff      cat           cat   none   diff\n",
       "MLP           cat       cat      cat          diff   diff   diff\n",
       "Mamba        diff       cat      cat           cat   diff   diff\n",
       "PrimeNet     diff      diff      cat          none   none   diff\n",
       "Transformer  diff       cat      cat           cat    cat    cat\n",
       "mTAND        diff      diff      cat           cat   none   diff"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_options.pivot(index=\"method\", columns=\"dataset\", values=\"option\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "974438c7-f509-43f9-8188-efcc066e1d1f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLEM</th>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Transformer</th>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>diff</td>\n",
       "      <td>diff</td>\n",
       "      <td>cat</td>\n",
       "      <td>cat</td>\n",
       "      <td>none</td>\n",
       "      <td>diff</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset       Age MIMIC-III Pendulum PhysioNet2012 Retail Taobao\n",
       "method                                                          \n",
       "CoLES         cat      diff      cat           cat   none   diff\n",
       "GRU           cat       cat      cat          none   diff   diff\n",
       "MLEM          cat      diff      cat           cat   none   diff\n",
       "MLP           cat       cat      cat          diff   diff   diff\n",
       "Mamba        diff       cat      cat           cat   diff   diff\n",
       "PrimeNet     diff      diff      cat          none   none   diff\n",
       "Transformer  diff       cat      cat           cat    cat    cat\n",
       "mTAND        diff      diff      cat           cat   none   diff"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_options.pivot(index=\"method\", columns=\"dataset\", values=\"option\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "053d2a35-cc8c-469e-b9d4-7a1dfbf34d03",
   "metadata": {},
   "source": [
    "# Collect metrics from experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "51f65369-d9dc-4a9c-9034-a1c8d733dc19",
   "metadata": {},
   "source": [
    "## Main"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "314dcaa3-ec2c-4bca-96b1-ef8f7d434651",
   "metadata": {},
   "outputs": [],
   "source": [
    "ms = []\n",
    "for d in DATASETS:\n",
    "    for m in METHODS:\n",
    "        path = logs_root / d / m / \"correlation\" / \"results.csv\"\n",
    "        try:\n",
    "            res = pd.read_csv(path, index_col=0)\n",
    "        except FileNotFoundError:\n",
    "            print(f\"Skipping {path}\")\n",
    "        else:\n",
    "            ms.append(pd.DataFrame(dict(\n",
    "                dataset=d,\n",
    "                method=m,\n",
    "                exp=\"main\",\n",
    "                seed=res.columns[:-2],\n",
    "                metric=res.loc[\"test_\" + METRIC_FOR_DS[d]].values[:-2],\n",
    "            )))\n",
    "\n",
    "df_eval = (\n",
    "    pd.concat(ms)\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")\n",
    "df_eval.pivot_table(index=\"method\", columns=\"dataset\", values=\"seed\", aggfunc=\"count\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a2dd2176-d390-4afc-8072-2a6bba04ba2a",
   "metadata": {},
   "source": [
    "## Time ablation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "85b738b4-5e8a-4643-b47a-de4f824dc883",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>metric</th>\n",
       "      <th>dataset</th>\n",
       "      <th>method</th>\n",
       "      <th>seed</th>\n",
       "      <th>exp</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.615905</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>0</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.601551</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>1</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.606336</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>2</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.610130</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>3</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.615245</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>4</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>615</th>\n",
       "      <td>0.902824</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>15</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>616</th>\n",
       "      <td>0.903514</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>16</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>617</th>\n",
       "      <td>0.902611</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>17</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>618</th>\n",
       "      <td>0.902720</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>18</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>619</th>\n",
       "      <td>0.903915</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>19</td>\n",
       "      <td>time</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>600 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       metric    dataset method  seed   exp\n",
       "0    0.615905        Age  Mamba     0  time\n",
       "1    0.601551        Age  Mamba     1  time\n",
       "2    0.606336        Age  Mamba     2  time\n",
       "3    0.610130        Age  Mamba     3  time\n",
       "4    0.615245        Age  Mamba     4  time\n",
       "..        ...        ...    ...   ...   ...\n",
       "615  0.902824  MIMIC-III  CoLES    15  time\n",
       "616  0.903514  MIMIC-III  CoLES    16  time\n",
       "617  0.902611  MIMIC-III  CoLES    17  time\n",
       "618  0.902720  MIMIC-III  CoLES    18  time\n",
       "619  0.903915  MIMIC-III  CoLES    19  time\n",
       "\n",
       "[600 rows x 5 columns]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_time = (\n",
    "    pd.read_csv(logs_root / \"time.csv\")\n",
    "    .assign(exp=\"time\")\n",
    "    .query(\"dataset != 'amex'\")\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")\n",
    "df_time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a315c5cd-73b3-4083-8b7a-ad3eca0f977a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset   Age  MIMIC-III  Pendulum  PhysioNet2012  Retail\n",
       "method                                                   \n",
       "CoLES      20         20        20             20      20\n",
       "GRU        20         20        20             20      20\n",
       "MLP        20         20        20             20      20\n",
       "Mamba      20         20        20             20      20\n",
       "PrimeNet   20         20        20             20      20\n",
       "mTAND      20         20        20             20      20"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_time.pivot_table(index=\"method\", columns=\"dataset\", values=\"seed\", aggfunc=\"count\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "42058a57-cfa6-4d91-acc3-43c06c411528",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>metric</th>\n",
       "      <th>dataset</th>\n",
       "      <th>method</th>\n",
       "      <th>seed</th>\n",
       "      <th>exp</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.608150</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>0</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.603201</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>1</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.582412</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>2</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.604356</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>3</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.597096</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>4</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>604</th>\n",
       "      <td>0.873675</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>15</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>605</th>\n",
       "      <td>0.872038</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>16</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>606</th>\n",
       "      <td>0.869259</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>17</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>607</th>\n",
       "      <td>0.874762</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>18</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>608</th>\n",
       "      <td>0.872158</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>19</td>\n",
       "      <td>perm</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>589 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       metric    dataset method  seed   exp\n",
       "0    0.608150        Age  Mamba     0  perm\n",
       "1    0.603201        Age  Mamba     1  perm\n",
       "2    0.582412        Age  Mamba     2  perm\n",
       "3    0.604356        Age  Mamba     3  perm\n",
       "4    0.597096        Age  Mamba     4  perm\n",
       "..        ...        ...    ...   ...   ...\n",
       "604  0.873675  MIMIC-III  CoLES    15  perm\n",
       "605  0.872038  MIMIC-III  CoLES    16  perm\n",
       "606  0.869259  MIMIC-III  CoLES    17  perm\n",
       "607  0.874762  MIMIC-III  CoLES    18  perm\n",
       "608  0.872158  MIMIC-III  CoLES    19  perm\n",
       "\n",
       "[589 rows x 5 columns]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_perm = (\n",
    "    pd.read_csv(logs_root / \"permutation.csv\")\n",
    "    .assign(exp=\"perm\")\n",
    "    .query(\"dataset != 'amex'\")\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")\n",
    "df_perm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b9906599-ea9d-48b1-b5a9-c69a178612a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset   Age  MIMIC-III  Pendulum  PhysioNet2012  Retail\n",
       "method                                                   \n",
       "CoLES      20         20        20             20      20\n",
       "GRU        20         20        20             20      20\n",
       "MLP        20         20        20             20      20\n",
       "Mamba      20         20        20             20      20\n",
       "PrimeNet   20         20        20             20       9\n",
       "mTAND      20         20        20             20      20"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_perm.pivot_table(index=\"method\", columns=\"dataset\", values=\"seed\", aggfunc=\"count\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2c85f6e9-8472-47d3-999f-b6e303262caa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>metric</th>\n",
       "      <th>dataset</th>\n",
       "      <th>method</th>\n",
       "      <th>seed</th>\n",
       "      <th>exp</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.603861</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>0</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.602211</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>1</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.590827</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>2</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.604191</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>3</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.603696</td>\n",
       "      <td>Age</td>\n",
       "      <td>Mamba</td>\n",
       "      <td>4</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>595</th>\n",
       "      <td>0.884485</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>15</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>596</th>\n",
       "      <td>0.884754</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>16</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>597</th>\n",
       "      <td>0.883535</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>17</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>598</th>\n",
       "      <td>0.887248</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>18</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>599</th>\n",
       "      <td>0.891277</td>\n",
       "      <td>MIMIC-III</td>\n",
       "      <td>CoLES</td>\n",
       "      <td>19</td>\n",
       "      <td>perm_kl</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>600 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       metric    dataset method  seed      exp\n",
       "0    0.603861        Age  Mamba     0  perm_kl\n",
       "1    0.602211        Age  Mamba     1  perm_kl\n",
       "2    0.590827        Age  Mamba     2  perm_kl\n",
       "3    0.604191        Age  Mamba     3  perm_kl\n",
       "4    0.603696        Age  Mamba     4  perm_kl\n",
       "..        ...        ...    ...   ...      ...\n",
       "595  0.884485  MIMIC-III  CoLES    15  perm_kl\n",
       "596  0.884754  MIMIC-III  CoLES    16  perm_kl\n",
       "597  0.883535  MIMIC-III  CoLES    17  perm_kl\n",
       "598  0.887248  MIMIC-III  CoLES    18  perm_kl\n",
       "599  0.891277  MIMIC-III  CoLES    19  perm_kl\n",
       "\n",
       "[600 rows x 5 columns]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_perm_kl = (\n",
    "    pd.read_csv(logs_root / \"permutation_keep_last.csv\")\n",
    "    .assign(exp=\"perm_kl\")\n",
    "    .query(\"dataset != 'amex'\")\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")\n",
    "df_perm_kl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7cb5b32e-f074-4493-b9a9-1c46dc8aa39b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset   Age  MIMIC-III  Pendulum  PhysioNet2012  Retail\n",
       "method                                                   \n",
       "CoLES      20         20        20             20      20\n",
       "GRU        20         20        20             20      20\n",
       "MLP        20         20        20             20      20\n",
       "Mamba      20         20        20             20      20\n",
       "PrimeNet   20         20        20             20      20\n",
       "mTAND      20         20        20             20      20"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_perm_kl.pivot_table(index=\"method\", columns=\"dataset\", values=\"seed\", aggfunc=\"count\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "277c162a-124b-4211-a4df-a422e8f8c599",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = (\n",
    "    pd.concat((df_eval, df_time, df_perm, df_perm_kl))\n",
    "    .assign(method=lambda df: df[\"method\"].replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df[\"dataset\"].replace(DATASETS_PRETTY))\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "adfe2ce2-ed55-4906-b097-803c1e686fdb",
   "metadata": {},
   "source": [
    "# Main metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "e63d4722-46d3-47a7-949c-ab58076e9277",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$0.634 \\pm 0.005$</td>\n",
       "      <td>$0.902 \\pm 0.001$</td>\n",
       "      <td>$0.916 \\pm 0.004$</td>\n",
       "      <td>$0.840 \\pm 0.004$</td>\n",
       "      <td>$0.553 \\pm 0.002$</td>\n",
       "      <td>$0.713 \\pm 0.002$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$0.626 \\pm 0.004$</td>\n",
       "      <td>$0.901 \\pm 0.002$</td>\n",
       "      <td>$0.896 \\pm 0.010$</td>\n",
       "      <td>$0.846 \\pm 0.004$</td>\n",
       "      <td>$0.543 \\pm 0.002$</td>\n",
       "      <td>$0.713 \\pm 0.004$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLEM</th>\n",
       "      <td>$0.634 \\pm 0.003$</td>\n",
       "      <td>$0.899 \\pm 0.002$</td>\n",
       "      <td>$0.890 \\pm 0.007$</td>\n",
       "      <td>$0.846 \\pm 0.007$</td>\n",
       "      <td>$0.544 \\pm 0.002$</td>\n",
       "      <td>$0.713 \\pm 0.004$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$0.581 \\pm 0.007$</td>\n",
       "      <td>$0.881 \\pm 0.001$</td>\n",
       "      <td>$0.165 \\pm 0.005$</td>\n",
       "      <td>$0.835 \\pm 0.004$</td>\n",
       "      <td>$0.526 \\pm 0.002$</td>\n",
       "      <td>$0.659 \\pm 0.035$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$0.609 \\pm 0.006$</td>\n",
       "      <td>$0.895 \\pm 0.002$</td>\n",
       "      <td>$0.908 \\pm 0.005$</td>\n",
       "      <td>$0.835 \\pm 0.006$</td>\n",
       "      <td>$0.538 \\pm 0.003$</td>\n",
       "      <td>$0.693 \\pm 0.023$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$0.583 \\pm 0.011$</td>\n",
       "      <td>$0.887 \\pm 0.004$</td>\n",
       "      <td>$0.842 \\pm 0.017$</td>\n",
       "      <td>$0.807 \\pm 0.065$</td>\n",
       "      <td>$0.521 \\pm 0.003$</td>\n",
       "      <td>$0.681 \\pm 0.010$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Transformer</th>\n",
       "      <td>$0.621 \\pm 0.006$</td>\n",
       "      <td>$0.894 \\pm 0.002$</td>\n",
       "      <td>$0.891 \\pm 0.015$</td>\n",
       "      <td>$0.838 \\pm 0.008$</td>\n",
       "      <td>$0.536 \\pm 0.006$</td>\n",
       "      <td>$0.692 \\pm 0.013$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$0.582 \\pm 0.009$</td>\n",
       "      <td>$0.888 \\pm 0.003$</td>\n",
       "      <td>$0.941 \\pm 0.009$</td>\n",
       "      <td>$0.841 \\pm 0.005$</td>\n",
       "      <td>$0.519 \\pm 0.003$</td>\n",
       "      <td>$0.672 \\pm 0.010$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset                    Age          MIMIC-III           Pendulum  \\\n",
       "method                                                                 \n",
       "CoLES        $0.634 \\pm 0.005$  $0.902 \\pm 0.001$  $0.916 \\pm 0.004$   \n",
       "GRU          $0.626 \\pm 0.004$  $0.901 \\pm 0.002$  $0.896 \\pm 0.010$   \n",
       "MLEM         $0.634 \\pm 0.003$  $0.899 \\pm 0.002$  $0.890 \\pm 0.007$   \n",
       "MLP          $0.581 \\pm 0.007$  $0.881 \\pm 0.001$  $0.165 \\pm 0.005$   \n",
       "Mamba        $0.609 \\pm 0.006$  $0.895 \\pm 0.002$  $0.908 \\pm 0.005$   \n",
       "PrimeNet     $0.583 \\pm 0.011$  $0.887 \\pm 0.004$  $0.842 \\pm 0.017$   \n",
       "Transformer  $0.621 \\pm 0.006$  $0.894 \\pm 0.002$  $0.891 \\pm 0.015$   \n",
       "mTAND        $0.582 \\pm 0.009$  $0.888 \\pm 0.003$  $0.941 \\pm 0.009$   \n",
       "\n",
       "dataset          PhysioNet2012             Retail             Taobao  \n",
       "method                                                                \n",
       "CoLES        $0.840 \\pm 0.004$  $0.553 \\pm 0.002$  $0.713 \\pm 0.002$  \n",
       "GRU          $0.846 \\pm 0.004$  $0.543 \\pm 0.002$  $0.713 \\pm 0.004$  \n",
       "MLEM         $0.846 \\pm 0.007$  $0.544 \\pm 0.002$  $0.713 \\pm 0.004$  \n",
       "MLP          $0.835 \\pm 0.004$  $0.526 \\pm 0.002$  $0.659 \\pm 0.035$  \n",
       "Mamba        $0.835 \\pm 0.006$  $0.538 \\pm 0.003$  $0.693 \\pm 0.023$  \n",
       "PrimeNet     $0.807 \\pm 0.065$  $0.521 \\pm 0.003$  $0.681 \\pm 0.010$  \n",
       "Transformer  $0.838 \\pm 0.008$  $0.536 \\pm 0.006$  $0.692 \\pm 0.013$  \n",
       "mTAND        $0.841 \\pm 0.005$  $0.519 \\pm 0.003$  $0.672 \\pm 0.010$  "
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main_res = df_eval.pivot_table(\n",
    "    index=\"method\",\n",
    "    columns=\"dataset\",\n",
    "    values=\"metric\",\n",
    "    aggfunc=[\"mean\", \"std\"],\n",
    ")\n",
    "main_res_latex = (\n",
    "    main_res.loc[:, \"mean\"].map(lambda x: f\"${x:.3f} \\pm \")\n",
    "    + main_res.loc[:, \"std\"].map(lambda x: f\"{x:.3f}$\")\n",
    ")\n",
    "main_res_latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ee4d9acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rcccccc}\n",
      "\\toprule\n",
      "Dataset & \\textbf{Age} & \\textbf{MIMIC-III} & \\textbf{Pendulum} & \\textbf{PhysioNet2012} & \\textbf{Retail} & \\textbf{Taobao} \\\\\n",
      "\\footnotesize{Metric} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} & \\footnotesize{R2} & \\footnotesize{ROC AUC} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} \\\\\n",
      "\\midrule\n",
      "\\textbf{CoLES} & $0.634 \\pm 0.005$ & $0.902 \\pm 0.001$ & $0.916 \\pm 0.004$ & $0.840 \\pm 0.004$ & $0.553 \\pm 0.002$ & $0.713 \\pm 0.002$ \\\\\n",
      "\\textbf{GRU} & $0.626 \\pm 0.004$ & $0.901 \\pm 0.002$ & $0.896 \\pm 0.010$ & $0.846 \\pm 0.004$ & $0.543 \\pm 0.002$ & $0.713 \\pm 0.004$ \\\\\n",
      "\\textbf{MLEM} & $0.634 \\pm 0.003$ & $0.899 \\pm 0.002$ & $0.890 \\pm 0.007$ & $0.846 \\pm 0.007$ & $0.544 \\pm 0.002$ & $0.713 \\pm 0.004$ \\\\\n",
      "\\textbf{MLP} & $0.581 \\pm 0.007$ & $0.881 \\pm 0.001$ & $0.165 \\pm 0.005$ & $0.835 \\pm 0.004$ & $0.526 \\pm 0.002$ & $0.659 \\pm 0.035$ \\\\\n",
      "\\textbf{Mamba} & $0.609 \\pm 0.006$ & $0.895 \\pm 0.002$ & $0.908 \\pm 0.005$ & $0.835 \\pm 0.006$ & $0.538 \\pm 0.003$ & $0.693 \\pm 0.023$ \\\\\n",
      "\\textbf{PrimeNet} & $0.583 \\pm 0.011$ & $0.887 \\pm 0.004$ & $0.842 \\pm 0.017$ & $0.807 \\pm 0.065$ & $0.521 \\pm 0.003$ & $0.681 \\pm 0.010$ \\\\\n",
      "\\textbf{Transformer} & $0.621 \\pm 0.006$ & $0.894 \\pm 0.002$ & $0.891 \\pm 0.015$ & $0.838 \\pm 0.008$ & $0.536 \\pm 0.006$ & $0.692 \\pm 0.013$ \\\\\n",
      "\\textbf{mTAND} & $0.582 \\pm 0.009$ & $0.888 \\pm 0.003$ & $0.941 \\pm 0.009$ & $0.841 \\pm 0.005$ & $0.519 \\pm 0.003$ & $0.672 \\pm 0.010$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_latex(main_res_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "78f76e9f-1265-485f-8bfd-420e6b9111f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$0.634 \\pm 0.8\\%$</td>\n",
       "      <td>$0.902 \\pm 0.1\\%$</td>\n",
       "      <td>$0.916 \\pm 0.4\\%$</td>\n",
       "      <td>$0.840 \\pm 0.5\\%$</td>\n",
       "      <td>$0.553 \\pm 0.3\\%$</td>\n",
       "      <td>$0.713 \\pm 0.3\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$0.626 \\pm 0.7\\%$</td>\n",
       "      <td>$0.901 \\pm 0.2\\%$</td>\n",
       "      <td>$0.896 \\pm 1.1\\%$</td>\n",
       "      <td>$0.846 \\pm 0.5\\%$</td>\n",
       "      <td>$0.543 \\pm 0.5\\%$</td>\n",
       "      <td>$0.713 \\pm 0.5\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLEM</th>\n",
       "      <td>$0.634 \\pm 0.5\\%$</td>\n",
       "      <td>$0.899 \\pm 0.3\\%$</td>\n",
       "      <td>$0.890 \\pm 0.8\\%$</td>\n",
       "      <td>$0.846 \\pm 0.9\\%$</td>\n",
       "      <td>$0.544 \\pm 0.4\\%$</td>\n",
       "      <td>$0.713 \\pm 0.6\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$0.581 \\pm 1.2\\%$</td>\n",
       "      <td>$0.881 \\pm 0.1\\%$</td>\n",
       "      <td>$0.165 \\pm 3.0\\%$</td>\n",
       "      <td>$0.835 \\pm 0.5\\%$</td>\n",
       "      <td>$0.526 \\pm 0.4\\%$</td>\n",
       "      <td>$0.659 \\pm 5.3\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$0.609 \\pm 1.0\\%$</td>\n",
       "      <td>$0.895 \\pm 0.3\\%$</td>\n",
       "      <td>$0.908 \\pm 0.6\\%$</td>\n",
       "      <td>$0.835 \\pm 0.7\\%$</td>\n",
       "      <td>$0.538 \\pm 0.6\\%$</td>\n",
       "      <td>$0.693 \\pm 3.3\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$0.583 \\pm 1.9\\%$</td>\n",
       "      <td>$0.887 \\pm 0.4\\%$</td>\n",
       "      <td>$0.842 \\pm 2.0\\%$</td>\n",
       "      <td>$0.807 \\pm 8.0\\%$</td>\n",
       "      <td>$0.521 \\pm 0.5\\%$</td>\n",
       "      <td>$0.681 \\pm 1.4\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Transformer</th>\n",
       "      <td>$0.621 \\pm 0.9\\%$</td>\n",
       "      <td>$0.894 \\pm 0.2\\%$</td>\n",
       "      <td>$0.891 \\pm 1.7\\%$</td>\n",
       "      <td>$0.838 \\pm 1.0\\%$</td>\n",
       "      <td>$0.536 \\pm 1.1\\%$</td>\n",
       "      <td>$0.692 \\pm 1.9\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$0.582 \\pm 1.5\\%$</td>\n",
       "      <td>$0.888 \\pm 0.3\\%$</td>\n",
       "      <td>$0.941 \\pm 0.9\\%$</td>\n",
       "      <td>$0.841 \\pm 0.6\\%$</td>\n",
       "      <td>$0.519 \\pm 0.6\\%$</td>\n",
       "      <td>$0.672 \\pm 1.6\\%$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset                    Age          MIMIC-III           Pendulum  \\\n",
       "method                                                                 \n",
       "CoLES        $0.634 \\pm 0.8\\%$  $0.902 \\pm 0.1\\%$  $0.916 \\pm 0.4\\%$   \n",
       "GRU          $0.626 \\pm 0.7\\%$  $0.901 \\pm 0.2\\%$  $0.896 \\pm 1.1\\%$   \n",
       "MLEM         $0.634 \\pm 0.5\\%$  $0.899 \\pm 0.3\\%$  $0.890 \\pm 0.8\\%$   \n",
       "MLP          $0.581 \\pm 1.2\\%$  $0.881 \\pm 0.1\\%$  $0.165 \\pm 3.0\\%$   \n",
       "Mamba        $0.609 \\pm 1.0\\%$  $0.895 \\pm 0.3\\%$  $0.908 \\pm 0.6\\%$   \n",
       "PrimeNet     $0.583 \\pm 1.9\\%$  $0.887 \\pm 0.4\\%$  $0.842 \\pm 2.0\\%$   \n",
       "Transformer  $0.621 \\pm 0.9\\%$  $0.894 \\pm 0.2\\%$  $0.891 \\pm 1.7\\%$   \n",
       "mTAND        $0.582 \\pm 1.5\\%$  $0.888 \\pm 0.3\\%$  $0.941 \\pm 0.9\\%$   \n",
       "\n",
       "dataset          PhysioNet2012             Retail             Taobao  \n",
       "method                                                                \n",
       "CoLES        $0.840 \\pm 0.5\\%$  $0.553 \\pm 0.3\\%$  $0.713 \\pm 0.3\\%$  \n",
       "GRU          $0.846 \\pm 0.5\\%$  $0.543 \\pm 0.5\\%$  $0.713 \\pm 0.5\\%$  \n",
       "MLEM         $0.846 \\pm 0.9\\%$  $0.544 \\pm 0.4\\%$  $0.713 \\pm 0.6\\%$  \n",
       "MLP          $0.835 \\pm 0.5\\%$  $0.526 \\pm 0.4\\%$  $0.659 \\pm 5.3\\%$  \n",
       "Mamba        $0.835 \\pm 0.7\\%$  $0.538 \\pm 0.6\\%$  $0.693 \\pm 3.3\\%$  \n",
       "PrimeNet     $0.807 \\pm 8.0\\%$  $0.521 \\pm 0.5\\%$  $0.681 \\pm 1.4\\%$  \n",
       "Transformer  $0.838 \\pm 1.0\\%$  $0.536 \\pm 1.1\\%$  $0.692 \\pm 1.9\\%$  \n",
       "mTAND        $0.841 \\pm 0.6\\%$  $0.519 \\pm 0.6\\%$  $0.672 \\pm 1.6\\%$  "
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main_res_rel_latex = (\n",
    "    main_res.loc[:, \"mean\"].map(lambda x: f\"${x:.3f} \\pm \")\n",
    "    + (main_res.loc[:, \"std\"] / main_res.loc[:, \"mean\"] * 100).map(lambda x: f\"{x:.1f}\\%$\")\n",
    ")\n",
    "main_res_rel_latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "05483767-3e34-4131-9265-2b03125fa639",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rcccccc}\n",
      "\\toprule\n",
      "Dataset & \\textbf{Age} & \\textbf{MIMIC-III} & \\textbf{Pendulum} & \\textbf{PhysioNet2012} & \\textbf{Retail} & \\textbf{Taobao} \\\\\n",
      "\\footnotesize{Metric} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} & \\footnotesize{R2} & \\footnotesize{ROC AUC} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} \\\\\n",
      "\\midrule\n",
      "\\textbf{CoLES} & $0.634 \\pm 0.005$ & $0.902 \\pm 0.001$ & $0.916 \\pm 0.004$ & $0.840 \\pm 0.004$ & $0.553 \\pm 0.002$ & $0.713 \\pm 0.002$ \\\\\n",
      "\\textbf{GRU} & $0.626 \\pm 0.004$ & $0.901 \\pm 0.002$ & $0.896 \\pm 0.010$ & $0.846 \\pm 0.004$ & $0.543 \\pm 0.002$ & $0.713 \\pm 0.004$ \\\\\n",
      "\\textbf{MLEM} & $0.634 \\pm 0.003$ & $0.899 \\pm 0.002$ & $0.890 \\pm 0.007$ & $0.846 \\pm 0.007$ & $0.544 \\pm 0.002$ & $0.713 \\pm 0.004$ \\\\\n",
      "\\textbf{MLP} & $0.581 \\pm 0.007$ & $0.881 \\pm 0.001$ & $0.165 \\pm 0.005$ & $0.835 \\pm 0.004$ & $0.526 \\pm 0.002$ & $0.659 \\pm 0.035$ \\\\\n",
      "\\textbf{Mamba} & $0.609 \\pm 0.006$ & $0.895 \\pm 0.002$ & $0.908 \\pm 0.005$ & $0.835 \\pm 0.006$ & $0.538 \\pm 0.003$ & $0.693 \\pm 0.023$ \\\\\n",
      "\\textbf{PrimeNet} & $0.583 \\pm 0.011$ & $0.887 \\pm 0.004$ & $0.842 \\pm 0.017$ & $0.807 \\pm 0.065$ & $0.521 \\pm 0.003$ & $0.681 \\pm 0.010$ \\\\\n",
      "\\textbf{Transformer} & $0.621 \\pm 0.006$ & $0.894 \\pm 0.002$ & $0.891 \\pm 0.015$ & $0.838 \\pm 0.008$ & $0.536 \\pm 0.006$ & $0.692 \\pm 0.013$ \\\\\n",
      "\\textbf{mTAND} & $0.582 \\pm 0.009$ & $0.888 \\pm 0.003$ & $0.941 \\pm 0.009$ & $0.841 \\pm 0.005$ & $0.519 \\pm 0.003$ & $0.672 \\pm 0.010$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_latex(main_res_latex)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2ebfbed0-4439-4e6e-8efa-276ec2c394da",
   "metadata": {},
   "source": [
    "# Ablations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b24f8cd9-abfa-457a-b259-12e040b3b80c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pvals(df: pd.DataFrame, exp1: str, exp2: str):\n",
    "    rows = []\n",
    "    name = exp1 + \" VS \" + exp2\n",
    "    for d in DATASETS_PRETTY.values():\n",
    "        for m in METHODS_PRETTY.values():\n",
    "            a = df.query(\"method == @m and dataset == @d and exp == @exp1\")[\"metric\"]\n",
    "            b = df.query(\"method == @m and dataset == @d and exp == @exp2\")[\"metric\"]\n",
    "            rows.append({\n",
    "                \"dataset\": d,\n",
    "                \"method\": m,\n",
    "                name: stats.ttest_ind(a, b, equal_var=False).pvalue\n",
    "            })\n",
    "    return pd.DataFrame(rows).pivot(index=\"method\", columns=\"dataset\", values=name).dropna(axis=0, how=\"all\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "04921f10-ec05-4978-a45f-d315cb759681",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_pval_formatter(threshold: float = 0.01):\n",
    "    \n",
    "    def fmt(pval: float) -> str:\n",
    "        if pval < threshold:\n",
    "            return f\"$<{threshold:.2f}$\"\n",
    "        return f\"${pval:.2f}$\"\n",
    "\n",
    "    return fmt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "85e5dcb4-b829-4bbb-b6d9-972bb7fef284",
   "metadata": {},
   "source": [
    "## Random time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "3f5f26d3-a0d5-437a-ab56-d83790f91641",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"5\" halign=\"left\">mean</th>\n",
       "      <th colspan=\"5\" halign=\"left\">std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>0.583163</td>\n",
       "      <td>0.887535</td>\n",
       "      <td>0.382374</td>\n",
       "      <td>0.839798</td>\n",
       "      <td>0.520654</td>\n",
       "      <td>0.006649</td>\n",
       "      <td>0.00632</td>\n",
       "      <td>0.090766</td>\n",
       "      <td>0.003869</td>\n",
       "      <td>0.002726</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>0.578964</td>\n",
       "      <td>0.880029</td>\n",
       "      <td>0.500042</td>\n",
       "      <td>0.838533</td>\n",
       "      <td>0.517128</td>\n",
       "      <td>0.005319</td>\n",
       "      <td>0.00712</td>\n",
       "      <td>0.109345</td>\n",
       "      <td>0.005621</td>\n",
       "      <td>0.003665</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              mean                                                   std  \\\n",
       "dataset        Age MIMIC-III  Pendulum PhysioNet2012    Retail       Age   \n",
       "method                                                                     \n",
       "PrimeNet  0.583163  0.887535  0.382374      0.839798  0.520654  0.006649   \n",
       "mTAND     0.578964  0.880029  0.500042      0.838533  0.517128  0.005319   \n",
       "\n",
       "                                                      \n",
       "dataset  MIMIC-III  Pendulum PhysioNet2012    Retail  \n",
       "method                                                \n",
       "PrimeNet   0.00632  0.090766      0.003869  0.002726  \n",
       "mTAND      0.00712  0.109345      0.005621  0.003665  "
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abl_time_res = df_time.pivot_table(\n",
    "    index=\"method\",\n",
    "    columns=\"dataset\",\n",
    "    values=\"metric\",\n",
    "    aggfunc=[\"mean\", \"std\"],\n",
    ").loc[[\"PrimeNet\", \"mTAND\"]]\n",
    "abl_time_res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "3ee51bbf-5ec9-456f-8dc5-7c3619a75d3f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$0.583 \\pm 0.007$</td>\n",
       "      <td>$0.888 \\pm 0.006$</td>\n",
       "      <td>$0.382 \\pm 0.091$</td>\n",
       "      <td>$0.840 \\pm 0.004$</td>\n",
       "      <td>$0.521 \\pm 0.003$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$0.579 \\pm 0.005$</td>\n",
       "      <td>$0.880 \\pm 0.007$</td>\n",
       "      <td>$0.500 \\pm 0.109$</td>\n",
       "      <td>$0.839 \\pm 0.006$</td>\n",
       "      <td>$0.517 \\pm 0.004$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset                 Age          MIMIC-III           Pendulum  \\\n",
       "method                                                              \n",
       "PrimeNet  $0.583 \\pm 0.007$  $0.888 \\pm 0.006$  $0.382 \\pm 0.091$   \n",
       "mTAND     $0.579 \\pm 0.005$  $0.880 \\pm 0.007$  $0.500 \\pm 0.109$   \n",
       "\n",
       "dataset       PhysioNet2012             Retail  \n",
       "method                                          \n",
       "PrimeNet  $0.840 \\pm 0.004$  $0.521 \\pm 0.003$  \n",
       "mTAND     $0.839 \\pm 0.006$  $0.517 \\pm 0.004$  "
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abl_time_latex = (\n",
    "    abl_time_res.loc[:, \"mean\"].map(lambda x: f\"${x:.3f} \\pm \")\n",
    "    + abl_time_res.loc[:, \"std\"].map(lambda x: f\"{x:.3f}$\")\n",
    ")\n",
    "abl_time_latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "9d48a850-6a34-46e3-a246-6735c9ca0344",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rccccc}\n",
      "\\toprule\n",
      "Dataset & \\textbf{Age} & \\textbf{MIMIC-III} & \\textbf{Pendulum} & \\textbf{PhysioNet2012} & \\textbf{Retail} \\\\\n",
      "\\footnotesize{Metric} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} & \\footnotesize{R2} & \\footnotesize{ROC AUC} & \\footnotesize{Accuracy} \\\\\n",
      "\\midrule\n",
      "\\textbf{PrimeNet} & $0.583 \\pm 0.007$ & $0.888 \\pm 0.006$ & $0.382 \\pm 0.091$ & $0.840 \\pm 0.004$ & $0.521 \\pm 0.003$ \\\\\n",
      "\\textbf{mTAND} & $0.579 \\pm 0.005$ & $0.880 \\pm 0.007$ & $0.500 \\pm 0.109$ & $0.839 \\pm 0.006$ & $0.517 \\pm 0.004$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_latex(abl_time_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "16375df3-4538-4071-9f62-8b0dff8d2792",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MBD</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.184626</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.999773</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>0.931582</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.888382</td>\n",
       "      <td>9.211562e-16</td>\n",
       "      <td>0.032940</td>\n",
       "      <td>0.657170</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>0.263451</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.000044</td>\n",
       "      <td>1.738127e-13</td>\n",
       "      <td>0.162791</td>\n",
       "      <td>0.099581</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset        Age  MBD  MIMIC-III      Pendulum  PhysioNet2012    Retail  \\\n",
       "method                                                                      \n",
       "CoLES     1.000000  NaN   1.000000  1.000000e+00       0.184626  1.000000   \n",
       "GRU       1.000000  NaN   1.000000  1.000000e+00       1.000000  1.000000   \n",
       "MLP       1.000000  NaN   1.000000  1.000000e+00       1.000000  1.000000   \n",
       "Mamba     1.000000  NaN   1.000000  1.000000e+00       0.999773  1.000000   \n",
       "PrimeNet  0.931582  NaN   0.888382  9.211562e-16       0.032940  0.657170   \n",
       "mTAND     0.263451  NaN   0.000044  1.738127e-13       0.162791  0.099581   \n",
       "\n",
       "dataset   Taobao  \n",
       "method            \n",
       "CoLES        NaN  \n",
       "GRU          NaN  \n",
       "MLP          NaN  \n",
       "Mamba        NaN  \n",
       "PrimeNet     NaN  \n",
       "mTAND        NaN  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pvals(df, \"main\", \"time\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b075ef1-c16f-4789-b05e-adeb573a74b2",
   "metadata": {},
   "source": [
    "## Events permutation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "7ce1b649",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Taobao</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>setting</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU w/o time with permutation</th>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset                        Age  MIMIC-III  Pendulum  PhysioNet2012  \\\n",
       "setting                                                                  \n",
       "GRU                             20         20        20             20   \n",
       "GRU w/o time with permutation   20         20        20             20   \n",
       "\n",
       "dataset                        Retail  Taobao  \n",
       "setting                                        \n",
       "GRU                                20      20  \n",
       "GRU w/o time with permutation      20      20  "
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ms = []\n",
    "for d in DATASETS:\n",
    "    for exp in [\"GRU\", \"GRU w/o time with permutation\"]:\n",
    "        path = logs_root / d / \"gru\" / \"correlation\" / \"results.csv\"\n",
    "        if exp != \"GRU BHP\":\n",
    "            path = logs_root / d / \"gru\" / \"permutation_keep_last\" / \"results.csv\"\n",
    "        try:\n",
    "            res = pd.read_csv(path, index_col=0)\n",
    "        except FileNotFoundError:\n",
    "            print(f\"Skipping {path}\")\n",
    "        else:\n",
    "            ms.append(pd.DataFrame(dict(\n",
    "                setting=exp,\n",
    "                dataset=d,\n",
    "                method=\"gru\",\n",
    "                exp=\"main\",\n",
    "                seed=res.columns[:-2],\n",
    "                metric=res.loc[\"test_\" + METRIC_FOR_DS[d]].values[:-2],\n",
    "            )))\n",
    "\n",
    "df_permute = (\n",
    "    pd.concat(ms)\n",
    "    .assign(method=lambda df: df.method.replace(METHODS_PRETTY))\n",
    "    .assign(dataset=lambda df: df.dataset.replace(DATASETS_PRETTY))\n",
    ")\n",
    "df_permute.pivot_table(index=\"setting\", columns=\"dataset\", values=\"seed\", aggfunc=\"count\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "d7df7b0b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rcccccc}\n",
      "\\toprule\n",
      "Dataset & \\textbf{Age} & \\textbf{MIMIC-III} & \\textbf{Pendulum} & \\textbf{PhysioNet2012} & \\textbf{Retail} & \\textbf{Taobao} \\\\\n",
      "\\footnotesize{Metric} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} & \\footnotesize{R2} & \\footnotesize{ROC AUC} & \\footnotesize{Accuracy} & \\footnotesize{ROC AUC} \\\\\n",
      "\\midrule\n",
      "\\textbf{GRU} & $0.630 \\pm 0.004$ & $0.890 \\pm 0.002$ & $0.581 \\pm 0.003$ & $0.844 \\pm 0.005$ & $0.546 \\pm 0.003$ & $0.702 \\pm 0.006$ \\\\\n",
      "\\textbf{GRU w/o time with permutation} & $0.630 \\pm 0.004$ & $0.890 \\pm 0.002$ & $0.581 \\pm 0.003$ & $0.844 \\pm 0.005$ & $0.546 \\pm 0.003$ & $0.702 \\pm 0.006$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df_permute_res = df_permute.pivot_table(\n",
    "    index=\"setting\",\n",
    "    columns=\"dataset\",\n",
    "    values=\"metric\",\n",
    "    aggfunc=[\"mean\", \"std\"],\n",
    ")\n",
    "df_permute_latex = (\n",
    "    df_permute_res.loc[:, \"mean\"].map(lambda x: f\"${x:.3f} \\pm \")\n",
    "    + df_permute_res.loc[:, \"std\"].map(lambda x: f\"{x:.3f}$\")\n",
    ")\n",
    "print_latex(df_permute_latex)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1d9e71b6",
   "metadata": {},
   "source": [
    "### No pretrain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "ece4ad75-a178-42d5-9055-6e8c44504f02",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"5\" halign=\"left\">mean</th>\n",
       "      <th colspan=\"5\" halign=\"left\">std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>0.624649</td>\n",
       "      <td>0.885372</td>\n",
       "      <td>-1.093690</td>\n",
       "      <td>0.822454</td>\n",
       "      <td>0.544533</td>\n",
       "      <td>0.006537</td>\n",
       "      <td>0.002987</td>\n",
       "      <td>0.408825</td>\n",
       "      <td>0.005845</td>\n",
       "      <td>0.003531</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>0.617118</td>\n",
       "      <td>0.861587</td>\n",
       "      <td>-1.142454</td>\n",
       "      <td>0.833177</td>\n",
       "      <td>0.530572</td>\n",
       "      <td>0.006200</td>\n",
       "      <td>0.006711</td>\n",
       "      <td>0.449495</td>\n",
       "      <td>0.005644</td>\n",
       "      <td>0.003888</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>0.580581</td>\n",
       "      <td>0.881054</td>\n",
       "      <td>0.165381</td>\n",
       "      <td>0.835443</td>\n",
       "      <td>0.525833</td>\n",
       "      <td>0.007185</td>\n",
       "      <td>0.001164</td>\n",
       "      <td>0.004974</td>\n",
       "      <td>0.004133</td>\n",
       "      <td>0.002061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>0.601031</td>\n",
       "      <td>0.867638</td>\n",
       "      <td>-2.281648</td>\n",
       "      <td>0.830018</td>\n",
       "      <td>0.524789</td>\n",
       "      <td>0.006276</td>\n",
       "      <td>0.016477</td>\n",
       "      <td>1.471252</td>\n",
       "      <td>0.008632</td>\n",
       "      <td>0.003797</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>0.544151</td>\n",
       "      <td>0.853179</td>\n",
       "      <td>0.120834</td>\n",
       "      <td>0.805889</td>\n",
       "      <td>0.383451</td>\n",
       "      <td>0.012874</td>\n",
       "      <td>0.006796</td>\n",
       "      <td>0.103091</td>\n",
       "      <td>0.006079</td>\n",
       "      <td>0.010063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>0.544217</td>\n",
       "      <td>0.851676</td>\n",
       "      <td>-0.730001</td>\n",
       "      <td>0.812311</td>\n",
       "      <td>0.354341</td>\n",
       "      <td>0.005301</td>\n",
       "      <td>0.005754</td>\n",
       "      <td>0.497187</td>\n",
       "      <td>0.005718</td>\n",
       "      <td>0.003040</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              mean                                                   std  \\\n",
       "dataset        Age MIMIC-III  Pendulum PhysioNet2012    Retail       Age   \n",
       "method                                                                     \n",
       "CoLES     0.624649  0.885372 -1.093690      0.822454  0.544533  0.006537   \n",
       "GRU       0.617118  0.861587 -1.142454      0.833177  0.530572  0.006200   \n",
       "MLP       0.580581  0.881054  0.165381      0.835443  0.525833  0.007185   \n",
       "Mamba     0.601031  0.867638 -2.281648      0.830018  0.524789  0.006276   \n",
       "PrimeNet  0.544151  0.853179  0.120834      0.805889  0.383451  0.012874   \n",
       "mTAND     0.544217  0.851676 -0.730001      0.812311  0.354341  0.005301   \n",
       "\n",
       "                                                      \n",
       "dataset  MIMIC-III  Pendulum PhysioNet2012    Retail  \n",
       "method                                                \n",
       "CoLES     0.002987  0.408825      0.005845  0.003531  \n",
       "GRU       0.006711  0.449495      0.005644  0.003888  \n",
       "MLP       0.001164  0.004974      0.004133  0.002061  \n",
       "Mamba     0.016477  1.471252      0.008632  0.003797  \n",
       "PrimeNet  0.006796  0.103091      0.006079  0.010063  \n",
       "mTAND     0.005754  0.497187      0.005718  0.003040  "
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abl_perm_kl_res = df_perm_kl.pivot_table(\n",
    "    index=\"method\",\n",
    "    columns=\"dataset\",\n",
    "    values=\"metric\",\n",
    "    aggfunc=[\"mean\", \"std\"],\n",
    ")\n",
    "abl_perm_kl_res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "c0636ddb-a797-422d-b4db-2c3578f81f34",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$0.634 \\pm 0.005$</td>\n",
       "      <td>$0.902 \\pm 0.001$</td>\n",
       "      <td>$0.916 \\pm 0.004$</td>\n",
       "      <td>$0.838 \\pm 0.009$</td>\n",
       "      <td>$0.553 \\pm 0.002$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$0.626 \\pm 0.004$</td>\n",
       "      <td>$0.901 \\pm 0.002$</td>\n",
       "      <td>$0.896 \\pm 0.010$</td>\n",
       "      <td>$0.846 \\pm 0.004$</td>\n",
       "      <td>$0.543 \\pm 0.002$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$0.581 \\pm 0.007$</td>\n",
       "      <td>$0.881 \\pm 0.001$</td>\n",
       "      <td>$0.165 \\pm 0.005$</td>\n",
       "      <td>$0.835 \\pm 0.004$</td>\n",
       "      <td>$0.526 \\pm 0.002$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$0.609 \\pm 0.006$</td>\n",
       "      <td>$0.895 \\pm 0.002$</td>\n",
       "      <td>$0.908 \\pm 0.005$</td>\n",
       "      <td>$0.835 \\pm 0.006$</td>\n",
       "      <td>$0.538 \\pm 0.003$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$0.584 \\pm 0.007$</td>\n",
       "      <td>$0.887 \\pm 0.006$</td>\n",
       "      <td>$0.788 \\pm 0.018$</td>\n",
       "      <td>$0.839 \\pm 0.004$</td>\n",
       "      <td>$0.521 \\pm 0.003$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$0.580 \\pm 0.005$</td>\n",
       "      <td>$0.880 \\pm 0.007$</td>\n",
       "      <td>$0.938 \\pm 0.013$</td>\n",
       "      <td>$0.840 \\pm 0.005$</td>\n",
       "      <td>$0.517 \\pm 0.004$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset                 Age          MIMIC-III           Pendulum  \\\n",
       "method                                                              \n",
       "CoLES     $0.634 \\pm 0.005$  $0.902 \\pm 0.001$  $0.916 \\pm 0.004$   \n",
       "GRU       $0.626 \\pm 0.004$  $0.901 \\pm 0.002$  $0.896 \\pm 0.010$   \n",
       "MLP       $0.581 \\pm 0.007$  $0.881 \\pm 0.001$  $0.165 \\pm 0.005$   \n",
       "Mamba     $0.609 \\pm 0.006$  $0.895 \\pm 0.002$  $0.908 \\pm 0.005$   \n",
       "PrimeNet  $0.584 \\pm 0.007$  $0.887 \\pm 0.006$  $0.788 \\pm 0.018$   \n",
       "mTAND     $0.580 \\pm 0.005$  $0.880 \\pm 0.007$  $0.938 \\pm 0.013$   \n",
       "\n",
       "dataset       PhysioNet2012             Retail  \n",
       "method                                          \n",
       "CoLES     $0.838 \\pm 0.009$  $0.553 \\pm 0.002$  \n",
       "GRU       $0.846 \\pm 0.004$  $0.543 \\pm 0.002$  \n",
       "MLP       $0.835 \\pm 0.004$  $0.526 \\pm 0.002$  \n",
       "Mamba     $0.835 \\pm 0.006$  $0.538 \\pm 0.003$  \n",
       "PrimeNet  $0.839 \\pm 0.004$  $0.521 \\pm 0.003$  \n",
       "mTAND     $0.840 \\pm 0.005$  $0.517 \\pm 0.004$  "
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main_res_latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "29a7ec35-40d9-4105-bf8d-3eb89420234d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>8.811791e-06</td>\n",
       "      <td>7.274862e-19</td>\n",
       "      <td>5.643368e-15</td>\n",
       "      <td>3.279115e-07</td>\n",
       "      <td>1.365499e-10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>8.005961e-06</td>\n",
       "      <td>2.861990e-18</td>\n",
       "      <td>2.422375e-14</td>\n",
       "      <td>2.017698e-09</td>\n",
       "      <td>1.307253e-13</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>9.999955e-01</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>1.850091e-04</td>\n",
       "      <td>5.473001e-07</td>\n",
       "      <td>8.660339e-09</td>\n",
       "      <td>3.968809e-02</td>\n",
       "      <td>2.824582e-14</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>5.466899e-13</td>\n",
       "      <td>3.180724e-19</td>\n",
       "      <td>9.291136e-18</td>\n",
       "      <td>4.336784e-20</td>\n",
       "      <td>2.034376e-25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>1.441247e-22</td>\n",
       "      <td>1.107779e-15</td>\n",
       "      <td>5.426189e-12</td>\n",
       "      <td>2.699618e-18</td>\n",
       "      <td>4.094367e-53</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset            Age     MIMIC-III      Pendulum  PhysioNet2012  \\\n",
       "method                                                              \n",
       "CoLES     8.811791e-06  7.274862e-19  5.643368e-15   3.279115e-07   \n",
       "GRU       8.005961e-06  2.861990e-18  2.422375e-14   2.017698e-09   \n",
       "MLP       1.000000e+00  1.000000e+00  9.999955e-01   1.000000e+00   \n",
       "Mamba     1.850091e-04  5.473001e-07  8.660339e-09   3.968809e-02   \n",
       "PrimeNet  5.466899e-13  3.180724e-19  9.291136e-18   4.336784e-20   \n",
       "mTAND     1.441247e-22  1.107779e-15  5.426189e-12   2.699618e-18   \n",
       "\n",
       "dataset         Retail  \n",
       "method                  \n",
       "CoLES     1.365499e-10  \n",
       "GRU       1.307253e-13  \n",
       "MLP       1.000000e+00  \n",
       "Mamba     2.824582e-14  \n",
       "PrimeNet  2.034376e-25  \n",
       "mTAND     4.094367e-53  "
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pvals(df, \"main\", \"perm_kl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "ce9a1e55-e6f7-4719-bf41-563b82b5d4b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$1.00$</td>\n",
       "      <td>$1.00$</td>\n",
       "      <td>$1.00$</td>\n",
       "      <td>$1.00$</td>\n",
       "      <td>$1.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$0.04$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "      <td>$&lt;0.01$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset       Age MIMIC-III Pendulum PhysioNet2012   Retail\n",
       "method                                                     \n",
       "CoLES     $<0.01$   $<0.01$  $<0.01$       $<0.01$  $<0.01$\n",
       "GRU       $<0.01$   $<0.01$  $<0.01$       $<0.01$  $<0.01$\n",
       "MLP        $1.00$    $1.00$   $1.00$        $1.00$   $1.00$\n",
       "Mamba     $<0.01$   $<0.01$  $<0.01$        $0.04$  $<0.01$\n",
       "PrimeNet  $<0.01$   $<0.01$  $<0.01$       $<0.01$  $<0.01$\n",
       "mTAND     $<0.01$   $<0.01$  $<0.01$       $<0.01$  $<0.01$"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pvals(df, \"main\", \"perm_kl\").map(make_pval_formatter())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "bc69a002-ad4e-49eb-8d61-c28c23032fb2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$-1.5\\%$</td>\n",
       "      <td>$-1.9\\%$</td>\n",
       "      <td>$-219.4\\%$</td>\n",
       "      <td>$-1.9\\%$</td>\n",
       "      <td>$-1.6\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$-1.4\\%$</td>\n",
       "      <td>$-4.4\\%$</td>\n",
       "      <td>$-227.4\\%$</td>\n",
       "      <td>$-1.5\\%$</td>\n",
       "      <td>$-2.3\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$0.0\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "      <td>$-0.0\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$-1.3\\%$</td>\n",
       "      <td>$-3.0\\%$</td>\n",
       "      <td>$-351.4\\%$</td>\n",
       "      <td>$-0.6\\%$</td>\n",
       "      <td>$-2.4\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$-6.8\\%$</td>\n",
       "      <td>$-3.9\\%$</td>\n",
       "      <td>$-84.7\\%$</td>\n",
       "      <td>$-4.0\\%$</td>\n",
       "      <td>$-26.4\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$-6.1\\%$</td>\n",
       "      <td>$-3.2\\%$</td>\n",
       "      <td>$-177.9\\%$</td>\n",
       "      <td>$-3.2\\%$</td>\n",
       "      <td>$-31.5\\%$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset        Age MIMIC-III    Pendulum PhysioNet2012     Retail\n",
       "method                                                           \n",
       "CoLES     $-1.5\\%$  $-1.9\\%$  $-219.4\\%$      $-1.9\\%$   $-1.6\\%$\n",
       "GRU       $-1.4\\%$  $-4.4\\%$  $-227.4\\%$      $-1.5\\%$   $-2.3\\%$\n",
       "MLP        $0.0\\%$   $0.0\\%$    $-0.0\\%$       $0.0\\%$    $0.0\\%$\n",
       "Mamba     $-1.3\\%$  $-3.0\\%$  $-351.4\\%$      $-0.6\\%$   $-2.4\\%$\n",
       "PrimeNet  $-6.8\\%$  $-3.9\\%$   $-84.7\\%$      $-4.0\\%$  $-26.4\\%$\n",
       "mTAND     $-6.1\\%$  $-3.2\\%$  $-177.9\\%$      $-3.2\\%$  $-31.5\\%$"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metric_rel_diff = ((abl_perm_kl_res[\"mean\"] - main_res[\"mean\"]) / main_res[\"mean\"] * 100).map(lambda x: f\"${x:.1f}\\%$\")\n",
    "metric_rel_diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "02d1172d-8ae9-45a7-a9d4-49c6acd6d50b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llllll}\n",
      "\\toprule\n",
      "dataset & Age & MIMIC-III & Pendulum & PhysioNet2012 & Retail \\\\\n",
      "method &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\textbf{CoLES} & $-1.5\\%$ & $-1.9\\%$ & $-219.4\\%$ & $-1.9\\%$ & $-1.6\\%$ \\\\\n",
      "\\textbf{GRU} & $-1.4\\%$ & $-4.4\\%$ & $-227.4\\%$ & $-1.5\\%$ & $-2.3\\%$ \\\\\n",
      "\\textbf{MLP} & $0.0\\%$ & $0.0\\%$ & $-0.0\\%$ & $0.0\\%$ & $0.0\\%$ \\\\\n",
      "\\textbf{Mamba} & $-1.3\\%$ & $-3.0\\%$ & $-351.4\\%$ & $-0.6\\%$ & $-2.4\\%$ \\\\\n",
      "\\textbf{PrimeNet} & $-6.8\\%$ & $-3.9\\%$ & $-84.7\\%$ & $-4.0\\%$ & $-26.4\\%$ \\\\\n",
      "\\textbf{mTAND} & $-6.1\\%$ & $-3.2\\%$ & $-177.9\\%$ & $-3.2\\%$ & $-31.5\\%$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(metric_rel_diff.to_latex(bold_rows=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "a191fa99-242b-4e5a-a195-aa7d982745f3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>Age</th>\n",
       "      <th>MIMIC-III</th>\n",
       "      <th>Pendulum</th>\n",
       "      <th>PhysioNet2012</th>\n",
       "      <th>Retail</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CoLES</th>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>GRU</th>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MLP</th>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Mamba</th>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "      <td>$nan\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PrimeNet</th>\n",
       "      <td>$-0.2\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "      <td>$-51.5\\%$</td>\n",
       "      <td>$0.1\\%$</td>\n",
       "      <td>$-0.1\\%$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mTAND</th>\n",
       "      <td>$-0.1\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "      <td>$-46.7\\%$</td>\n",
       "      <td>$-0.1\\%$</td>\n",
       "      <td>$0.0\\%$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset        Age MIMIC-III   Pendulum PhysioNet2012    Retail\n",
       "method                                                         \n",
       "CoLES      $nan\\%$   $nan\\%$    $nan\\%$       $nan\\%$   $nan\\%$\n",
       "GRU        $nan\\%$   $nan\\%$    $nan\\%$       $nan\\%$   $nan\\%$\n",
       "MLP        $nan\\%$   $nan\\%$    $nan\\%$       $nan\\%$   $nan\\%$\n",
       "Mamba      $nan\\%$   $nan\\%$    $nan\\%$       $nan\\%$   $nan\\%$\n",
       "PrimeNet  $-0.2\\%$   $0.0\\%$  $-51.5\\%$       $0.1\\%$  $-0.1\\%$\n",
       "mTAND     $-0.1\\%$   $0.0\\%$  $-46.7\\%$      $-0.1\\%$   $0.0\\%$"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "((abl_time_res[\"mean\"] - main_res[\"mean\"]) / main_res[\"mean\"] * 100).map(lambda x: f\"${x:.1f}\\%$\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "32ff0abc-4126-4a77-b870-4ccd2db5908d",
   "metadata": {},
   "source": [
    "## Method robustnes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "480d2cac-c672-4476-a05c-beafbeefbb17",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "method\n",
       "CoLES       2.0\n",
       "GRU         3.2\n",
       "MLP         3.8\n",
       "Mamba       2.8\n",
       "PrimeNet    4.4\n",
       "mTAND       4.8\n",
       "dtype: float64"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main_ranks = main_res[\"mean\"].apply(lambda x: main_res.shape[0] - np.argsort(x), axis=0).mean(1)\n",
    "main_ranks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "9dcf641a-b42e-4c1f-b53d-deacb0e1dd5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "method\n",
       "CoLES       1.8\n",
       "GRU         2.2\n",
       "MLP         4.8\n",
       "Mamba       2.8\n",
       "PrimeNet    4.2\n",
       "mTAND       5.2\n",
       "dtype: float64"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "perm_kl_ranks = abl_perm_kl_res[\"mean\"].apply(lambda x: main_res.shape[0] - np.argsort(x), axis=0).mean(1)\n",
    "perm_kl_ranks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "9bca505b-2ca6-4f66-a6c6-5a3b021af3cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n"
     ]
    },
    {
     "data": {
      "image/png": "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B6NHj8a6deuKbffee+9h5cqVWLx4MS5fvoxPP/0U69evx5QpU8q975YtW2L48OEYOXIk1q9fj/j4eBw5cgQRERH45ZdfDO26desGV1dXDB8+HO7u7ujcubNh2fDhw1G/fn0MHDgQv//+O+Lj47Fnzx689dZbRrcCSuPm5oZ9+/bhzz//xK1btwAAkydPxo4dOxAfH48TJ07gt99+MwSL4uzfvx//+te/cOnSJSxatAhr167FpEmTAFTueVAWPXv2xLFjx7B69WpcvnwZM2fOLBJO3NzccPjwYSQkJODWrVvQ6XRo0aIFjh07hh07duDSpUv46KOPcPTo0SLrnT59GjExMbh165bJKy4TJkzAtWvX8Oabb+LixYvYtGkTZs6ciXfeeQcKBT9iqGx4plCNsGzZMvTu3RsajabIspdeegnHjh0z3MsfPnw4zp8/jyZNmhTp3zB37lx89NFHiIiIgLe3N/r27YtffvkF7u7uJe7/008/RZ06dRAYGIgBAwYgODjYqH8IAKxevRouLi7o1q0bXnjhBYwbNw6Ojo5Qq9UA9Jedt27dim7dumH06NFo2bIlhg4diqtXrxru/ZfV9OnT4e/vj+DgYHTv3h2urq5FBp8y18svv4xVq1bhlVdewfr16022CQkJweeff45PPvkEPj4+WLJkCVasWIHu3btXaN8rVqzAyJEj8e6778LLywshISE4evQomjVrZmgjSRJCQ0Nx6tSpIreT7OzssG/fPjRr1gwvvvgivL29MXbsWGRnZ5t1pWTOnDlISEjAE088Ybi9k5+fj/DwcMP50rJlS3z99dclbufdd9/FsWPH0K5dO3z88cf49NNPERwcbHgflXUelEVwcDA++ugjvP/+++jYsSMyMjIwcuRIozZTpkyBUqlE69at0aBBAyQmJuL111/Hiy++iCFDhqBz5864ffu20VUSABg3bhy8vLzQoUMHNGjQAPv37y+y/yZNmmDr1q04cuQI2rZti/Hjx2Ps2LGYPn16pb9Xqr0k8ejNRiIqk+vXr0Or1eLXX39Fr1695C6HqombmxsmT55crhFNicg09hkhKqPdu3cjMzMTvr6+SEpKwvvvvw83Nzd069ZN7tKIiB5rDCNEZZSXl4cPP/wQV65cgaOjIwIDA/HDDz8U+ZYAERGZh7dpiIiISFbswEpERESyYhghIiIiWTGMEBERkawYRoiIiEhWDCNEREQkK4YRIiIikhXDCBEREcmKYYSIiIhk9f9dA/R0m286iQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, ax = plt.subplots()\n",
    "\n",
    "for m in main_ranks.index:\n",
    "    ax.scatter([main_ranks.at[m]], [perm_kl_ranks.at[m]], marker=\"*\", s=200, label=m)\n",
    "\n",
    "ax.legend()\n",
    "ax.set_xlabel(\"Average rank on evaluation\")\n",
    "ax.set_xlabel(\"Average rank on events permutation\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0945309a-eac1-456c-9b6e-d1ef63447542",
   "metadata": {},
   "source": [
    "# Critical differences"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "f162c5c8-1ad3-4d5e-b92f-2435b4f6719e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>classifier_name</th>\n",
       "      <th>dataset_name</th>\n",
       "      <th>accuracy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>mtand</td>\n",
       "      <td>0</td>\n",
       "      <td>0.844177</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>mtand</td>\n",
       "      <td>1</td>\n",
       "      <td>0.842219</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>mtand</td>\n",
       "      <td>2</td>\n",
       "      <td>0.843357</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>mtand</td>\n",
       "      <td>3</td>\n",
       "      <td>0.841333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>mtand</td>\n",
       "      <td>4</td>\n",
       "      <td>0.845710</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>primenet</td>\n",
       "      <td>15</td>\n",
       "      <td>0.836894</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>primenet</td>\n",
       "      <td>16</td>\n",
       "      <td>0.837698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>primenet</td>\n",
       "      <td>17</td>\n",
       "      <td>0.834237</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>primenet</td>\n",
       "      <td>18</td>\n",
       "      <td>0.843152</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>primenet</td>\n",
       "      <td>19</td>\n",
       "      <td>0.838095</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>120 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   classifier_name dataset_name  accuracy\n",
       "0            mtand            0  0.844177\n",
       "1            mtand            1  0.842219\n",
       "2            mtand            2  0.843357\n",
       "3            mtand            3  0.841333\n",
       "4            mtand            4  0.845710\n",
       "..             ...          ...       ...\n",
       "15        primenet           15  0.836894\n",
       "16        primenet           16  0.837698\n",
       "17        primenet           17  0.834237\n",
       "18        primenet           18  0.843152\n",
       "19        primenet           19  0.838095\n",
       "\n",
       "[120 rows x 3 columns]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = df_eval.query(\"dataset == 'physionet2012'\")[[\"method\", \"seed\", \"metric\"]]\n",
    "df.columns = [\"classifier_name\", \"dataset_name\", \"accuracy\"]\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "75f68915-7b51-4007-9676-2426cc211d3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['mtand' 'gru' 'mlp' 'mamba' 'coles' 'primenet']\n",
      "coles        2.0\n",
      "gru         16.0\n",
      "mamba        0.0\n",
      "mlp          0.0\n",
      "mtand        1.0\n",
      "primenet     1.0\n",
      "dtype: float64\n",
      "mamba       4.95\n",
      "mlp         4.95\n",
      "primenet    3.35\n",
      "coles       3.30\n",
      "mtand       3.20\n",
      "gru         1.25\n",
      "dtype: float64\n",
      "('gru', 'mamba', 1.9073486328125e-06, True)\n",
      "('gru', 'mlp', 1.9073486328125e-06, True)\n",
      "('gru', 'mtand', 5.7220458984375e-06, True)\n",
      "('coles', 'gru', 1.9073486328125e-05, True)\n",
      "('gru', 'primenet', 4.76837158203125e-05, True)\n",
      "('mamba', 'mtand', 0.0003223419189453125, True)\n",
      "('mamba', 'primenet', 0.0031528472900390625, True)\n",
      "('mlp', 'mtand', 0.0042209625244140625, True)\n",
      "('mlp', 'primenet', 0.012079238891601562, False)\n",
      "('coles', 'mamba', 0.026641845703125, False)\n",
      "('coles', 'mlp', 0.082550048828125, False)\n",
      "('coles', 'primenet', 0.6742229461669922, False)\n",
      "('coles', 'mtand', 0.7285060882568359, False)\n",
      "('mamba', 'mlp', 0.7841262817382812, False)\n",
      "('mtand', 'primenet', 0.7841262817382812, False)\n",
      "Index(['mamba', 'mlp', 'primenet', 'coles', 'mtand', 'gru'], dtype='object')\n",
      "[3, 1, 0]\n",
      "[3, 1, 2]\n",
      "[3, 4, 2]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n",
      "findfont: Generic family 'sans-serif' not found because none of the following families were found: Arial\n"
     ]
    }
   ],
   "source": [
    "draw_cd_diagram(df, fname=\"notebooks/figures/cd-physionet.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "575e29e3-9d58-431f-83fb-2fa383c95a19",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
