{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "from pathlib import Path\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "from tabulate import tabulate\n",
    "\n",
    "from pkg.utils.analyze import summarize_outputs_in_df\n",
    "\n",
    "OUTPUT_PATH_PYKT = \"/home/knowledge-tracing/pykt-models\"\n",
    "OUTPUT_PATH_KTST = \"/home/knowledge-tracing/ktst/benchmark/eval\"\n",
    "\n",
    "MODELS = {\n",
    "    \"dkt\": \"DKT\",\n",
    "    \"dkvmn\": \"DKVMN\",\n",
    "    \"dkt_plus\": \"DKT+\",\n",
    "    \"deep_irt\": \"DeepIRT\", \n",
    "    \"dkt_forget\": \"DKT-F\",\n",
    "    \"gkt\": \"GKT\", \n",
    "    \"kqn\": \"KQN\", \n",
    "    \"sakt\": \"SAKT\",\n",
    "    \"skvmn\": \"SKVMN\", \n",
    "    \"akt\": \"AKT\",\n",
    "    \"qdkt\": \"qDKT\", \n",
    "    \"saint\": \"SAINT\",\n",
    "    \"atkt\": \"ATKT\",\n",
    "    \"hawkes\": \"HawkesKT\", \n",
    "    \"iekt\": \"IEKT\",\n",
    "    \"lpkt\": \"LPKT\", \n",
    "    \"dimkt\": \"DIMKT\",\n",
    "    \"atdkt\": \"AT-DKT\", \n",
    "    \"dtransformer\": \"DTransformer\",\n",
    "    \"folibikt\": \"FoLiBiKT\",\n",
    "    \"qikt\": \"QIKT\", \n",
    "    \"simplekt\": \"simpleKT\",\n",
    "}\n",
    "\n",
    "MODELS_REDUCED = {\n",
    "    \"dkt\": \"DKT\",\n",
    "    \"dkvmn\": \"DKVMN\",\n",
    "    \"dkt_plus\": \"DKT+\",\n",
    "    \"gkt\": \"GKT\", \n",
    "    \"sakt\": \"SAKT\",\n",
    "    \"skvmn\": \"SKVMN\", \n",
    "    \"akt\": \"AKT\",\n",
    "    \"saint\": \"SAINT\",\n",
    "    \"hawkes\": \"HawkesKT\", \n",
    "    \"iekt\": \"IEKT\",\n",
    "    \"lpkt\": \"LPKT\", \n",
    "    \"dimkt\": \"DIMKT\",\n",
    "    \"dtransformer\": \"DTransformer\",\n",
    "    \"folibikt\": \"FoLiBiKT\",\n",
    "    \"qikt\": \"QIKT\", \n",
    "    \"simplekt\": \"simpleKT\",\n",
    "}\n",
    "\n",
    "MODELS_FULL = MODELS | {\n",
    "    \"ktst_mean\": \"KTST (mean)\",\n",
    "    \"ktst_unique\": \"KTST (unique)\",\n",
    "    \"ktst_mhsa\": \"KTST (MHSA)\",\n",
    "}\n",
    "\n",
    "MODELS_REDUCED_FULL = MODELS_REDUCED | {\n",
    "    \"ktst_mean\": \"KTST (mean)\",\n",
    "    \"ktst_unique\": \"KTST (unique)\",\n",
    "    \"ktst_mhsa\": \"KTST (MHSA)\",\n",
    "}\n",
    "\n",
    "DATASETS = {\n",
    "    \"ednet\": \"Ednet\",\n",
    "    \"algebra2005\": \"AL2005\",\n",
    "    \"assist2009\": \"AS2009\",\n",
    "    \"nips_task34\": \"NIPS34\",\n",
    "    \"bridge2algebra2006\": \"BD2006\",\n",
    "    \"statics2011\": \"Statics2011\",\n",
    "    \"assist2015\": \"AS2015\",\n",
    "    \"poj\": \"POJ\",\n",
    "}\n",
    "\n",
    "DATASETS_REDUCED = {\n",
    "    \"ednet\": \"Ednet\",\n",
    "    \"algebra2005\": \"AL2005\",\n",
    "    \"assist2009\": \"AS2009\",\n",
    "    \"nips_task34\": \"NIPS34\",\n",
    "    \"bridge2algebra2006\": \"BD2006\",\n",
    "}\n",
    "\n",
    "INVALID_MODEL_DATASET_COMBINATIONS = (\n",
    "    (\"dkt_forget\", \"assist2009\"),\n",
    "    (\"dkt_forget\", \"assist2015\"),\n",
    "    (\"lpkt\", \"statics2011\"),\n",
    "    (\"lpkt\", \"assist2015\"),\n",
    "    (\"lpkt\", \"poj\"),\n",
    "    (\"iekt\", \"statics2011\"),\n",
    "    (\"iekt\", \"assist2015\"),\n",
    "    (\"iekt\", \"poj\"),\n",
    "    (\"dimkt\", \"statics2011\"),\n",
    "    (\"dimkt\", \"assist2015\"),\n",
    "    (\"dimkt\", \"poj\"),\n",
    "    (\"atdkt\", \"statics2011\"),\n",
    "    (\"atdkt\", \"assist2015\"),\n",
    "    (\"atdkt\", \"poj\"),\n",
    "    (\"qikt\", \"statics2011\"),\n",
    "    (\"qikt\", \"assist2015\"),\n",
    "    (\"qikt\", \"poj\"),\n",
    "    (\"qdkt\", \"statics2011\"),\n",
    "    (\"qdkt\", \"assist2015\"),\n",
    "    (\"qdkt\", \"poj\"),\n",
    "    (\"hawkes\", \"statics2011\"),\n",
    "    (\"hawkes\", \"assist2015\"),\n",
    "    (\"hawkes\", \"poj\"),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_results(type, model, dataset):\n",
    "    outputs_path = Path(f\"{OUTPUT_PATH_PYKT}/{model}/{dataset}\")\n",
    "    best_files = list(outputs_path.glob(f\"**/test_results.json\"))\n",
    "\n",
    "    joined_dfs = []\n",
    "\n",
    "    for best_file in best_files:\n",
    "        result_df = pd.read_json(path_or_buf=best_file, lines=True)\n",
    "        with open(f\"{best_file.parent}/config.json\") as f:\n",
    "            result_config = json.load(f)\n",
    "        result_df[\"fold\"] = result_config[\"params\"][\"fold\"]\n",
    "        joined_dfs.append(result_df)\n",
    "\n",
    "    df = pd.concat(joined_dfs, axis=0)\n",
    "\n",
    "    if f\"window{type}late_mean\" in df.columns:\n",
    "        results = df.sort_values(by=[\"fold\"])[f\"window{type}late_mean\"].values\n",
    "    else:\n",
    "        results = df.sort_values(by=[\"fold\"])[f\"window_test{type}\"].values\n",
    "\n",
    "    assert len(results) == 5\n",
    "\n",
    "    return results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add results for pykt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_auc = pd.DataFrame(\n",
    "    data=zip(MODELS.keys(), MODELS.values()), columns=[\"Index\", \"Model\"]\n",
    ").set_index(\"Index\")\n",
    "df_acc = pd.DataFrame(\n",
    "    data=zip(MODELS.keys(), MODELS.values()), columns=[\"Index\", \"Model\"]\n",
    ").set_index(\"Index\")\n",
    "\n",
    "for k_dataset, v_dataset in DATASETS.items():\n",
    "    acc, auc = {}, {}\n",
    "    for k_model, v_model in MODELS.items():\n",
    "        if (k_model, k_dataset) not in INVALID_MODEL_DATASET_COMBINATIONS:\n",
    "            acc[k_model] = {v_dataset: get_results(\"acc\", k_model, k_dataset)}\n",
    "            auc[k_model] = {v_dataset: get_results(\"auc\", k_model, k_dataset)}\n",
    "        else:\n",
    "            acc[k_model] = {v_dataset: []}\n",
    "            auc[k_model] = {v_dataset: []}\n",
    "\n",
    "    df_acc = df_acc.join(pd.DataFrame.from_dict(acc, orient=\"index\"))\n",
    "    df_auc = df_auc.join(pd.DataFrame.from_dict(auc, orient=\"index\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add results for KTST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_sota = summarize_outputs_in_df(outputs_dir=f\"{OUTPUT_PATH_KTST}\")\n",
    "assert len(df_sota) == 70\n",
    "\n",
    "df_sota_mean = df_sota[(df_sota[\"data.format\"] == \"set_dense\") & (df_sota[\"model.aggregation\"] == \"q_mean_c\")]\n",
    "df_sota_combinatorial = df_sota[(df_sota[\"data.format\"] == \"combinatorial_dense\") & (df_sota[\"model.aggregation\"] == \"q_mean_c\")]\n",
    "df_sota_mhsa = df_sota[(df_sota[\"data.format\"] == \"set_dense\") & (df_sota[\"model.aggregation\"] == \"self_attn_all\")]\n",
    "assert len(df_sota_mean) == 40\n",
    "assert len(df_sota_combinatorial) == 15\n",
    "assert len(df_sota_mhsa) == 15"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add results for KTST (set_dense)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_auc, out_acc = {\"Model\": \"KTST (mean)\"}, {\"Model\": \"KTST (mean)\"}\n",
    "for k, v in DATASETS.items():\n",
    "    _df = df_sota_mean[df_sota_mean[\"data.dataset\"] == k].sort_values(\n",
    "        by=[\"data.dataset\", \"data.val_fold_idx\"]\n",
    "    )\n",
    "    out_auc |= {v: _df[\"test_auc\"].values}\n",
    "    out_acc |= {v: _df[\"test_accuracy\"].values}\n",
    "df_auc = pd.concat(\n",
    "    [df_auc, pd.DataFrame.from_dict({\"ktst_mean\": out_auc}, orient=\"index\")]\n",
    ")\n",
    "df_acc = pd.concat(\n",
    "    [df_acc, pd.DataFrame.from_dict({\"ktst_mean\": out_acc}, orient=\"index\")]\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add results for KTST (combinatorial)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_auc, out_acc = {\"Model\": \"KTST (unique)\"}, {\"Model\": \"KTST (unique)\"}\n",
    "for k, v in DATASETS.items():\n",
    "    _df = df_sota_combinatorial[df_sota_combinatorial[\"data.dataset\"] == k].sort_values(\n",
    "        by=[\"data.dataset\", \"data.val_fold_idx\"]\n",
    "    )\n",
    "    out_auc |= {v: _df[\"test_auc\"].values}\n",
    "    out_acc |= {v: _df[\"test_accuracy\"].values}\n",
    "df_auc = pd.concat(\n",
    "    [df_auc, pd.DataFrame.from_dict({\"ktst_unique\": out_auc}, orient=\"index\")]\n",
    ")\n",
    "df_acc = pd.concat(\n",
    "    [df_acc, pd.DataFrame.from_dict({\"ktst_unique\": out_acc}, orient=\"index\")]\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add results for KTST (MHSA)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_auc, out_acc = {\"Model\": \"KTST (MHSA)\"}, {\"Model\": \"KTST (MHSA)\"}\n",
    "for k, v in DATASETS.items():\n",
    "    _df = df_sota_mhsa[df_sota_mhsa[\"data.dataset\"] == k].sort_values(\n",
    "        by=[\"data.dataset\", \"data.val_fold_idx\"]\n",
    "    )\n",
    "    out_auc |= {v: _df[\"test_auc\"].values}\n",
    "    out_acc |= {v: _df[\"test_accuracy\"].values}\n",
    "df_auc = pd.concat(\n",
    "    [df_auc, pd.DataFrame.from_dict({\"ktst_mhsa\": out_auc}, orient=\"index\")]\n",
    ")\n",
    "df_acc = pd.concat(\n",
    "    [df_acc, pd.DataFrame.from_dict({\"ktst_mhsa\": out_acc}, orient=\"index\")]\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Compute columns of results table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "for d in (df_auc, df_acc):\n",
    "    for k, v in DATASETS.items():\n",
    "        f_mean = lambda x: np.array(x).mean() if len(x) > 0 else None\n",
    "        f_std = lambda x: np.array(x).std() if len(x) > 0 else None\n",
    "        _f_sig = lambda a, b: (\n",
    "            (\n",
    "                \"$\\circ$\"\n",
    "                if stats.ttest_rel(a, b).pvalue > 0.01\n",
    "                else (\"$\\\\ast$\" if (f_mean(b) - f_mean(a) > 0) else \"$\\\\bullet$\")\n",
    "            )\n",
    "            if (a != b).all() # if the same entry is compared\n",
    "            else \"$\\\\; \\\\: $\"\n",
    "        )\n",
    "        f_sig = lambda x: (\n",
    "            _f_sig(x, d.iloc[d.index == \"ktst_mean\"][v].values[0])\n",
    "            if (len(x) > 0)\n",
    "            else \"\"\n",
    "        )\n",
    "        d[f\"{v}_mean\"] = d[v].apply(f_mean)\n",
    "        d[f\"{v}_std\"] = d[v].apply(f_std)\n",
    "        d[f\"{v}_sig\"] = d[v].apply(f_sig)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Display results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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>Model</th>\n",
       "      <th>Ednet_mean</th>\n",
       "      <th>Ednet_std</th>\n",
       "      <th>AL2005_mean</th>\n",
       "      <th>AL2005_std</th>\n",
       "      <th>AS2009_mean</th>\n",
       "      <th>AS2009_std</th>\n",
       "      <th>NIPS34_mean</th>\n",
       "      <th>NIPS34_std</th>\n",
       "      <th>BD2006_mean</th>\n",
       "      <th>BD2006_std</th>\n",
       "      <th>Statics2011_mean</th>\n",
       "      <th>Statics2011_std</th>\n",
       "      <th>AS2015_mean</th>\n",
       "      <th>AS2015_std</th>\n",
       "      <th>POJ_mean</th>\n",
       "      <th>POJ_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>dkt</th>\n",
       "      <td>DKT</td>\n",
       "      <td>0.642017</td>\n",
       "      <td>0.002328</td>\n",
       "      <td>0.809377</td>\n",
       "      <td>0.000986</td>\n",
       "      <td>0.724056</td>\n",
       "      <td>0.001182</td>\n",
       "      <td>0.702370</td>\n",
       "      <td>0.000810</td>\n",
       "      <td>0.855059</td>\n",
       "      <td>0.000256</td>\n",
       "      <td>0.797432</td>\n",
       "      <td>0.000497</td>\n",
       "      <td>0.750538</td>\n",
       "      <td>0.000553</td>\n",
       "      <td>0.632917</td>\n",
       "      <td>0.002275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkvmn</th>\n",
       "      <td>DKVMN</td>\n",
       "      <td>0.644559</td>\n",
       "      <td>0.003005</td>\n",
       "      <td>0.803100</td>\n",
       "      <td>0.000775</td>\n",
       "      <td>0.719401</td>\n",
       "      <td>0.000586</td>\n",
       "      <td>0.701966</td>\n",
       "      <td>0.000449</td>\n",
       "      <td>0.854459</td>\n",
       "      <td>0.000301</td>\n",
       "      <td>0.793082</td>\n",
       "      <td>0.000775</td>\n",
       "      <td>0.750658</td>\n",
       "      <td>0.000334</td>\n",
       "      <td>0.639364</td>\n",
       "      <td>0.001602</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkt_plus</th>\n",
       "      <td>DKT+</td>\n",
       "      <td>0.651682</td>\n",
       "      <td>0.005656</td>\n",
       "      <td>0.809279</td>\n",
       "      <td>0.000394</td>\n",
       "      <td>0.724079</td>\n",
       "      <td>0.001254</td>\n",
       "      <td>0.703419</td>\n",
       "      <td>0.000502</td>\n",
       "      <td>0.855065</td>\n",
       "      <td>0.000239</td>\n",
       "      <td>0.797375</td>\n",
       "      <td>0.000624</td>\n",
       "      <td>0.750922</td>\n",
       "      <td>0.000362</td>\n",
       "      <td>0.647902</td>\n",
       "      <td>0.002252</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>deep_irt</th>\n",
       "      <td>DeepIRT</td>\n",
       "      <td>0.648338</td>\n",
       "      <td>0.005834</td>\n",
       "      <td>0.803278</td>\n",
       "      <td>0.000696</td>\n",
       "      <td>0.719123</td>\n",
       "      <td>0.000732</td>\n",
       "      <td>0.701360</td>\n",
       "      <td>0.000583</td>\n",
       "      <td>0.854238</td>\n",
       "      <td>0.000148</td>\n",
       "      <td>0.790907</td>\n",
       "      <td>0.002963</td>\n",
       "      <td>0.750674</td>\n",
       "      <td>0.000197</td>\n",
       "      <td>0.637170</td>\n",
       "      <td>0.000764</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkt_forget</th>\n",
       "      <td>DKT-F</td>\n",
       "      <td>0.639539</td>\n",
       "      <td>0.000920</td>\n",
       "      <td>0.809044</td>\n",
       "      <td>0.000646</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.707022</td>\n",
       "      <td>0.000443</td>\n",
       "      <td>0.853424</td>\n",
       "      <td>0.000566</td>\n",
       "      <td>0.786659</td>\n",
       "      <td>0.000597</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.637097</td>\n",
       "      <td>0.003802</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gkt</th>\n",
       "      <td>GKT</td>\n",
       "      <td>0.663887</td>\n",
       "      <td>0.005025</td>\n",
       "      <td>0.808611</td>\n",
       "      <td>0.000820</td>\n",
       "      <td>0.715755</td>\n",
       "      <td>0.001604</td>\n",
       "      <td>0.695648</td>\n",
       "      <td>0.010277</td>\n",
       "      <td>0.855332</td>\n",
       "      <td>0.000323</td>\n",
       "      <td>0.790041</td>\n",
       "      <td>0.001059</td>\n",
       "      <td>0.749638</td>\n",
       "      <td>0.000560</td>\n",
       "      <td>0.602402</td>\n",
       "      <td>0.022831</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>kqn</th>\n",
       "      <td>KQN</td>\n",
       "      <td>0.638749</td>\n",
       "      <td>0.003090</td>\n",
       "      <td>0.802285</td>\n",
       "      <td>0.001289</td>\n",
       "      <td>0.722422</td>\n",
       "      <td>0.001376</td>\n",
       "      <td>0.701824</td>\n",
       "      <td>0.000220</td>\n",
       "      <td>0.853289</td>\n",
       "      <td>0.000431</td>\n",
       "      <td>0.798138</td>\n",
       "      <td>0.000829</td>\n",
       "      <td>0.750241</td>\n",
       "      <td>0.000181</td>\n",
       "      <td>0.643285</td>\n",
       "      <td>0.001954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>sakt</th>\n",
       "      <td>SAKT</td>\n",
       "      <td>0.639224</td>\n",
       "      <td>0.003857</td>\n",
       "      <td>0.795875</td>\n",
       "      <td>0.001769</td>\n",
       "      <td>0.707060</td>\n",
       "      <td>0.001604</td>\n",
       "      <td>0.686957</td>\n",
       "      <td>0.001049</td>\n",
       "      <td>0.845646</td>\n",
       "      <td>0.000635</td>\n",
       "      <td>0.787690</td>\n",
       "      <td>0.002063</td>\n",
       "      <td>0.747426</td>\n",
       "      <td>0.000133</td>\n",
       "      <td>0.639948</td>\n",
       "      <td>0.002905</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>skvmn</th>\n",
       "      <td>SKVMN</td>\n",
       "      <td>0.660609</td>\n",
       "      <td>0.009030</td>\n",
       "      <td>0.782093</td>\n",
       "      <td>0.003213</td>\n",
       "      <td>0.715980</td>\n",
       "      <td>0.001022</td>\n",
       "      <td>0.687432</td>\n",
       "      <td>0.000999</td>\n",
       "      <td>0.840806</td>\n",
       "      <td>0.000469</td>\n",
       "      <td>0.792188</td>\n",
       "      <td>0.001049</td>\n",
       "      <td>0.745701</td>\n",
       "      <td>0.000431</td>\n",
       "      <td>0.640744</td>\n",
       "      <td>0.002927</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>akt</th>\n",
       "      <td>AKT</td>\n",
       "      <td>0.664535</td>\n",
       "      <td>0.003506</td>\n",
       "      <td>0.812454</td>\n",
       "      <td>0.001637</td>\n",
       "      <td>0.738337</td>\n",
       "      <td>0.001974</td>\n",
       "      <td>0.731701</td>\n",
       "      <td>0.000457</td>\n",
       "      <td>0.858604</td>\n",
       "      <td>0.000503</td>\n",
       "      <td>0.802317</td>\n",
       "      <td>0.000597</td>\n",
       "      <td>0.752066</td>\n",
       "      <td>0.000517</td>\n",
       "      <td>0.649184</td>\n",
       "      <td>0.001715</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>qdkt</th>\n",
       "      <td>qDKT</td>\n",
       "      <td>0.692201</td>\n",
       "      <td>0.000510</td>\n",
       "      <td>0.726233</td>\n",
       "      <td>0.000814</td>\n",
       "      <td>0.678143</td>\n",
       "      <td>0.003412</td>\n",
       "      <td>0.730490</td>\n",
       "      <td>0.000345</td>\n",
       "      <td>0.830231</td>\n",
       "      <td>0.000725</td>\n",
       "      <td>NaN</td>\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>saint</th>\n",
       "      <td>SAINT</td>\n",
       "      <td>0.651059</td>\n",
       "      <td>0.003851</td>\n",
       "      <td>0.778913</td>\n",
       "      <td>0.002971</td>\n",
       "      <td>0.688488</td>\n",
       "      <td>0.004412</td>\n",
       "      <td>0.717229</td>\n",
       "      <td>0.002495</td>\n",
       "      <td>0.837350</td>\n",
       "      <td>0.010825</td>\n",
       "      <td>0.762967</td>\n",
       "      <td>0.013866</td>\n",
       "      <td>0.745065</td>\n",
       "      <td>0.000849</td>\n",
       "      <td>0.647389</td>\n",
       "      <td>0.000470</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>atkt</th>\n",
       "      <td>ATKT</td>\n",
       "      <td>0.636400</td>\n",
       "      <td>0.001546</td>\n",
       "      <td>0.798757</td>\n",
       "      <td>0.000763</td>\n",
       "      <td>0.720089</td>\n",
       "      <td>0.000855</td>\n",
       "      <td>0.700676</td>\n",
       "      <td>0.000581</td>\n",
       "      <td>0.850741</td>\n",
       "      <td>0.000305</td>\n",
       "      <td>0.790451</td>\n",
       "      <td>0.001554</td>\n",
       "      <td>0.749049</td>\n",
       "      <td>0.000280</td>\n",
       "      <td>0.636424</td>\n",
       "      <td>0.003151</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>hawkes</th>\n",
       "      <td>HawkesKT</td>\n",
       "      <td>0.690528</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.811192</td>\n",
       "      <td>0.001219</td>\n",
       "      <td>0.704529</td>\n",
       "      <td>0.000787</td>\n",
       "      <td>0.710176</td>\n",
       "      <td>0.001251</td>\n",
       "      <td>0.855897</td>\n",
       "      <td>0.000482</td>\n",
       "      <td>NaN</td>\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>iekt</th>\n",
       "      <td>IEKT</td>\n",
       "      <td>0.710596</td>\n",
       "      <td>0.001784</td>\n",
       "      <td>0.822847</td>\n",
       "      <td>0.000804</td>\n",
       "      <td>0.733583</td>\n",
       "      <td>0.002731</td>\n",
       "      <td>0.732659</td>\n",
       "      <td>0.000087</td>\n",
       "      <td>0.855566</td>\n",
       "      <td>0.000930</td>\n",
       "      <td>NaN</td>\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>lpkt</th>\n",
       "      <td>LPKT</td>\n",
       "      <td>0.712805</td>\n",
       "      <td>0.000379</td>\n",
       "      <td>0.812875</td>\n",
       "      <td>0.000773</td>\n",
       "      <td>0.735576</td>\n",
       "      <td>0.001122</td>\n",
       "      <td>0.717906</td>\n",
       "      <td>0.003278</td>\n",
       "      <td>0.853796</td>\n",
       "      <td>0.000198</td>\n",
       "      <td>NaN</td>\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>dimkt</th>\n",
       "      <td>DIMKT</td>\n",
       "      <td>0.669979</td>\n",
       "      <td>0.003779</td>\n",
       "      <td>0.810637</td>\n",
       "      <td>0.000388</td>\n",
       "      <td>0.735419</td>\n",
       "      <td>0.001896</td>\n",
       "      <td>0.730870</td>\n",
       "      <td>0.000546</td>\n",
       "      <td>0.857848</td>\n",
       "      <td>0.000379</td>\n",
       "      <td>NaN</td>\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>atdkt</th>\n",
       "      <td>AT-DKT</td>\n",
       "      <td>0.647382</td>\n",
       "      <td>0.006586</td>\n",
       "      <td>0.813044</td>\n",
       "      <td>0.000852</td>\n",
       "      <td>0.724640</td>\n",
       "      <td>0.001595</td>\n",
       "      <td>0.714563</td>\n",
       "      <td>0.000560</td>\n",
       "      <td>0.855280</td>\n",
       "      <td>0.000406</td>\n",
       "      <td>NaN</td>\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>dtransformer</th>\n",
       "      <td>DTransformer</td>\n",
       "      <td>0.665600</td>\n",
       "      <td>0.003231</td>\n",
       "      <td>0.805391</td>\n",
       "      <td>0.000730</td>\n",
       "      <td>0.728397</td>\n",
       "      <td>0.000684</td>\n",
       "      <td>0.729044</td>\n",
       "      <td>0.001209</td>\n",
       "      <td>0.855585</td>\n",
       "      <td>0.000621</td>\n",
       "      <td>0.798764</td>\n",
       "      <td>0.002148</td>\n",
       "      <td>0.751139</td>\n",
       "      <td>0.000550</td>\n",
       "      <td>0.650912</td>\n",
       "      <td>0.000422</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>folibikt</th>\n",
       "      <td>FoLiBiKT</td>\n",
       "      <td>0.666624</td>\n",
       "      <td>0.002786</td>\n",
       "      <td>0.812704</td>\n",
       "      <td>0.001215</td>\n",
       "      <td>0.739104</td>\n",
       "      <td>0.001328</td>\n",
       "      <td>0.731931</td>\n",
       "      <td>0.000537</td>\n",
       "      <td>0.858335</td>\n",
       "      <td>0.000580</td>\n",
       "      <td>0.801879</td>\n",
       "      <td>0.000533</td>\n",
       "      <td>0.752588</td>\n",
       "      <td>0.000212</td>\n",
       "      <td>0.650707</td>\n",
       "      <td>0.003262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>qikt</th>\n",
       "      <td>QIKT</td>\n",
       "      <td>0.707702</td>\n",
       "      <td>0.001427</td>\n",
       "      <td>0.822039</td>\n",
       "      <td>0.000735</td>\n",
       "      <td>0.738169</td>\n",
       "      <td>0.000834</td>\n",
       "      <td>0.732603</td>\n",
       "      <td>0.000819</td>\n",
       "      <td>0.853720</td>\n",
       "      <td>0.000483</td>\n",
       "      <td>NaN</td>\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>simplekt</th>\n",
       "      <td>simpleKT</td>\n",
       "      <td>0.656539</td>\n",
       "      <td>0.002944</td>\n",
       "      <td>0.808124</td>\n",
       "      <td>0.001029</td>\n",
       "      <td>0.731891</td>\n",
       "      <td>0.001887</td>\n",
       "      <td>0.732731</td>\n",
       "      <td>0.000289</td>\n",
       "      <td>0.857949</td>\n",
       "      <td>0.000238</td>\n",
       "      <td>0.794722</td>\n",
       "      <td>0.002565</td>\n",
       "      <td>0.750541</td>\n",
       "      <td>0.000458</td>\n",
       "      <td>0.651629</td>\n",
       "      <td>0.000901</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ktst_mean</th>\n",
       "      <td>KTST (mean)</td>\n",
       "      <td>0.715404</td>\n",
       "      <td>0.001112</td>\n",
       "      <td>0.828660</td>\n",
       "      <td>0.000546</td>\n",
       "      <td>0.749032</td>\n",
       "      <td>0.001292</td>\n",
       "      <td>0.735552</td>\n",
       "      <td>0.000276</td>\n",
       "      <td>0.860820</td>\n",
       "      <td>0.000530</td>\n",
       "      <td>0.800194</td>\n",
       "      <td>0.001444</td>\n",
       "      <td>0.752331</td>\n",
       "      <td>0.000174</td>\n",
       "      <td>0.656844</td>\n",
       "      <td>0.000769</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ktst_unique</th>\n",
       "      <td>KTST (unique)</td>\n",
       "      <td>0.713147</td>\n",
       "      <td>0.001691</td>\n",
       "      <td>0.829127</td>\n",
       "      <td>0.000795</td>\n",
       "      <td>0.748910</td>\n",
       "      <td>0.001140</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\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>ktst_mhsa</th>\n",
       "      <td>KTST (MHSA)</td>\n",
       "      <td>0.715153</td>\n",
       "      <td>0.001114</td>\n",
       "      <td>0.816568</td>\n",
       "      <td>0.001207</td>\n",
       "      <td>0.741544</td>\n",
       "      <td>0.001441</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Model  Ednet_mean  Ednet_std  AL2005_mean  AL2005_std  \\\n",
       "dkt                     DKT    0.642017   0.002328     0.809377    0.000986   \n",
       "dkvmn                 DKVMN    0.644559   0.003005     0.803100    0.000775   \n",
       "dkt_plus               DKT+    0.651682   0.005656     0.809279    0.000394   \n",
       "deep_irt            DeepIRT    0.648338   0.005834     0.803278    0.000696   \n",
       "dkt_forget            DKT-F    0.639539   0.000920     0.809044    0.000646   \n",
       "gkt                     GKT    0.663887   0.005025     0.808611    0.000820   \n",
       "kqn                     KQN    0.638749   0.003090     0.802285    0.001289   \n",
       "sakt                   SAKT    0.639224   0.003857     0.795875    0.001769   \n",
       "skvmn                 SKVMN    0.660609   0.009030     0.782093    0.003213   \n",
       "akt                     AKT    0.664535   0.003506     0.812454    0.001637   \n",
       "qdkt                   qDKT    0.692201   0.000510     0.726233    0.000814   \n",
       "saint                 SAINT    0.651059   0.003851     0.778913    0.002971   \n",
       "atkt                   ATKT    0.636400   0.001546     0.798757    0.000763   \n",
       "hawkes             HawkesKT    0.690528   0.002500     0.811192    0.001219   \n",
       "iekt                   IEKT    0.710596   0.001784     0.822847    0.000804   \n",
       "lpkt                   LPKT    0.712805   0.000379     0.812875    0.000773   \n",
       "dimkt                 DIMKT    0.669979   0.003779     0.810637    0.000388   \n",
       "atdkt                AT-DKT    0.647382   0.006586     0.813044    0.000852   \n",
       "dtransformer   DTransformer    0.665600   0.003231     0.805391    0.000730   \n",
       "folibikt           FoLiBiKT    0.666624   0.002786     0.812704    0.001215   \n",
       "qikt                   QIKT    0.707702   0.001427     0.822039    0.000735   \n",
       "simplekt           simpleKT    0.656539   0.002944     0.808124    0.001029   \n",
       "ktst_mean       KTST (mean)    0.715404   0.001112     0.828660    0.000546   \n",
       "ktst_unique   KTST (unique)    0.713147   0.001691     0.829127    0.000795   \n",
       "ktst_mhsa       KTST (MHSA)    0.715153   0.001114     0.816568    0.001207   \n",
       "\n",
       "              AS2009_mean  AS2009_std  NIPS34_mean  NIPS34_std  BD2006_mean  \\\n",
       "dkt              0.724056    0.001182     0.702370    0.000810     0.855059   \n",
       "dkvmn            0.719401    0.000586     0.701966    0.000449     0.854459   \n",
       "dkt_plus         0.724079    0.001254     0.703419    0.000502     0.855065   \n",
       "deep_irt         0.719123    0.000732     0.701360    0.000583     0.854238   \n",
       "dkt_forget            NaN         NaN     0.707022    0.000443     0.853424   \n",
       "gkt              0.715755    0.001604     0.695648    0.010277     0.855332   \n",
       "kqn              0.722422    0.001376     0.701824    0.000220     0.853289   \n",
       "sakt             0.707060    0.001604     0.686957    0.001049     0.845646   \n",
       "skvmn            0.715980    0.001022     0.687432    0.000999     0.840806   \n",
       "akt              0.738337    0.001974     0.731701    0.000457     0.858604   \n",
       "qdkt             0.678143    0.003412     0.730490    0.000345     0.830231   \n",
       "saint            0.688488    0.004412     0.717229    0.002495     0.837350   \n",
       "atkt             0.720089    0.000855     0.700676    0.000581     0.850741   \n",
       "hawkes           0.704529    0.000787     0.710176    0.001251     0.855897   \n",
       "iekt             0.733583    0.002731     0.732659    0.000087     0.855566   \n",
       "lpkt             0.735576    0.001122     0.717906    0.003278     0.853796   \n",
       "dimkt            0.735419    0.001896     0.730870    0.000546     0.857848   \n",
       "atdkt            0.724640    0.001595     0.714563    0.000560     0.855280   \n",
       "dtransformer     0.728397    0.000684     0.729044    0.001209     0.855585   \n",
       "folibikt         0.739104    0.001328     0.731931    0.000537     0.858335   \n",
       "qikt             0.738169    0.000834     0.732603    0.000819     0.853720   \n",
       "simplekt         0.731891    0.001887     0.732731    0.000289     0.857949   \n",
       "ktst_mean        0.749032    0.001292     0.735552    0.000276     0.860820   \n",
       "ktst_unique      0.748910    0.001140          NaN         NaN          NaN   \n",
       "ktst_mhsa        0.741544    0.001441          NaN         NaN          NaN   \n",
       "\n",
       "              BD2006_std  Statics2011_mean  Statics2011_std  AS2015_mean  \\\n",
       "dkt             0.000256          0.797432         0.000497     0.750538   \n",
       "dkvmn           0.000301          0.793082         0.000775     0.750658   \n",
       "dkt_plus        0.000239          0.797375         0.000624     0.750922   \n",
       "deep_irt        0.000148          0.790907         0.002963     0.750674   \n",
       "dkt_forget      0.000566          0.786659         0.000597          NaN   \n",
       "gkt             0.000323          0.790041         0.001059     0.749638   \n",
       "kqn             0.000431          0.798138         0.000829     0.750241   \n",
       "sakt            0.000635          0.787690         0.002063     0.747426   \n",
       "skvmn           0.000469          0.792188         0.001049     0.745701   \n",
       "akt             0.000503          0.802317         0.000597     0.752066   \n",
       "qdkt            0.000725               NaN              NaN          NaN   \n",
       "saint           0.010825          0.762967         0.013866     0.745065   \n",
       "atkt            0.000305          0.790451         0.001554     0.749049   \n",
       "hawkes          0.000482               NaN              NaN          NaN   \n",
       "iekt            0.000930               NaN              NaN          NaN   \n",
       "lpkt            0.000198               NaN              NaN          NaN   \n",
       "dimkt           0.000379               NaN              NaN          NaN   \n",
       "atdkt           0.000406               NaN              NaN          NaN   \n",
       "dtransformer    0.000621          0.798764         0.002148     0.751139   \n",
       "folibikt        0.000580          0.801879         0.000533     0.752588   \n",
       "qikt            0.000483               NaN              NaN          NaN   \n",
       "simplekt        0.000238          0.794722         0.002565     0.750541   \n",
       "ktst_mean       0.000530          0.800194         0.001444     0.752331   \n",
       "ktst_unique          NaN               NaN              NaN          NaN   \n",
       "ktst_mhsa            NaN               NaN              NaN          NaN   \n",
       "\n",
       "              AS2015_std  POJ_mean   POJ_std  \n",
       "dkt             0.000553  0.632917  0.002275  \n",
       "dkvmn           0.000334  0.639364  0.001602  \n",
       "dkt_plus        0.000362  0.647902  0.002252  \n",
       "deep_irt        0.000197  0.637170  0.000764  \n",
       "dkt_forget           NaN  0.637097  0.003802  \n",
       "gkt             0.000560  0.602402  0.022831  \n",
       "kqn             0.000181  0.643285  0.001954  \n",
       "sakt            0.000133  0.639948  0.002905  \n",
       "skvmn           0.000431  0.640744  0.002927  \n",
       "akt             0.000517  0.649184  0.001715  \n",
       "qdkt                 NaN       NaN       NaN  \n",
       "saint           0.000849  0.647389  0.000470  \n",
       "atkt            0.000280  0.636424  0.003151  \n",
       "hawkes               NaN       NaN       NaN  \n",
       "iekt                 NaN       NaN       NaN  \n",
       "lpkt                 NaN       NaN       NaN  \n",
       "dimkt                NaN       NaN       NaN  \n",
       "atdkt                NaN       NaN       NaN  \n",
       "dtransformer    0.000550  0.650912  0.000422  \n",
       "folibikt        0.000212  0.650707  0.003262  \n",
       "qikt                 NaN       NaN       NaN  \n",
       "simplekt        0.000458  0.651629  0.000901  \n",
       "ktst_mean       0.000174  0.656844  0.000769  \n",
       "ktst_unique          NaN       NaN       NaN  \n",
       "ktst_mhsa            NaN       NaN       NaN  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_acc[sum([[f\"{k}_mean\", f\"{k}_std\"] for k in DATASETS.values()], [\"Model\"])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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>Model</th>\n",
       "      <th>Ednet_mean</th>\n",
       "      <th>Ednet_std</th>\n",
       "      <th>AL2005_mean</th>\n",
       "      <th>AL2005_std</th>\n",
       "      <th>AS2009_mean</th>\n",
       "      <th>AS2009_std</th>\n",
       "      <th>NIPS34_mean</th>\n",
       "      <th>NIPS34_std</th>\n",
       "      <th>BD2006_mean</th>\n",
       "      <th>BD2006_std</th>\n",
       "      <th>Statics2011_mean</th>\n",
       "      <th>Statics2011_std</th>\n",
       "      <th>AS2015_mean</th>\n",
       "      <th>AS2015_std</th>\n",
       "      <th>POJ_mean</th>\n",
       "      <th>POJ_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>dkt</th>\n",
       "      <td>DKT</td>\n",
       "      <td>0.610790</td>\n",
       "      <td>0.001667</td>\n",
       "      <td>0.813704</td>\n",
       "      <td>0.001834</td>\n",
       "      <td>0.753174</td>\n",
       "      <td>0.001171</td>\n",
       "      <td>0.768190</td>\n",
       "      <td>0.000550</td>\n",
       "      <td>0.801067</td>\n",
       "      <td>0.000457</td>\n",
       "      <td>0.821961</td>\n",
       "      <td>0.001453</td>\n",
       "      <td>0.726754</td>\n",
       "      <td>0.000465</td>\n",
       "      <td>0.609184</td>\n",
       "      <td>0.000954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkvmn</th>\n",
       "      <td>DKVMN</td>\n",
       "      <td>0.615771</td>\n",
       "      <td>0.001977</td>\n",
       "      <td>0.806036</td>\n",
       "      <td>0.001603</td>\n",
       "      <td>0.746053</td>\n",
       "      <td>0.000977</td>\n",
       "      <td>0.767520</td>\n",
       "      <td>0.000401</td>\n",
       "      <td>0.797955</td>\n",
       "      <td>0.001424</td>\n",
       "      <td>0.809225</td>\n",
       "      <td>0.001635</td>\n",
       "      <td>0.722257</td>\n",
       "      <td>0.000447</td>\n",
       "      <td>0.605584</td>\n",
       "      <td>0.002245</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkt_plus</th>\n",
       "      <td>DKT+</td>\n",
       "      <td>0.615612</td>\n",
       "      <td>0.001775</td>\n",
       "      <td>0.814185</td>\n",
       "      <td>0.000429</td>\n",
       "      <td>0.753626</td>\n",
       "      <td>0.001638</td>\n",
       "      <td>0.768833</td>\n",
       "      <td>0.000189</td>\n",
       "      <td>0.801199</td>\n",
       "      <td>0.000633</td>\n",
       "      <td>0.827460</td>\n",
       "      <td>0.000437</td>\n",
       "      <td>0.728358</td>\n",
       "      <td>0.000598</td>\n",
       "      <td>0.617329</td>\n",
       "      <td>0.000743</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>deep_irt</th>\n",
       "      <td>DeepIRT</td>\n",
       "      <td>0.617130</td>\n",
       "      <td>0.002400</td>\n",
       "      <td>0.802955</td>\n",
       "      <td>0.001384</td>\n",
       "      <td>0.745881</td>\n",
       "      <td>0.000561</td>\n",
       "      <td>0.766843</td>\n",
       "      <td>0.000792</td>\n",
       "      <td>0.796119</td>\n",
       "      <td>0.000757</td>\n",
       "      <td>0.804788</td>\n",
       "      <td>0.003983</td>\n",
       "      <td>0.721658</td>\n",
       "      <td>0.000291</td>\n",
       "      <td>0.603964</td>\n",
       "      <td>0.001906</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dkt_forget</th>\n",
       "      <td>DKT-F</td>\n",
       "      <td>0.616353</td>\n",
       "      <td>0.000849</td>\n",
       "      <td>0.814731</td>\n",
       "      <td>0.001625</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.772859</td>\n",
       "      <td>0.000320</td>\n",
       "      <td>0.797890</td>\n",
       "      <td>0.001367</td>\n",
       "      <td>0.780467</td>\n",
       "      <td>0.000781</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.602747</td>\n",
       "      <td>0.002592</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gkt</th>\n",
       "      <td>GKT</td>\n",
       "      <td>0.621306</td>\n",
       "      <td>0.002440</td>\n",
       "      <td>0.808549</td>\n",
       "      <td>0.001835</td>\n",
       "      <td>0.742227</td>\n",
       "      <td>0.002837</td>\n",
       "      <td>0.765021</td>\n",
       "      <td>0.007080</td>\n",
       "      <td>0.804283</td>\n",
       "      <td>0.001275</td>\n",
       "      <td>0.803340</td>\n",
       "      <td>0.006330</td>\n",
       "      <td>0.723292</td>\n",
       "      <td>0.001546</td>\n",
       "      <td>0.605149</td>\n",
       "      <td>0.006410</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>kqn</th>\n",
       "      <td>KQN</td>\n",
       "      <td>0.608626</td>\n",
       "      <td>0.002209</td>\n",
       "      <td>0.802285</td>\n",
       "      <td>0.002084</td>\n",
       "      <td>0.746545</td>\n",
       "      <td>0.001527</td>\n",
       "      <td>0.767174</td>\n",
       "      <td>0.000401</td>\n",
       "      <td>0.793153</td>\n",
       "      <td>0.000823</td>\n",
       "      <td>0.823063</td>\n",
       "      <td>0.000699</td>\n",
       "      <td>0.725533</td>\n",
       "      <td>0.000415</td>\n",
       "      <td>0.607879</td>\n",
       "      <td>0.001530</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>sakt</th>\n",
       "      <td>SAKT</td>\n",
       "      <td>0.607426</td>\n",
       "      <td>0.001297</td>\n",
       "      <td>0.788747</td>\n",
       "      <td>0.004185</td>\n",
       "      <td>0.724539</td>\n",
       "      <td>0.000934</td>\n",
       "      <td>0.750696</td>\n",
       "      <td>0.001073</td>\n",
       "      <td>0.773196</td>\n",
       "      <td>0.000956</td>\n",
       "      <td>0.796127</td>\n",
       "      <td>0.001323</td>\n",
       "      <td>0.711718</td>\n",
       "      <td>0.000234</td>\n",
       "      <td>0.609112</td>\n",
       "      <td>0.001331</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>skvmn</th>\n",
       "      <td>SKVMN</td>\n",
       "      <td>0.622981</td>\n",
       "      <td>0.004481</td>\n",
       "      <td>0.746146</td>\n",
       "      <td>0.003342</td>\n",
       "      <td>0.732630</td>\n",
       "      <td>0.001609</td>\n",
       "      <td>0.750173</td>\n",
       "      <td>0.001231</td>\n",
       "      <td>0.728555</td>\n",
       "      <td>0.004625</td>\n",
       "      <td>0.807147</td>\n",
       "      <td>0.003045</td>\n",
       "      <td>0.707560</td>\n",
       "      <td>0.000638</td>\n",
       "      <td>0.599646</td>\n",
       "      <td>0.002323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>akt</th>\n",
       "      <td>AKT</td>\n",
       "      <td>0.670454</td>\n",
       "      <td>0.002358</td>\n",
       "      <td>0.829830</td>\n",
       "      <td>0.001651</td>\n",
       "      <td>0.783960</td>\n",
       "      <td>0.001552</td>\n",
       "      <td>0.803020</td>\n",
       "      <td>0.000274</td>\n",
       "      <td>0.820372</td>\n",
       "      <td>0.000621</td>\n",
       "      <td>0.830808</td>\n",
       "      <td>0.001212</td>\n",
       "      <td>0.727914</td>\n",
       "      <td>0.000794</td>\n",
       "      <td>0.628149</td>\n",
       "      <td>0.001471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>qdkt</th>\n",
       "      <td>qDKT</td>\n",
       "      <td>0.698569</td>\n",
       "      <td>0.000637</td>\n",
       "      <td>0.747990</td>\n",
       "      <td>0.001388</td>\n",
       "      <td>0.701406</td>\n",
       "      <td>0.005311</td>\n",
       "      <td>0.799814</td>\n",
       "      <td>0.000331</td>\n",
       "      <td>0.752106</td>\n",
       "      <td>0.000712</td>\n",
       "      <td>NaN</td>\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>saint</th>\n",
       "      <td>SAINT</td>\n",
       "      <td>0.659807</td>\n",
       "      <td>0.002327</td>\n",
       "      <td>0.776718</td>\n",
       "      <td>0.001837</td>\n",
       "      <td>0.691806</td>\n",
       "      <td>0.003626</td>\n",
       "      <td>0.786611</td>\n",
       "      <td>0.002293</td>\n",
       "      <td>0.776181</td>\n",
       "      <td>0.002518</td>\n",
       "      <td>0.760170</td>\n",
       "      <td>0.012928</td>\n",
       "      <td>0.701542</td>\n",
       "      <td>0.000938</td>\n",
       "      <td>0.556379</td>\n",
       "      <td>0.001274</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>atkt</th>\n",
       "      <td>ATKT</td>\n",
       "      <td>0.604818</td>\n",
       "      <td>0.001870</td>\n",
       "      <td>0.797488</td>\n",
       "      <td>0.000676</td>\n",
       "      <td>0.745303</td>\n",
       "      <td>0.000477</td>\n",
       "      <td>0.765700</td>\n",
       "      <td>0.000470</td>\n",
       "      <td>0.787115</td>\n",
       "      <td>0.001725</td>\n",
       "      <td>0.804908</td>\n",
       "      <td>0.002325</td>\n",
       "      <td>0.723844</td>\n",
       "      <td>0.000778</td>\n",
       "      <td>0.607118</td>\n",
       "      <td>0.001509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>hawkes</th>\n",
       "      <td>HawkesKT</td>\n",
       "      <td>0.681516</td>\n",
       "      <td>0.004094</td>\n",
       "      <td>0.820689</td>\n",
       "      <td>0.002080</td>\n",
       "      <td>0.722398</td>\n",
       "      <td>0.000629</td>\n",
       "      <td>0.775736</td>\n",
       "      <td>0.001373</td>\n",
       "      <td>0.806661</td>\n",
       "      <td>0.001092</td>\n",
       "      <td>NaN</td>\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>iekt</th>\n",
       "      <td>IEKT</td>\n",
       "      <td>0.730146</td>\n",
       "      <td>0.001176</td>\n",
       "      <td>0.840311</td>\n",
       "      <td>0.001889</td>\n",
       "      <td>0.783165</td>\n",
       "      <td>0.002110</td>\n",
       "      <td>0.803878</td>\n",
       "      <td>0.000282</td>\n",
       "      <td>0.811622</td>\n",
       "      <td>0.001312</td>\n",
       "      <td>NaN</td>\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>lpkt</th>\n",
       "      <td>LPKT</td>\n",
       "      <td>0.733997</td>\n",
       "      <td>0.000676</td>\n",
       "      <td>0.823912</td>\n",
       "      <td>0.000806</td>\n",
       "      <td>0.781133</td>\n",
       "      <td>0.001945</td>\n",
       "      <td>0.793961</td>\n",
       "      <td>0.001237</td>\n",
       "      <td>0.803906</td>\n",
       "      <td>0.000433</td>\n",
       "      <td>NaN</td>\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>dimkt</th>\n",
       "      <td>DIMKT</td>\n",
       "      <td>0.674791</td>\n",
       "      <td>0.002963</td>\n",
       "      <td>0.827625</td>\n",
       "      <td>0.000715</td>\n",
       "      <td>0.771693</td>\n",
       "      <td>0.001048</td>\n",
       "      <td>0.802163</td>\n",
       "      <td>0.000945</td>\n",
       "      <td>0.816612</td>\n",
       "      <td>0.000658</td>\n",
       "      <td>NaN</td>\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>atdkt</th>\n",
       "      <td>AT-DKT</td>\n",
       "      <td>0.620705</td>\n",
       "      <td>0.004667</td>\n",
       "      <td>0.822287</td>\n",
       "      <td>0.002712</td>\n",
       "      <td>0.755006</td>\n",
       "      <td>0.001692</td>\n",
       "      <td>0.781276</td>\n",
       "      <td>0.000447</td>\n",
       "      <td>0.808601</td>\n",
       "      <td>0.001112</td>\n",
       "      <td>NaN</td>\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>dtransformer</th>\n",
       "      <td>DTransformer</td>\n",
       "      <td>0.671898</td>\n",
       "      <td>0.003711</td>\n",
       "      <td>0.818937</td>\n",
       "      <td>0.002419</td>\n",
       "      <td>0.771814</td>\n",
       "      <td>0.002066</td>\n",
       "      <td>0.798967</td>\n",
       "      <td>0.000616</td>\n",
       "      <td>0.808251</td>\n",
       "      <td>0.000584</td>\n",
       "      <td>0.823482</td>\n",
       "      <td>0.002032</td>\n",
       "      <td>0.725733</td>\n",
       "      <td>0.000393</td>\n",
       "      <td>0.617557</td>\n",
       "      <td>0.000928</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>folibikt</th>\n",
       "      <td>FoLiBiKT</td>\n",
       "      <td>0.672081</td>\n",
       "      <td>0.001803</td>\n",
       "      <td>0.830651</td>\n",
       "      <td>0.000546</td>\n",
       "      <td>0.782829</td>\n",
       "      <td>0.001553</td>\n",
       "      <td>0.802793</td>\n",
       "      <td>0.000519</td>\n",
       "      <td>0.820325</td>\n",
       "      <td>0.001465</td>\n",
       "      <td>0.830186</td>\n",
       "      <td>0.001033</td>\n",
       "      <td>0.728253</td>\n",
       "      <td>0.000423</td>\n",
       "      <td>0.628328</td>\n",
       "      <td>0.000554</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>qikt</th>\n",
       "      <td>QIKT</td>\n",
       "      <td>0.725997</td>\n",
       "      <td>0.001268</td>\n",
       "      <td>0.840795</td>\n",
       "      <td>0.000766</td>\n",
       "      <td>0.787711</td>\n",
       "      <td>0.001883</td>\n",
       "      <td>0.804068</td>\n",
       "      <td>0.000831</td>\n",
       "      <td>0.809382</td>\n",
       "      <td>0.000779</td>\n",
       "      <td>NaN</td>\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>simplekt</th>\n",
       "      <td>simpleKT</td>\n",
       "      <td>0.659340</td>\n",
       "      <td>0.004125</td>\n",
       "      <td>0.824611</td>\n",
       "      <td>0.001195</td>\n",
       "      <td>0.774487</td>\n",
       "      <td>0.002134</td>\n",
       "      <td>0.803472</td>\n",
       "      <td>0.000226</td>\n",
       "      <td>0.815891</td>\n",
       "      <td>0.000501</td>\n",
       "      <td>0.819186</td>\n",
       "      <td>0.000336</td>\n",
       "      <td>0.724467</td>\n",
       "      <td>0.000593</td>\n",
       "      <td>0.624809</td>\n",
       "      <td>0.000891</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ktst_mean</th>\n",
       "      <td>KTST (mean)</td>\n",
       "      <td>0.739416</td>\n",
       "      <td>0.000234</td>\n",
       "      <td>0.852205</td>\n",
       "      <td>0.000450</td>\n",
       "      <td>0.799346</td>\n",
       "      <td>0.001224</td>\n",
       "      <td>0.807055</td>\n",
       "      <td>0.000040</td>\n",
       "      <td>0.826365</td>\n",
       "      <td>0.000359</td>\n",
       "      <td>0.829128</td>\n",
       "      <td>0.000893</td>\n",
       "      <td>0.731416</td>\n",
       "      <td>0.000310</td>\n",
       "      <td>0.634721</td>\n",
       "      <td>0.001138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ktst_unique</th>\n",
       "      <td>KTST (unique)</td>\n",
       "      <td>0.735460</td>\n",
       "      <td>0.000791</td>\n",
       "      <td>0.852937</td>\n",
       "      <td>0.000898</td>\n",
       "      <td>0.798883</td>\n",
       "      <td>0.001381</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\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>ktst_mhsa</th>\n",
       "      <td>KTST (MHSA)</td>\n",
       "      <td>0.738852</td>\n",
       "      <td>0.000895</td>\n",
       "      <td>0.828850</td>\n",
       "      <td>0.000926</td>\n",
       "      <td>0.787124</td>\n",
       "      <td>0.002247</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Model  Ednet_mean  Ednet_std  AL2005_mean  AL2005_std  \\\n",
       "dkt                     DKT    0.610790   0.001667     0.813704    0.001834   \n",
       "dkvmn                 DKVMN    0.615771   0.001977     0.806036    0.001603   \n",
       "dkt_plus               DKT+    0.615612   0.001775     0.814185    0.000429   \n",
       "deep_irt            DeepIRT    0.617130   0.002400     0.802955    0.001384   \n",
       "dkt_forget            DKT-F    0.616353   0.000849     0.814731    0.001625   \n",
       "gkt                     GKT    0.621306   0.002440     0.808549    0.001835   \n",
       "kqn                     KQN    0.608626   0.002209     0.802285    0.002084   \n",
       "sakt                   SAKT    0.607426   0.001297     0.788747    0.004185   \n",
       "skvmn                 SKVMN    0.622981   0.004481     0.746146    0.003342   \n",
       "akt                     AKT    0.670454   0.002358     0.829830    0.001651   \n",
       "qdkt                   qDKT    0.698569   0.000637     0.747990    0.001388   \n",
       "saint                 SAINT    0.659807   0.002327     0.776718    0.001837   \n",
       "atkt                   ATKT    0.604818   0.001870     0.797488    0.000676   \n",
       "hawkes             HawkesKT    0.681516   0.004094     0.820689    0.002080   \n",
       "iekt                   IEKT    0.730146   0.001176     0.840311    0.001889   \n",
       "lpkt                   LPKT    0.733997   0.000676     0.823912    0.000806   \n",
       "dimkt                 DIMKT    0.674791   0.002963     0.827625    0.000715   \n",
       "atdkt                AT-DKT    0.620705   0.004667     0.822287    0.002712   \n",
       "dtransformer   DTransformer    0.671898   0.003711     0.818937    0.002419   \n",
       "folibikt           FoLiBiKT    0.672081   0.001803     0.830651    0.000546   \n",
       "qikt                   QIKT    0.725997   0.001268     0.840795    0.000766   \n",
       "simplekt           simpleKT    0.659340   0.004125     0.824611    0.001195   \n",
       "ktst_mean       KTST (mean)    0.739416   0.000234     0.852205    0.000450   \n",
       "ktst_unique   KTST (unique)    0.735460   0.000791     0.852937    0.000898   \n",
       "ktst_mhsa       KTST (MHSA)    0.738852   0.000895     0.828850    0.000926   \n",
       "\n",
       "              AS2009_mean  AS2009_std  NIPS34_mean  NIPS34_std  BD2006_mean  \\\n",
       "dkt              0.753174    0.001171     0.768190    0.000550     0.801067   \n",
       "dkvmn            0.746053    0.000977     0.767520    0.000401     0.797955   \n",
       "dkt_plus         0.753626    0.001638     0.768833    0.000189     0.801199   \n",
       "deep_irt         0.745881    0.000561     0.766843    0.000792     0.796119   \n",
       "dkt_forget            NaN         NaN     0.772859    0.000320     0.797890   \n",
       "gkt              0.742227    0.002837     0.765021    0.007080     0.804283   \n",
       "kqn              0.746545    0.001527     0.767174    0.000401     0.793153   \n",
       "sakt             0.724539    0.000934     0.750696    0.001073     0.773196   \n",
       "skvmn            0.732630    0.001609     0.750173    0.001231     0.728555   \n",
       "akt              0.783960    0.001552     0.803020    0.000274     0.820372   \n",
       "qdkt             0.701406    0.005311     0.799814    0.000331     0.752106   \n",
       "saint            0.691806    0.003626     0.786611    0.002293     0.776181   \n",
       "atkt             0.745303    0.000477     0.765700    0.000470     0.787115   \n",
       "hawkes           0.722398    0.000629     0.775736    0.001373     0.806661   \n",
       "iekt             0.783165    0.002110     0.803878    0.000282     0.811622   \n",
       "lpkt             0.781133    0.001945     0.793961    0.001237     0.803906   \n",
       "dimkt            0.771693    0.001048     0.802163    0.000945     0.816612   \n",
       "atdkt            0.755006    0.001692     0.781276    0.000447     0.808601   \n",
       "dtransformer     0.771814    0.002066     0.798967    0.000616     0.808251   \n",
       "folibikt         0.782829    0.001553     0.802793    0.000519     0.820325   \n",
       "qikt             0.787711    0.001883     0.804068    0.000831     0.809382   \n",
       "simplekt         0.774487    0.002134     0.803472    0.000226     0.815891   \n",
       "ktst_mean        0.799346    0.001224     0.807055    0.000040     0.826365   \n",
       "ktst_unique      0.798883    0.001381          NaN         NaN          NaN   \n",
       "ktst_mhsa        0.787124    0.002247          NaN         NaN          NaN   \n",
       "\n",
       "              BD2006_std  Statics2011_mean  Statics2011_std  AS2015_mean  \\\n",
       "dkt             0.000457          0.821961         0.001453     0.726754   \n",
       "dkvmn           0.001424          0.809225         0.001635     0.722257   \n",
       "dkt_plus        0.000633          0.827460         0.000437     0.728358   \n",
       "deep_irt        0.000757          0.804788         0.003983     0.721658   \n",
       "dkt_forget      0.001367          0.780467         0.000781          NaN   \n",
       "gkt             0.001275          0.803340         0.006330     0.723292   \n",
       "kqn             0.000823          0.823063         0.000699     0.725533   \n",
       "sakt            0.000956          0.796127         0.001323     0.711718   \n",
       "skvmn           0.004625          0.807147         0.003045     0.707560   \n",
       "akt             0.000621          0.830808         0.001212     0.727914   \n",
       "qdkt            0.000712               NaN              NaN          NaN   \n",
       "saint           0.002518          0.760170         0.012928     0.701542   \n",
       "atkt            0.001725          0.804908         0.002325     0.723844   \n",
       "hawkes          0.001092               NaN              NaN          NaN   \n",
       "iekt            0.001312               NaN              NaN          NaN   \n",
       "lpkt            0.000433               NaN              NaN          NaN   \n",
       "dimkt           0.000658               NaN              NaN          NaN   \n",
       "atdkt           0.001112               NaN              NaN          NaN   \n",
       "dtransformer    0.000584          0.823482         0.002032     0.725733   \n",
       "folibikt        0.001465          0.830186         0.001033     0.728253   \n",
       "qikt            0.000779               NaN              NaN          NaN   \n",
       "simplekt        0.000501          0.819186         0.000336     0.724467   \n",
       "ktst_mean       0.000359          0.829128         0.000893     0.731416   \n",
       "ktst_unique          NaN               NaN              NaN          NaN   \n",
       "ktst_mhsa            NaN               NaN              NaN          NaN   \n",
       "\n",
       "              AS2015_std  POJ_mean   POJ_std  \n",
       "dkt             0.000465  0.609184  0.000954  \n",
       "dkvmn           0.000447  0.605584  0.002245  \n",
       "dkt_plus        0.000598  0.617329  0.000743  \n",
       "deep_irt        0.000291  0.603964  0.001906  \n",
       "dkt_forget           NaN  0.602747  0.002592  \n",
       "gkt             0.001546  0.605149  0.006410  \n",
       "kqn             0.000415  0.607879  0.001530  \n",
       "sakt            0.000234  0.609112  0.001331  \n",
       "skvmn           0.000638  0.599646  0.002323  \n",
       "akt             0.000794  0.628149  0.001471  \n",
       "qdkt                 NaN       NaN       NaN  \n",
       "saint           0.000938  0.556379  0.001274  \n",
       "atkt            0.000778  0.607118  0.001509  \n",
       "hawkes               NaN       NaN       NaN  \n",
       "iekt                 NaN       NaN       NaN  \n",
       "lpkt                 NaN       NaN       NaN  \n",
       "dimkt                NaN       NaN       NaN  \n",
       "atdkt                NaN       NaN       NaN  \n",
       "dtransformer    0.000393  0.617557  0.000928  \n",
       "folibikt        0.000423  0.628328  0.000554  \n",
       "qikt                 NaN       NaN       NaN  \n",
       "simplekt        0.000593  0.624809  0.000891  \n",
       "ktst_mean       0.000310  0.634721  0.001138  \n",
       "ktst_unique          NaN       NaN       NaN  \n",
       "ktst_mhsa            NaN       NaN       NaN  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_auc[sum([[f\"{k}_mean\", f\"{k}_std\"] for k in DATASETS.values()], [\"Model\"])]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Format results to LaTeX"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_latex(df: pd.DataFrame, reduced: bool):\n",
    "    f = lambda x, m, n: (\n",
    "        (\"\\\\textbf{\" if (x == m) else \"\")\n",
    "        + (\"\\\\underline{\" if (x == n) else \"\")\n",
    "        + \"{0:.4f}\".format(x)\n",
    "        + (\"}\" if (x == m) else \"\")\n",
    "        + (\"}\" if (x == n) else \"\")\n",
    "    )\n",
    "    g = lambda x: \"{0:.4f}\".format(x)\n",
    "    for dataset in (DATASETS_REDUCED if reduced else DATASETS).values():\n",
    "        max_val, sec_max_val = df[f\"{dataset}_mean\"].nlargest(2)\n",
    "        df[dataset] = df.apply(\n",
    "            lambda x: (\n",
    "                (tmp := f(x[f\"{dataset}_mean\"], max_val, sec_max_val))\n",
    "                + \" $\\pm$ \"\n",
    "                + g(x[f\"{dataset}_std\"])\n",
    "                # + f\"{'}' if 'textbf' in tmp else ''}\"\n",
    "                + f\" {x[f'{dataset}_sig']}\"\n",
    "                if pd.notnull(x[f\"{dataset}_mean\"])\n",
    "                else \"---\"\n",
    "            ),\n",
    "            axis=1,\n",
    "        )\n",
    "    df_out = df[[\"Model\"] + list((DATASETS_REDUCED if reduced else DATASETS).values())]\n",
    "    df_out = df_out[df_out[\"Model\"].isin((MODELS_REDUCED_FULL if reduced else MODELS_FULL).values())]\n",
    "    df_out[\"Model\"] = df_out[\"Model\"].apply(lambda x: f\"\\\\textbf{{{x}}}\")\n",
    "    df_out = df_out.set_index(\"Model\")\n",
    "\n",
    "    headers = [f\"\\\\textbf{{{d}}}\" for d in (DATASETS_REDUCED if reduced else DATASETS).values()]\n",
    "    print(\n",
    "        tabulate(\n",
    "            df_out,\n",
    "            headers=headers,\n",
    "            tablefmt=\"latex_raw\",\n",
    "            colalign=[\"right\"] + [\"center\"] * len((DATASETS_REDUCED if reduced else DATASETS).values()),\n",
    "        )\n",
    "    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "--- Reduced"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rccccc}\n",
      "\\hline\n",
      "                        &             \\textbf{Ednet}              &             \\textbf{AL2005}              &             \\textbf{AS2009}             &            \\textbf{NIPS34}             &            \\textbf{BD2006}             \\\\\n",
      "\\hline\n",
      "           \\textbf{DKT} &       0.6108 $\\pm$ 0.0017 $\\ast$        &        0.8137 $\\pm$ 0.0018 $\\ast$        &       0.7532 $\\pm$ 0.0012 $\\ast$        &       0.7682 $\\pm$ 0.0006 $\\ast$       &       0.8011 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "         \\textbf{DKVMN} &       0.6158 $\\pm$ 0.0020 $\\ast$        &        0.8060 $\\pm$ 0.0016 $\\ast$        &       0.7461 $\\pm$ 0.0010 $\\ast$        &       0.7675 $\\pm$ 0.0004 $\\ast$       &       0.7980 $\\pm$ 0.0014 $\\ast$       \\\\\n",
      "          \\textbf{DKT+} &       0.6156 $\\pm$ 0.0018 $\\ast$        &        0.8142 $\\pm$ 0.0004 $\\ast$        &       0.7536 $\\pm$ 0.0016 $\\ast$        &       0.7688 $\\pm$ 0.0002 $\\ast$       &       0.8012 $\\pm$ 0.0006 $\\ast$       \\\\\n",
      "           \\textbf{GKT} &       0.6213 $\\pm$ 0.0024 $\\ast$        &        0.8085 $\\pm$ 0.0018 $\\ast$        &       0.7422 $\\pm$ 0.0028 $\\ast$        &       0.7650 $\\pm$ 0.0071 $\\ast$       &       0.8043 $\\pm$ 0.0013 $\\ast$       \\\\\n",
      "          \\textbf{SAKT} &       0.6074 $\\pm$ 0.0013 $\\ast$        &        0.7887 $\\pm$ 0.0042 $\\ast$        &       0.7245 $\\pm$ 0.0009 $\\ast$        &       0.7507 $\\pm$ 0.0011 $\\ast$       &       0.7732 $\\pm$ 0.0010 $\\ast$       \\\\\n",
      "         \\textbf{SKVMN} &       0.6230 $\\pm$ 0.0045 $\\ast$        &        0.7461 $\\pm$ 0.0033 $\\ast$        &       0.7326 $\\pm$ 0.0016 $\\ast$        &       0.7502 $\\pm$ 0.0012 $\\ast$       &       0.7286 $\\pm$ 0.0046 $\\ast$       \\\\\n",
      "           \\textbf{AKT} &       0.6705 $\\pm$ 0.0024 $\\ast$        &        0.8298 $\\pm$ 0.0017 $\\ast$        &       0.7840 $\\pm$ 0.0016 $\\ast$        &       0.8030 $\\pm$ 0.0003 $\\ast$       & \\underline{0.8204} $\\pm$ 0.0006 $\\ast$ \\\\\n",
      "         \\textbf{SAINT} &       0.6598 $\\pm$ 0.0023 $\\ast$        &        0.7767 $\\pm$ 0.0018 $\\ast$        &       0.6918 $\\pm$ 0.0036 $\\ast$        &       0.7866 $\\pm$ 0.0023 $\\ast$       &       0.7762 $\\pm$ 0.0025 $\\ast$       \\\\\n",
      "      \\textbf{HawkesKT} &       0.6815 $\\pm$ 0.0041 $\\ast$        &        0.8207 $\\pm$ 0.0021 $\\ast$        &       0.7224 $\\pm$ 0.0006 $\\ast$        &       0.7757 $\\pm$ 0.0014 $\\ast$       &       0.8067 $\\pm$ 0.0011 $\\ast$       \\\\\n",
      "          \\textbf{IEKT} &       0.7301 $\\pm$ 0.0012 $\\ast$        &        0.8403 $\\pm$ 0.0019 $\\ast$        &       0.7832 $\\pm$ 0.0021 $\\ast$        &       0.8039 $\\pm$ 0.0003 $\\ast$       &       0.8116 $\\pm$ 0.0013 $\\ast$       \\\\\n",
      "          \\textbf{LPKT} &       0.7340 $\\pm$ 0.0007 $\\ast$        &        0.8239 $\\pm$ 0.0008 $\\ast$        &       0.7811 $\\pm$ 0.0019 $\\ast$        &       0.7940 $\\pm$ 0.0012 $\\ast$       &       0.8039 $\\pm$ 0.0004 $\\ast$       \\\\\n",
      "         \\textbf{DIMKT} &       0.6748 $\\pm$ 0.0030 $\\ast$        &        0.8276 $\\pm$ 0.0007 $\\ast$        &       0.7717 $\\pm$ 0.0010 $\\ast$        &       0.8022 $\\pm$ 0.0009 $\\ast$       &       0.8166 $\\pm$ 0.0007 $\\ast$       \\\\\n",
      "  \\textbf{DTransformer} &       0.6719 $\\pm$ 0.0037 $\\ast$        &        0.8189 $\\pm$ 0.0024 $\\ast$        &       0.7718 $\\pm$ 0.0021 $\\ast$        &       0.7990 $\\pm$ 0.0006 $\\ast$       &       0.8083 $\\pm$ 0.0006 $\\ast$       \\\\\n",
      "      \\textbf{FoLiBiKT} &       0.6721 $\\pm$ 0.0018 $\\ast$        &        0.8307 $\\pm$ 0.0005 $\\ast$        &       0.7828 $\\pm$ 0.0016 $\\ast$        &       0.8028 $\\pm$ 0.0005 $\\ast$       &       0.8203 $\\pm$ 0.0015 $\\ast$       \\\\\n",
      "          \\textbf{QIKT} &       0.7260 $\\pm$ 0.0013 $\\ast$        &        0.8408 $\\pm$ 0.0008 $\\ast$        &       0.7877 $\\pm$ 0.0019 $\\ast$        & \\underline{0.8041} $\\pm$ 0.0008 $\\ast$ &       0.8094 $\\pm$ 0.0008 $\\ast$       \\\\\n",
      "      \\textbf{simpleKT} &       0.6593 $\\pm$ 0.0041 $\\ast$        &        0.8246 $\\pm$ 0.0012 $\\ast$        &       0.7745 $\\pm$ 0.0021 $\\ast$        &       0.8035 $\\pm$ 0.0002 $\\ast$       &       0.8159 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "   \\textbf{KTST (mean)} &  \\textbf{0.7394} $\\pm$ 0.0002 $\\; \\: $  & \\underline{0.8522} $\\pm$ 0.0004 $\\; \\: $ &  \\textbf{0.7993} $\\pm$ 0.0012 $\\; \\: $  & \\textbf{0.8071} $\\pm$ 0.0000 $\\; \\: $  & \\textbf{0.8264} $\\pm$ 0.0004 $\\; \\: $  \\\\\n",
      " \\textbf{KTST (unique)} &       0.7355 $\\pm$ 0.0008 $\\ast$        &   \\textbf{0.8529} $\\pm$ 0.0009 $\\circ$   & \\underline{0.7989} $\\pm$ 0.0014 $\\circ$ &                  ---                   &                  ---                   \\\\\n",
      "   \\textbf{KTST (MHSA)} & \\underline{0.7389} $\\pm$ 0.0009 $\\circ$ &        0.8288 $\\pm$ 0.0009 $\\ast$        &       0.7871 $\\pm$ 0.0022 $\\ast$        &                  ---                   &                  ---                   \\\\\n",
      "\\hline\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "print_latex(df_auc, reduced=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rccccc}\n",
      "\\hline\n",
      "                        &             \\textbf{Ednet}              &             \\textbf{AL2005}              &             \\textbf{AS2009}             &            \\textbf{NIPS34}             &            \\textbf{BD2006}             \\\\\n",
      "\\hline\n",
      "           \\textbf{DKT} &       0.6420 $\\pm$ 0.0023 $\\ast$        &        0.8094 $\\pm$ 0.0010 $\\ast$        &       0.7241 $\\pm$ 0.0012 $\\ast$        &       0.7024 $\\pm$ 0.0008 $\\ast$       &       0.8551 $\\pm$ 0.0003 $\\ast$       \\\\\n",
      "         \\textbf{DKVMN} &       0.6446 $\\pm$ 0.0030 $\\ast$        &        0.8031 $\\pm$ 0.0008 $\\ast$        &       0.7194 $\\pm$ 0.0006 $\\ast$        &       0.7020 $\\pm$ 0.0004 $\\ast$       &       0.8545 $\\pm$ 0.0003 $\\ast$       \\\\\n",
      "          \\textbf{DKT+} &       0.6517 $\\pm$ 0.0057 $\\ast$        &        0.8093 $\\pm$ 0.0004 $\\ast$        &       0.7241 $\\pm$ 0.0013 $\\ast$        &       0.7034 $\\pm$ 0.0005 $\\ast$       &       0.8551 $\\pm$ 0.0002 $\\ast$       \\\\\n",
      "           \\textbf{GKT} &       0.6639 $\\pm$ 0.0050 $\\ast$        &        0.8086 $\\pm$ 0.0008 $\\ast$        &       0.7158 $\\pm$ 0.0016 $\\ast$        &       0.6956 $\\pm$ 0.0103 $\\ast$       &       0.8553 $\\pm$ 0.0003 $\\ast$       \\\\\n",
      "          \\textbf{SAKT} &       0.6392 $\\pm$ 0.0039 $\\ast$        &        0.7959 $\\pm$ 0.0018 $\\ast$        &       0.7071 $\\pm$ 0.0016 $\\ast$        &       0.6870 $\\pm$ 0.0010 $\\ast$       &       0.8456 $\\pm$ 0.0006 $\\ast$       \\\\\n",
      "         \\textbf{SKVMN} &       0.6606 $\\pm$ 0.0090 $\\ast$        &        0.7821 $\\pm$ 0.0032 $\\ast$        &       0.7160 $\\pm$ 0.0010 $\\ast$        &       0.6874 $\\pm$ 0.0010 $\\ast$       &       0.8408 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "           \\textbf{AKT} &       0.6645 $\\pm$ 0.0035 $\\ast$        &        0.8125 $\\pm$ 0.0016 $\\ast$        &       0.7383 $\\pm$ 0.0020 $\\ast$        &       0.7317 $\\pm$ 0.0005 $\\ast$       & \\underline{0.8586} $\\pm$ 0.0005 $\\ast$ \\\\\n",
      "         \\textbf{SAINT} &       0.6511 $\\pm$ 0.0039 $\\ast$        &        0.7789 $\\pm$ 0.0030 $\\ast$        &       0.6885 $\\pm$ 0.0044 $\\ast$        &       0.7172 $\\pm$ 0.0025 $\\ast$       &      0.8374 $\\pm$ 0.0108 $\\circ$       \\\\\n",
      "      \\textbf{HawkesKT} &       0.6905 $\\pm$ 0.0025 $\\ast$        &        0.8112 $\\pm$ 0.0012 $\\ast$        &       0.7045 $\\pm$ 0.0008 $\\ast$        &       0.7102 $\\pm$ 0.0013 $\\ast$       &       0.8559 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "          \\textbf{IEKT} &       0.7106 $\\pm$ 0.0018 $\\ast$        &        0.8228 $\\pm$ 0.0008 $\\ast$        &       0.7336 $\\pm$ 0.0027 $\\ast$        &       0.7327 $\\pm$ 0.0001 $\\ast$       &       0.8556 $\\pm$ 0.0009 $\\ast$       \\\\\n",
      "          \\textbf{LPKT} &       0.7128 $\\pm$ 0.0004 $\\ast$        &        0.8129 $\\pm$ 0.0008 $\\ast$        &       0.7356 $\\pm$ 0.0011 $\\ast$        &       0.7179 $\\pm$ 0.0033 $\\ast$       &       0.8538 $\\pm$ 0.0002 $\\ast$       \\\\\n",
      "         \\textbf{DIMKT} &       0.6700 $\\pm$ 0.0038 $\\ast$        &        0.8106 $\\pm$ 0.0004 $\\ast$        &       0.7354 $\\pm$ 0.0019 $\\ast$        &       0.7309 $\\pm$ 0.0005 $\\ast$       &       0.8578 $\\pm$ 0.0004 $\\ast$       \\\\\n",
      "  \\textbf{DTransformer} &       0.6656 $\\pm$ 0.0032 $\\ast$        &        0.8054 $\\pm$ 0.0007 $\\ast$        &       0.7284 $\\pm$ 0.0007 $\\ast$        &       0.7290 $\\pm$ 0.0012 $\\ast$       &       0.8556 $\\pm$ 0.0006 $\\ast$       \\\\\n",
      "      \\textbf{FoLiBiKT} &       0.6666 $\\pm$ 0.0028 $\\ast$        &        0.8127 $\\pm$ 0.0012 $\\ast$        &       0.7391 $\\pm$ 0.0013 $\\ast$        &       0.7319 $\\pm$ 0.0005 $\\ast$       &       0.8583 $\\pm$ 0.0006 $\\ast$       \\\\\n",
      "          \\textbf{QIKT} &       0.7077 $\\pm$ 0.0014 $\\ast$        &        0.8220 $\\pm$ 0.0007 $\\ast$        &       0.7382 $\\pm$ 0.0008 $\\ast$        &       0.7326 $\\pm$ 0.0008 $\\ast$       &       0.8537 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "      \\textbf{simpleKT} &       0.6565 $\\pm$ 0.0029 $\\ast$        &        0.8081 $\\pm$ 0.0010 $\\ast$        &       0.7319 $\\pm$ 0.0019 $\\ast$        & \\underline{0.7327} $\\pm$ 0.0003 $\\ast$ &       0.8579 $\\pm$ 0.0002 $\\ast$       \\\\\n",
      "   \\textbf{KTST (mean)} &  \\textbf{0.7154} $\\pm$ 0.0011 $\\; \\: $  & \\underline{0.8287} $\\pm$ 0.0005 $\\; \\: $ &  \\textbf{0.7490} $\\pm$ 0.0013 $\\; \\: $  & \\textbf{0.7356} $\\pm$ 0.0003 $\\; \\: $  & \\textbf{0.8608} $\\pm$ 0.0005 $\\; \\: $  \\\\\n",
      " \\textbf{KTST (unique)} &       0.7131 $\\pm$ 0.0017 $\\circ$       &   \\textbf{0.8291} $\\pm$ 0.0008 $\\circ$   & \\underline{0.7489} $\\pm$ 0.0011 $\\circ$ &                  ---                   &                  ---                   \\\\\n",
      "   \\textbf{KTST (MHSA)} & \\underline{0.7152} $\\pm$ 0.0011 $\\circ$ &        0.8166 $\\pm$ 0.0012 $\\ast$        &       0.7415 $\\pm$ 0.0014 $\\ast$        &                  ---                   &                  ---                   \\\\\n",
      "\\hline\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "print_latex(df_acc, reduced=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "--- Complete"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rcccccccc}\n",
      "\\hline\n",
      "                        &             \\textbf{Ednet}              &             \\textbf{AL2005}              &             \\textbf{AS2009}             &            \\textbf{NIPS34}             &            \\textbf{BD2006}             &          \\textbf{Statics2011}           &            \\textbf{AS2015}             &              \\textbf{POJ}              \\\\\n",
      "\\hline\n",
      "           \\textbf{DKT} &       0.6108 $\\pm$ 0.0017 $\\ast$        &        0.8137 $\\pm$ 0.0018 $\\ast$        &       0.7532 $\\pm$ 0.0012 $\\ast$        &       0.7682 $\\pm$ 0.0006 $\\ast$       &       0.8011 $\\pm$ 0.0005 $\\ast$       &       0.8220 $\\pm$ 0.0015 $\\ast$        &       0.7268 $\\pm$ 0.0005 $\\ast$       &       0.6092 $\\pm$ 0.0010 $\\ast$       \\\\\n",
      "         \\textbf{DKVMN} &       0.6158 $\\pm$ 0.0020 $\\ast$        &        0.8060 $\\pm$ 0.0016 $\\ast$        &       0.7461 $\\pm$ 0.0010 $\\ast$        &       0.7675 $\\pm$ 0.0004 $\\ast$       &       0.7980 $\\pm$ 0.0014 $\\ast$       &       0.8092 $\\pm$ 0.0016 $\\ast$        &       0.7223 $\\pm$ 0.0004 $\\ast$       &       0.6056 $\\pm$ 0.0022 $\\ast$       \\\\\n",
      "          \\textbf{DKT+} &       0.6156 $\\pm$ 0.0018 $\\ast$        &        0.8142 $\\pm$ 0.0004 $\\ast$        &       0.7536 $\\pm$ 0.0016 $\\ast$        &       0.7688 $\\pm$ 0.0002 $\\ast$       &       0.8012 $\\pm$ 0.0006 $\\ast$       &       0.8275 $\\pm$ 0.0004 $\\circ$       & \\underline{0.7284} $\\pm$ 0.0006 $\\ast$ &       0.6173 $\\pm$ 0.0007 $\\ast$       \\\\\n",
      "       \\textbf{DeepIRT} &       0.6171 $\\pm$ 0.0024 $\\ast$        &        0.8030 $\\pm$ 0.0014 $\\ast$        &       0.7459 $\\pm$ 0.0006 $\\ast$        &       0.7668 $\\pm$ 0.0008 $\\ast$       &       0.7961 $\\pm$ 0.0008 $\\ast$       &       0.8048 $\\pm$ 0.0040 $\\ast$        &       0.7217 $\\pm$ 0.0003 $\\ast$       &       0.6040 $\\pm$ 0.0019 $\\ast$       \\\\\n",
      "         \\textbf{DKT-F} &       0.6164 $\\pm$ 0.0008 $\\ast$        &        0.8147 $\\pm$ 0.0016 $\\ast$        &                   ---                   &       0.7729 $\\pm$ 0.0003 $\\ast$       &       0.7979 $\\pm$ 0.0014 $\\ast$       &       0.7805 $\\pm$ 0.0008 $\\ast$        &                  ---                   &       0.6027 $\\pm$ 0.0026 $\\ast$       \\\\\n",
      "           \\textbf{GKT} &       0.6213 $\\pm$ 0.0024 $\\ast$        &        0.8085 $\\pm$ 0.0018 $\\ast$        &       0.7422 $\\pm$ 0.0028 $\\ast$        &       0.7650 $\\pm$ 0.0071 $\\ast$       &       0.8043 $\\pm$ 0.0013 $\\ast$       &       0.8033 $\\pm$ 0.0063 $\\ast$        &       0.7233 $\\pm$ 0.0015 $\\ast$       &       0.6051 $\\pm$ 0.0064 $\\ast$       \\\\\n",
      "           \\textbf{KQN} &       0.6086 $\\pm$ 0.0022 $\\ast$        &        0.8023 $\\pm$ 0.0021 $\\ast$        &       0.7465 $\\pm$ 0.0015 $\\ast$        &       0.7672 $\\pm$ 0.0004 $\\ast$       &       0.7932 $\\pm$ 0.0008 $\\ast$       &       0.8231 $\\pm$ 0.0007 $\\ast$        &       0.7255 $\\pm$ 0.0004 $\\ast$       &       0.6079 $\\pm$ 0.0015 $\\ast$       \\\\\n",
      "          \\textbf{SAKT} &       0.6074 $\\pm$ 0.0013 $\\ast$        &        0.7887 $\\pm$ 0.0042 $\\ast$        &       0.7245 $\\pm$ 0.0009 $\\ast$        &       0.7507 $\\pm$ 0.0011 $\\ast$       &       0.7732 $\\pm$ 0.0010 $\\ast$       &       0.7961 $\\pm$ 0.0013 $\\ast$        &       0.7117 $\\pm$ 0.0002 $\\ast$       &       0.6091 $\\pm$ 0.0013 $\\ast$       \\\\\n",
      "         \\textbf{SKVMN} &       0.6230 $\\pm$ 0.0045 $\\ast$        &        0.7461 $\\pm$ 0.0033 $\\ast$        &       0.7326 $\\pm$ 0.0016 $\\ast$        &       0.7502 $\\pm$ 0.0012 $\\ast$       &       0.7286 $\\pm$ 0.0046 $\\ast$       &       0.8071 $\\pm$ 0.0030 $\\ast$        &       0.7076 $\\pm$ 0.0006 $\\ast$       &       0.5996 $\\pm$ 0.0023 $\\ast$       \\\\\n",
      "           \\textbf{AKT} &       0.6705 $\\pm$ 0.0024 $\\ast$        &        0.8298 $\\pm$ 0.0017 $\\ast$        &       0.7840 $\\pm$ 0.0016 $\\ast$        &       0.8030 $\\pm$ 0.0003 $\\ast$       & \\underline{0.8204} $\\pm$ 0.0006 $\\ast$ &  \\textbf{0.8308} $\\pm$ 0.0012 $\\circ$   &       0.7279 $\\pm$ 0.0008 $\\ast$       &       0.6281 $\\pm$ 0.0015 $\\ast$       \\\\\n",
      "          \\textbf{qDKT} &       0.6986 $\\pm$ 0.0006 $\\ast$        &        0.7480 $\\pm$ 0.0014 $\\ast$        &       0.7014 $\\pm$ 0.0053 $\\ast$        &       0.7998 $\\pm$ 0.0003 $\\ast$       &       0.7521 $\\pm$ 0.0007 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "         \\textbf{SAINT} &       0.6598 $\\pm$ 0.0023 $\\ast$        &        0.7767 $\\pm$ 0.0018 $\\ast$        &       0.6918 $\\pm$ 0.0036 $\\ast$        &       0.7866 $\\pm$ 0.0023 $\\ast$       &       0.7762 $\\pm$ 0.0025 $\\ast$       &       0.7602 $\\pm$ 0.0129 $\\ast$        &       0.7015 $\\pm$ 0.0009 $\\ast$       &       0.5564 $\\pm$ 0.0013 $\\ast$       \\\\\n",
      "          \\textbf{ATKT} &       0.6048 $\\pm$ 0.0019 $\\ast$        &        0.7975 $\\pm$ 0.0007 $\\ast$        &       0.7453 $\\pm$ 0.0005 $\\ast$        &       0.7657 $\\pm$ 0.0005 $\\ast$       &       0.7871 $\\pm$ 0.0017 $\\ast$       &       0.8049 $\\pm$ 0.0023 $\\ast$        &       0.7238 $\\pm$ 0.0008 $\\ast$       &       0.6071 $\\pm$ 0.0015 $\\ast$       \\\\\n",
      "      \\textbf{HawkesKT} &       0.6815 $\\pm$ 0.0041 $\\ast$        &        0.8207 $\\pm$ 0.0021 $\\ast$        &       0.7224 $\\pm$ 0.0006 $\\ast$        &       0.7757 $\\pm$ 0.0014 $\\ast$       &       0.8067 $\\pm$ 0.0011 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "          \\textbf{IEKT} &       0.7301 $\\pm$ 0.0012 $\\ast$        &        0.8403 $\\pm$ 0.0019 $\\ast$        &       0.7832 $\\pm$ 0.0021 $\\ast$        &       0.8039 $\\pm$ 0.0003 $\\ast$       &       0.8116 $\\pm$ 0.0013 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "          \\textbf{LPKT} &       0.7340 $\\pm$ 0.0007 $\\ast$        &        0.8239 $\\pm$ 0.0008 $\\ast$        &       0.7811 $\\pm$ 0.0019 $\\ast$        &       0.7940 $\\pm$ 0.0012 $\\ast$       &       0.8039 $\\pm$ 0.0004 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "         \\textbf{DIMKT} &       0.6748 $\\pm$ 0.0030 $\\ast$        &        0.8276 $\\pm$ 0.0007 $\\ast$        &       0.7717 $\\pm$ 0.0010 $\\ast$        &       0.8022 $\\pm$ 0.0009 $\\ast$       &       0.8166 $\\pm$ 0.0007 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "        \\textbf{AT-DKT} &       0.6207 $\\pm$ 0.0047 $\\ast$        &        0.8223 $\\pm$ 0.0027 $\\ast$        &       0.7550 $\\pm$ 0.0017 $\\ast$        &       0.7813 $\\pm$ 0.0004 $\\ast$       &       0.8086 $\\pm$ 0.0011 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "  \\textbf{DTransformer} &       0.6719 $\\pm$ 0.0037 $\\ast$        &        0.8189 $\\pm$ 0.0024 $\\ast$        &       0.7718 $\\pm$ 0.0021 $\\ast$        &       0.7990 $\\pm$ 0.0006 $\\ast$       &       0.8083 $\\pm$ 0.0006 $\\ast$       &       0.8235 $\\pm$ 0.0020 $\\ast$        &       0.7257 $\\pm$ 0.0004 $\\ast$       &       0.6176 $\\pm$ 0.0009 $\\ast$       \\\\\n",
      "      \\textbf{FoLiBiKT} &       0.6721 $\\pm$ 0.0018 $\\ast$        &        0.8307 $\\pm$ 0.0005 $\\ast$        &       0.7828 $\\pm$ 0.0016 $\\ast$        &       0.8028 $\\pm$ 0.0005 $\\ast$       &       0.8203 $\\pm$ 0.0015 $\\ast$       & \\underline{0.8302} $\\pm$ 0.0010 $\\circ$ &       0.7283 $\\pm$ 0.0004 $\\ast$       & \\underline{0.6283} $\\pm$ 0.0006 $\\ast$ \\\\\n",
      "          \\textbf{QIKT} &       0.7260 $\\pm$ 0.0013 $\\ast$        &        0.8408 $\\pm$ 0.0008 $\\ast$        &       0.7877 $\\pm$ 0.0019 $\\ast$        & \\underline{0.8041} $\\pm$ 0.0008 $\\ast$ &       0.8094 $\\pm$ 0.0008 $\\ast$       &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "      \\textbf{simpleKT} &       0.6593 $\\pm$ 0.0041 $\\ast$        &        0.8246 $\\pm$ 0.0012 $\\ast$        &       0.7745 $\\pm$ 0.0021 $\\ast$        &       0.8035 $\\pm$ 0.0002 $\\ast$       &       0.8159 $\\pm$ 0.0005 $\\ast$       &       0.8192 $\\pm$ 0.0003 $\\ast$        &       0.7245 $\\pm$ 0.0006 $\\ast$       &       0.6248 $\\pm$ 0.0009 $\\ast$       \\\\\n",
      "   \\textbf{KTST (mean)} &  \\textbf{0.7394} $\\pm$ 0.0002 $\\; \\: $  & \\underline{0.8522} $\\pm$ 0.0004 $\\; \\: $ &  \\textbf{0.7993} $\\pm$ 0.0012 $\\; \\: $  & \\textbf{0.8071} $\\pm$ 0.0000 $\\; \\: $  & \\textbf{0.8264} $\\pm$ 0.0004 $\\; \\: $  &      0.8291 $\\pm$ 0.0009 $\\; \\: $       & \\textbf{0.7314} $\\pm$ 0.0003 $\\; \\: $  & \\textbf{0.6347} $\\pm$ 0.0011 $\\; \\: $  \\\\\n",
      " \\textbf{KTST (unique)} &       0.7355 $\\pm$ 0.0008 $\\ast$        &   \\textbf{0.8529} $\\pm$ 0.0009 $\\circ$   & \\underline{0.7989} $\\pm$ 0.0014 $\\circ$ &                  ---                   &                  ---                   &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "   \\textbf{KTST (MHSA)} & \\underline{0.7389} $\\pm$ 0.0009 $\\circ$ &        0.8288 $\\pm$ 0.0009 $\\ast$        &       0.7871 $\\pm$ 0.0022 $\\ast$        &                  ---                   &                  ---                   &                   ---                   &                  ---                   &                  ---                   \\\\\n",
      "\\hline\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "print_latex(df_auc, reduced=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rcccccccc}\n",
      "\\hline\n",
      "                        &             \\textbf{Ednet}              &             \\textbf{AL2005}              &             \\textbf{AS2009}             &            \\textbf{NIPS34}             &            \\textbf{BD2006}             &          \\textbf{Statics2011}           &             \\textbf{AS2015}              &              \\textbf{POJ}              \\\\\n",
      "\\hline\n",
      "           \\textbf{DKT} &       0.6420 $\\pm$ 0.0023 $\\ast$        &        0.8094 $\\pm$ 0.0010 $\\ast$        &       0.7241 $\\pm$ 0.0012 $\\ast$        &       0.7024 $\\pm$ 0.0008 $\\ast$       &       0.8551 $\\pm$ 0.0003 $\\ast$       &       0.7974 $\\pm$ 0.0005 $\\ast$        &        0.7505 $\\pm$ 0.0006 $\\ast$        &       0.6329 $\\pm$ 0.0023 $\\ast$       \\\\\n",
      "         \\textbf{DKVMN} &       0.6446 $\\pm$ 0.0030 $\\ast$        &        0.8031 $\\pm$ 0.0008 $\\ast$        &       0.7194 $\\pm$ 0.0006 $\\ast$        &       0.7020 $\\pm$ 0.0004 $\\ast$       &       0.8545 $\\pm$ 0.0003 $\\ast$       &       0.7931 $\\pm$ 0.0008 $\\ast$        &        0.7507 $\\pm$ 0.0003 $\\ast$        &       0.6394 $\\pm$ 0.0016 $\\ast$       \\\\\n",
      "          \\textbf{DKT+} &       0.6517 $\\pm$ 0.0057 $\\ast$        &        0.8093 $\\pm$ 0.0004 $\\ast$        &       0.7241 $\\pm$ 0.0013 $\\ast$        &       0.7034 $\\pm$ 0.0005 $\\ast$       &       0.8551 $\\pm$ 0.0002 $\\ast$       &       0.7974 $\\pm$ 0.0006 $\\circ$       &        0.7509 $\\pm$ 0.0004 $\\ast$        &       0.6479 $\\pm$ 0.0023 $\\ast$       \\\\\n",
      "       \\textbf{DeepIRT} &       0.6483 $\\pm$ 0.0058 $\\ast$        &        0.8033 $\\pm$ 0.0007 $\\ast$        &       0.7191 $\\pm$ 0.0007 $\\ast$        &       0.7014 $\\pm$ 0.0006 $\\ast$       &       0.8542 $\\pm$ 0.0001 $\\ast$       &       0.7909 $\\pm$ 0.0030 $\\ast$        &        0.7507 $\\pm$ 0.0002 $\\ast$        &       0.6372 $\\pm$ 0.0008 $\\ast$       \\\\\n",
      "         \\textbf{DKT-F} &       0.6395 $\\pm$ 0.0009 $\\ast$        &        0.8090 $\\pm$ 0.0006 $\\ast$        &                   ---                   &       0.7070 $\\pm$ 0.0004 $\\ast$       &       0.8534 $\\pm$ 0.0006 $\\ast$       &       0.7867 $\\pm$ 0.0006 $\\ast$        &                   ---                    &       0.6371 $\\pm$ 0.0038 $\\ast$       \\\\\n",
      "           \\textbf{GKT} &       0.6639 $\\pm$ 0.0050 $\\ast$        &        0.8086 $\\pm$ 0.0008 $\\ast$        &       0.7158 $\\pm$ 0.0016 $\\ast$        &       0.6956 $\\pm$ 0.0103 $\\ast$       &       0.8553 $\\pm$ 0.0003 $\\ast$       &       0.7900 $\\pm$ 0.0011 $\\ast$        &        0.7496 $\\pm$ 0.0006 $\\ast$        &       0.6024 $\\pm$ 0.0228 $\\ast$       \\\\\n",
      "           \\textbf{KQN} &       0.6387 $\\pm$ 0.0031 $\\ast$        &        0.8023 $\\pm$ 0.0013 $\\ast$        &       0.7224 $\\pm$ 0.0014 $\\ast$        &       0.7018 $\\pm$ 0.0002 $\\ast$       &       0.8533 $\\pm$ 0.0004 $\\ast$       &       0.7981 $\\pm$ 0.0008 $\\circ$       &        0.7502 $\\pm$ 0.0002 $\\ast$        &       0.6433 $\\pm$ 0.0020 $\\ast$       \\\\\n",
      "          \\textbf{SAKT} &       0.6392 $\\pm$ 0.0039 $\\ast$        &        0.7959 $\\pm$ 0.0018 $\\ast$        &       0.7071 $\\pm$ 0.0016 $\\ast$        &       0.6870 $\\pm$ 0.0010 $\\ast$       &       0.8456 $\\pm$ 0.0006 $\\ast$       &       0.7877 $\\pm$ 0.0021 $\\ast$        &        0.7474 $\\pm$ 0.0001 $\\ast$        &       0.6399 $\\pm$ 0.0029 $\\ast$       \\\\\n",
      "         \\textbf{SKVMN} &       0.6606 $\\pm$ 0.0090 $\\ast$        &        0.7821 $\\pm$ 0.0032 $\\ast$        &       0.7160 $\\pm$ 0.0010 $\\ast$        &       0.6874 $\\pm$ 0.0010 $\\ast$       &       0.8408 $\\pm$ 0.0005 $\\ast$       &       0.7922 $\\pm$ 0.0010 $\\ast$        &        0.7457 $\\pm$ 0.0004 $\\ast$        &       0.6407 $\\pm$ 0.0029 $\\ast$       \\\\\n",
      "           \\textbf{AKT} &       0.6645 $\\pm$ 0.0035 $\\ast$        &        0.8125 $\\pm$ 0.0016 $\\ast$        &       0.7383 $\\pm$ 0.0020 $\\ast$        &       0.7317 $\\pm$ 0.0005 $\\ast$       & \\underline{0.8586} $\\pm$ 0.0005 $\\ast$ &  \\textbf{0.8023} $\\pm$ 0.0006 $\\circ$   &       0.7521 $\\pm$ 0.0005 $\\circ$        &       0.6492 $\\pm$ 0.0017 $\\ast$       \\\\\n",
      "          \\textbf{qDKT} &       0.6922 $\\pm$ 0.0005 $\\ast$        &        0.7262 $\\pm$ 0.0008 $\\ast$        &       0.6781 $\\pm$ 0.0034 $\\ast$        &       0.7305 $\\pm$ 0.0003 $\\ast$       &       0.8302 $\\pm$ 0.0007 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "         \\textbf{SAINT} &       0.6511 $\\pm$ 0.0039 $\\ast$        &        0.7789 $\\pm$ 0.0030 $\\ast$        &       0.6885 $\\pm$ 0.0044 $\\ast$        &       0.7172 $\\pm$ 0.0025 $\\ast$       &      0.8374 $\\pm$ 0.0108 $\\circ$       &       0.7630 $\\pm$ 0.0139 $\\ast$        &        0.7451 $\\pm$ 0.0008 $\\ast$        &       0.6474 $\\pm$ 0.0005 $\\ast$       \\\\\n",
      "          \\textbf{ATKT} &       0.6364 $\\pm$ 0.0015 $\\ast$        &        0.7988 $\\pm$ 0.0008 $\\ast$        &       0.7201 $\\pm$ 0.0009 $\\ast$        &       0.7007 $\\pm$ 0.0006 $\\ast$       &       0.8507 $\\pm$ 0.0003 $\\ast$       &       0.7905 $\\pm$ 0.0016 $\\ast$        &        0.7490 $\\pm$ 0.0003 $\\ast$        &       0.6364 $\\pm$ 0.0032 $\\ast$       \\\\\n",
      "      \\textbf{HawkesKT} &       0.6905 $\\pm$ 0.0025 $\\ast$        &        0.8112 $\\pm$ 0.0012 $\\ast$        &       0.7045 $\\pm$ 0.0008 $\\ast$        &       0.7102 $\\pm$ 0.0013 $\\ast$       &       0.8559 $\\pm$ 0.0005 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "          \\textbf{IEKT} &       0.7106 $\\pm$ 0.0018 $\\ast$        &        0.8228 $\\pm$ 0.0008 $\\ast$        &       0.7336 $\\pm$ 0.0027 $\\ast$        &       0.7327 $\\pm$ 0.0001 $\\ast$       &       0.8556 $\\pm$ 0.0009 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "          \\textbf{LPKT} &       0.7128 $\\pm$ 0.0004 $\\ast$        &        0.8129 $\\pm$ 0.0008 $\\ast$        &       0.7356 $\\pm$ 0.0011 $\\ast$        &       0.7179 $\\pm$ 0.0033 $\\ast$       &       0.8538 $\\pm$ 0.0002 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "         \\textbf{DIMKT} &       0.6700 $\\pm$ 0.0038 $\\ast$        &        0.8106 $\\pm$ 0.0004 $\\ast$        &       0.7354 $\\pm$ 0.0019 $\\ast$        &       0.7309 $\\pm$ 0.0005 $\\ast$       &       0.8578 $\\pm$ 0.0004 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "        \\textbf{AT-DKT} &       0.6474 $\\pm$ 0.0066 $\\ast$        &        0.8130 $\\pm$ 0.0009 $\\ast$        &       0.7246 $\\pm$ 0.0016 $\\ast$        &       0.7146 $\\pm$ 0.0006 $\\ast$       &       0.8553 $\\pm$ 0.0004 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "  \\textbf{DTransformer} &       0.6656 $\\pm$ 0.0032 $\\ast$        &        0.8054 $\\pm$ 0.0007 $\\ast$        &       0.7284 $\\pm$ 0.0007 $\\ast$        &       0.7290 $\\pm$ 0.0012 $\\ast$       &       0.8556 $\\pm$ 0.0006 $\\ast$       &       0.7988 $\\pm$ 0.0021 $\\circ$       &       0.7511 $\\pm$ 0.0006 $\\circ$        &       0.6509 $\\pm$ 0.0004 $\\ast$       \\\\\n",
      "      \\textbf{FoLiBiKT} &       0.6666 $\\pm$ 0.0028 $\\ast$        &        0.8127 $\\pm$ 0.0012 $\\ast$        &       0.7391 $\\pm$ 0.0013 $\\ast$        &       0.7319 $\\pm$ 0.0005 $\\ast$       &       0.8583 $\\pm$ 0.0006 $\\ast$       & \\underline{0.8019} $\\pm$ 0.0005 $\\circ$ &   \\textbf{0.7526} $\\pm$ 0.0002 $\\circ$   &      0.6507 $\\pm$ 0.0033 $\\circ$       \\\\\n",
      "          \\textbf{QIKT} &       0.7077 $\\pm$ 0.0014 $\\ast$        &        0.8220 $\\pm$ 0.0007 $\\ast$        &       0.7382 $\\pm$ 0.0008 $\\ast$        &       0.7326 $\\pm$ 0.0008 $\\ast$       &       0.8537 $\\pm$ 0.0005 $\\ast$       &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "      \\textbf{simpleKT} &       0.6565 $\\pm$ 0.0029 $\\ast$        &        0.8081 $\\pm$ 0.0010 $\\ast$        &       0.7319 $\\pm$ 0.0019 $\\ast$        & \\underline{0.7327} $\\pm$ 0.0003 $\\ast$ &       0.8579 $\\pm$ 0.0002 $\\ast$       &       0.7947 $\\pm$ 0.0026 $\\ast$        &        0.7505 $\\pm$ 0.0005 $\\ast$        & \\underline{0.6516} $\\pm$ 0.0009 $\\ast$ \\\\\n",
      "   \\textbf{KTST (mean)} &  \\textbf{0.7154} $\\pm$ 0.0011 $\\; \\: $  & \\underline{0.8287} $\\pm$ 0.0005 $\\; \\: $ &  \\textbf{0.7490} $\\pm$ 0.0013 $\\; \\: $  & \\textbf{0.7356} $\\pm$ 0.0003 $\\; \\: $  & \\textbf{0.8608} $\\pm$ 0.0005 $\\; \\: $  &      0.8002 $\\pm$ 0.0014 $\\; \\: $       & \\underline{0.7523} $\\pm$ 0.0002 $\\; \\: $ & \\textbf{0.6568} $\\pm$ 0.0008 $\\; \\: $  \\\\\n",
      " \\textbf{KTST (unique)} &       0.7131 $\\pm$ 0.0017 $\\circ$       &   \\textbf{0.8291} $\\pm$ 0.0008 $\\circ$   & \\underline{0.7489} $\\pm$ 0.0011 $\\circ$ &                  ---                   &                  ---                   &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "   \\textbf{KTST (MHSA)} & \\underline{0.7152} $\\pm$ 0.0011 $\\circ$ &        0.8166 $\\pm$ 0.0012 $\\ast$        &       0.7415 $\\pm$ 0.0014 $\\ast$        &                  ---                   &                  ---                   &                   ---                   &                   ---                    &                  ---                   \\\\\n",
      "\\hline\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "print_latex(df_acc, reduced=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "kt_transformer",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
