{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32m2024-09-17 16:09:34.461\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabscratch/foundation-default-tabzilla_has_completed_runs-zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.467\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabscratch/foundation-default-tabzilla_has_completed_runs-finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.473\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.478\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.484\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.490\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.496\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforest/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.503\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforest/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.509\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.515\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32m2024-09-17 16:09:34.521\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.526\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.532\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.538\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.544\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/foundation_flash/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.550\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/foundation_flash/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.556\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/foundation_flash_big/test_tabzilla_has_completed_runs_zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.562\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/foundation_flash_big/test_tabzilla_has_completed_runs_finetune/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.568\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/attic_lr1e-5/tab2d-default-tabzilla_has_completed_runs-zeroshot/results_sweep.nc\u001b[0m\n",
      "\u001b[32m2024-09-17 16:09:34.574\u001b[0m | \u001b[1mINFO    \u001b[0m | \u001b[36mtabicl.results.results_sweep\u001b[0m:\u001b[36mload\u001b[0m:\u001b[36m44\u001b[0m - \u001b[1mLoaded results from outputs/saved_tab2d/attic_lr1e-5/tab2d-default-tabzilla_has_completed_runs-finetune/results_sweep.nc\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "from pathlib import Path\n",
    "import xarray as xr\n",
    "from tabicl.core.enums import BenchmarkOrigin\n",
    "from tabicl.results.dataset_manipulations import add_model_plot_names, average_out_the_cv_split, create_normalized_score, only_use_models_and_datasets_specified_in_cfg, select_only_the_first_default_run_of_every_model_and_dataset, take_run_with_best_validation_loss\n",
    "from tabicl.results.merge_ds_bench_tabzilla_and_sweeps import merge_ds_bench_tabzilla_and_sweeps\n",
    "from tabicl.results.normalize_scores import create_normalization_info\n",
    "from tabicl.results.ranking_table import make_ranking_table_, process_benchmark_results, process_sweep_results\n",
    "from tabicl.results.reformat_results_get import get_reformatted_results\n",
    "from tabicl.results.results_sweep import ResultsSweep\n",
    "from tabicl.config.config_benchmark_sweep import ConfigBenchmarkSweep\n",
    "\n",
    "cfg_general = ConfigBenchmarkSweep.load(Path(\"outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_finetune/config_benchmark_sweep.yaml\"))\n",
    "\n",
    "def prepare_ds(txt: str, path: Path):\n",
    "    results_sweep = ResultsSweep.load(path / \"results_sweep.nc\")\n",
    "    ds = results_sweep.ds\n",
    "    ds.attrs['model_plot_name'] = txt\n",
    "    return ds\n",
    "\n",
    "\n",
    "dss = [\n",
    "    prepare_ds(\"TabPFN - Zero-shot\", Path(\"outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-zeroshot\")),\n",
    "    prepare_ds(\"TabPFN - Fine-tuned\", Path(\"outputs/saved/tabpfn_original/tabpfn-default-tabzilla_has_completed_runs-finetune\")),\n",
    "    prepare_ds(\"TabForestPFN - Zero-shot\", Path(\"outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_zeroshot\")),\n",
    "    prepare_ds(\"TabForestPFN - Fine-tuned\", Path(\"outputs/saved/tabforestpfn/test_tabzilla_has_completed_runs_finetune\")),\n",
    "    prepare_ds(\"TabForestPFN BF16-M - Zero-shot\", Path(\"outputs/saved_tab2d/foundation_flash/test_tabzilla_has_completed_runs_zeroshot\")),\n",
    "    prepare_ds(\"TabForestPFN BF16-M - Fine-tuned\", Path(\"outputs/saved_tab2d/foundation_flash/test_tabzilla_has_completed_runs_finetune\")),\n",
    "    prepare_ds(\"TabForestPFN BF16-L - Zero-shot\", Path(\"outputs/saved_tab2d/foundation_flash_big/test_tabzilla_has_completed_runs_zeroshot\")),\n",
    "    prepare_ds(\"TabForestPFN BF16-L - Fine-tuned\", Path(\"outputs/saved_tab2d/foundation_flash_big/test_tabzilla_has_completed_runs_finetune\")),\n",
    "    prepare_ds(\"Attic - Zero-shot\", Path(\"outputs/saved_tab2d/attic_lr1e-5/tab2d-default-tabzilla_has_completed_runs-zeroshot\")),\n",
    "    prepare_ds(\"Attic - Fine-tuned\", Path(\"outputs/saved_tab2d/attic_lr1e-5/tab2d-default-tabzilla_has_completed_runs-finetune\")),\n",
    "]\n",
    "\n",
    "\n",
    "ds = merge_ds_bench_tabzilla_and_sweeps(cfg_general, dss)\n",
    "df = make_ranking_table_(cfg_general, ds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & rank_min & rank_max & rank_mean & rank_median & acc_mean & acc_median \\\\\n",
      "\\midrule\n",
      "Attic - Fine-tuned & 1 & 28 & 6.4 & 4.0 & 0.882 & 0.961 \\\\\n",
      "Attic - Zero-shot & 1 & 26 & 8.8 & 6.2 & 0.834 & 0.922 \\\\\n",
      "TabForestPFN - Fine-tuned & 1 & 28 & 9.2 & 7.0 & 0.829 & 0.886 \\\\\n",
      "CatBoost & 1 & 24 & 10.4 & 10.0 & 0.832 & 0.861 \\\\\n",
      "TabForestPFN - Zero-shot & 1 & 25 & 10.4 & 10.0 & 0.809 & 0.880 \\\\\n",
      "TabPFN - Fine-tuned & 1 & 27 & 10.5 & 10.5 & 0.823 & 0.875 \\\\\n",
      "XGBoost & 1 & 25 & 10.7 & 11.0 & 0.826 & 0.877 \\\\\n",
      "TabForestPFN BF16-L - Fine-tuned & 1 & 27 & 12.2 & 11.0 & 0.785 & 0.868 \\\\\n",
      "TabForestPFN BF16-M - Fine-tuned & 1 & 26 & 12.5 & 12.2 & 0.784 & 0.850 \\\\\n",
      "LightGBM & 2 & 28 & 12.5 & 12.2 & 0.777 & 0.860 \\\\\n",
      "TabForestPFN BF16-L - Zero-shot & 1 & 26 & 12.8 & 12.2 & 0.770 & 0.852 \\\\\n",
      "RandomForest & 1 & 27 & 12.9 & 12.5 & 0.782 & 0.835 \\\\\n",
      "TabPFN - Zero-shot & 1 & 27 & 13.0 & 13.0 & 0.767 & 0.830 \\\\\n",
      "Resnet & 1 & 28 & 13.5 & 13.0 & 0.719 & 0.834 \\\\\n",
      "SAINT & 1 & 28 & 13.8 & 14.0 & 0.721 & 0.795 \\\\\n",
      "NODE & 2 & 28 & 13.8 & 14.5 & 0.741 & 0.817 \\\\\n",
      "SVM & 1 & 27 & 14.1 & 14.5 & 0.701 & 0.798 \\\\\n",
      "FT-Transformer & 1 & 25 & 14.4 & 15.0 & 0.724 & 0.794 \\\\\n",
      "DANet & 3 & 28 & 16.4 & 16.0 & 0.708 & 0.757 \\\\\n",
      "TabForestPFN BF16-M - Zero-shot & 1 & 27 & 17.1 & 17.0 & 0.708 & 0.795 \\\\\n",
      "MLP-rtdl & 1 & 28 & 17.8 & 19.8 & 0.613 & 0.723 \\\\\n",
      "STG & 2 & 28 & 18.0 & 19.8 & 0.585 & 0.672 \\\\\n",
      "LinearRegression & 1 & 28 & 19.4 & 22.0 & 0.559 & 0.590 \\\\\n",
      "MLP & 2 & 28 & 19.6 & 22.0 & 0.563 & 0.582 \\\\\n",
      "TabNet & 3 & 28 & 19.9 & 21.0 & 0.571 & 0.661 \\\\\n",
      "DecisionTree & 1 & 28 & 20.6 & 22.0 & 0.496 & 0.551 \\\\\n",
      "KNN & 2 & 28 & 21.4 & 24.0 & 0.467 & 0.478 \\\\\n",
      "VIME & 2 & 28 & 23.7 & 26.0 & 0.337 & 0.238 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df[['rank_min', 'rank_max']] = df[['rank_min', 'rank_max']].astype(int)\n",
    "# df['rank_mean'] = df['rank_mean'].apply(lambda x: f\"{x:.1f}\")\n",
    "# df[['acc_mean', 'acc_median']] = df[['acc_mean', 'acc_median']].apply(lambda x: f\"{x:.3f}\")\n",
    "\n",
    "format_mapping = {\n",
    "    'acc_mean': '{:.3f}',\n",
    "    'acc_median': '{:.3f}',\n",
    "    'rank_mean': '{:.1f}',\n",
    "    'rank_median': '{:.1f}',\n",
    "}\n",
    "\n",
    "\n",
    "print(df.to_latex(formatters=format_mapping))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                  rank_min  rank_max  rank_mean  rank_median  \\\n",
      "TabPFN - Zero-shot                     1.0      19.0        7.7          7.0   \n",
      "TabPFN - Fine-tuned                    1.0      18.0        6.4          6.5   \n",
      "TabForestPFN - Zero-shot               1.0      18.0        6.3          6.0   \n",
      "TabForestPFN - Fine-tuned              1.0      19.0        5.6          4.5   \n",
      "TabForestPFN BF16-M - Zero-shot        1.0      18.0       10.0         10.0   \n",
      "TabForestPFN BF16-M - Fine-tuned       1.0      18.0        7.4          7.0   \n",
      "TabForestPFN BF16-L - Zero-shot        1.0      18.0        7.7          7.0   \n",
      "TabForestPFN BF16-L - Fine-tuned       1.0      18.0        7.3          6.0   \n",
      "Attic - Zero-shot                      1.0      17.0        5.4          4.0   \n",
      "Attic - Fine-tuned                     1.0      19.0        4.0          2.0   \n",
      "\n",
      "                                  acc_mean  acc_median  \n",
      "TabPFN - Zero-shot                   0.780       0.841  \n",
      "TabPFN - Fine-tuned                  0.838       0.909  \n",
      "TabForestPFN - Zero-shot             0.824       0.900  \n",
      "TabForestPFN - Fine-tuned            0.846       0.910  \n",
      "TabForestPFN BF16-M - Zero-shot      0.721       0.795  \n",
      "TabForestPFN BF16-M - Fine-tuned     0.799       0.870  \n",
      "TabForestPFN BF16-L - Zero-shot      0.784       0.868  \n",
      "TabForestPFN BF16-L - Fine-tuned     0.801       0.887  \n",
      "Attic - Zero-shot                    0.847       0.925  \n",
      "Attic - Fine-tuned                   0.886       0.962  \n",
      "\n",
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & rank_min & rank_max & rank_mean & rank_median & acc_mean & acc_median \\\\\n",
      "\\midrule\n",
      "TabPFN - Zero-shot & 1 & 19 & 7.7 & 7.0 & 0.780 & 0.841 \\\\\n",
      "TabPFN - Fine-tuned & 1 & 18 & 6.4 & 6.5 & 0.838 & 0.909 \\\\\n",
      "TabForestPFN - Zero-shot & 1 & 18 & 6.3 & 6.0 & 0.824 & 0.900 \\\\\n",
      "TabForestPFN - Fine-tuned & 1 & 19 & 5.6 & 4.5 & 0.846 & 0.910 \\\\\n",
      "TabForestPFN BF16-M - Zero-shot & 1 & 18 & 10.0 & 10.0 & 0.721 & 0.795 \\\\\n",
      "TabForestPFN BF16-M - Fine-tuned & 1 & 18 & 7.4 & 7.0 & 0.799 & 0.870 \\\\\n",
      "TabForestPFN BF16-L - Zero-shot & 1 & 18 & 7.7 & 7.0 & 0.784 & 0.868 \\\\\n",
      "TabForestPFN BF16-L - Fine-tuned & 1 & 18 & 7.3 & 6.0 & 0.801 & 0.887 \\\\\n",
      "Attic - Zero-shot & 1 & 17 & 5.4 & 4.0 & 0.847 & 0.925 \\\\\n",
      "Attic - Fine-tuned & 1 & 19 & 4.0 & 2.0 & 0.886 & 0.962 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "individual_performance = []\n",
    "\n",
    "for ds in dss:\n",
    "\n",
    "    ds_merged = merge_ds_bench_tabzilla_and_sweeps(cfg_general, [ds])\n",
    "    df = make_ranking_table_(cfg_general, ds_merged)\n",
    "    my_model = df.filter(regex='Zero-shot|Fine-tune', axis=0)\n",
    "    individual_performance.append(my_model)\n",
    "\n",
    "\n",
    "df_indiv = pd.concat(individual_performance)\n",
    "print(df_indiv)\n",
    "print(\"\")\n",
    "df_indiv[['rank_min', 'rank_max']] = df_indiv[['rank_min', 'rank_max']].astype(int)\n",
    "print(df_indiv.to_latex(formatters=format_mapping))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                    rank_min  rank_max  rank_mean  rank_median  acc_mean  \\\n",
      "Attic - Fine-tuned       1.0      19.0        4.0         2.00     0.886   \n",
      "CatBoost                 1.0      15.0        6.3         5.00     0.836   \n",
      "XGBoost                  1.0      16.0        6.5         5.75     0.830   \n",
      "LightGBM                 2.0      19.0        7.9         6.75     0.781   \n",
      "RandomForest             1.0      18.0        8.0         8.00     0.786   \n",
      "NODE                     1.0      19.0        8.5         8.00     0.744   \n",
      "Resnet                   1.0      19.0        8.5         8.00     0.722   \n",
      "SAINT                    1.0      19.0        8.6         8.00     0.724   \n",
      "SVM                      1.0      18.5        8.7         8.00     0.704   \n",
      "FT-Transformer           1.0      16.0        9.0         8.50     0.729   \n",
      "DANet                    2.0      19.0       10.1        10.00     0.712   \n",
      "STG                      2.0      19.0       11.6        12.50     0.587   \n",
      "MLP-rtdl                 1.0      19.0       11.6        12.00     0.616   \n",
      "LinearRegression         1.0      19.0       12.4        14.00     0.562   \n",
      "MLP                      1.0      19.0       12.6        14.00     0.566   \n",
      "TabNet                   2.0      19.0       12.8        13.75     0.575   \n",
      "DecisionTree             1.0      19.0       13.3        14.00     0.500   \n",
      "KNN                      2.5      19.0       13.9        15.00     0.471   \n",
      "VIME                     1.0      19.0       15.8        17.00     0.341   \n",
      "\n",
      "                    acc_median  \n",
      "Attic - Fine-tuned       0.962  \n",
      "CatBoost                 0.863  \n",
      "XGBoost                  0.882  \n",
      "LightGBM                 0.860  \n",
      "RandomForest             0.837  \n",
      "NODE                     0.824  \n",
      "Resnet                   0.836  \n",
      "SAINT                    0.802  \n",
      "SVM                      0.799  \n",
      "FT-Transformer           0.796  \n",
      "DANet                    0.758  \n",
      "STG                      0.672  \n",
      "MLP-rtdl                 0.725  \n",
      "LinearRegression         0.592  \n",
      "MLP                      0.583  \n",
      "TabNet                   0.666  \n",
      "DecisionTree             0.551  \n",
      "KNN                      0.478  \n",
      "VIME                     0.240  \n",
      "\n",
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & rank_min & rank_max & rank_mean & rank_median & acc_mean & acc_median \\\\\n",
      "\\midrule\n",
      "Attic - Fine-tuned & 1 & 19 & 4.0 & 2.0 & 0.886 & 0.962 \\\\\n",
      "CatBoost & 1 & 15 & 6.3 & 5.0 & 0.836 & 0.863 \\\\\n",
      "XGBoost & 1 & 16 & 6.5 & 5.8 & 0.830 & 0.882 \\\\\n",
      "LightGBM & 2 & 19 & 7.9 & 6.8 & 0.781 & 0.860 \\\\\n",
      "RandomForest & 1 & 18 & 8.0 & 8.0 & 0.786 & 0.837 \\\\\n",
      "NODE & 1 & 19 & 8.5 & 8.0 & 0.744 & 0.824 \\\\\n",
      "Resnet & 1 & 19 & 8.5 & 8.0 & 0.722 & 0.836 \\\\\n",
      "SAINT & 1 & 19 & 8.6 & 8.0 & 0.724 & 0.802 \\\\\n",
      "SVM & 1 & 18 & 8.7 & 8.0 & 0.704 & 0.799 \\\\\n",
      "FT-Transformer & 1 & 16 & 9.0 & 8.5 & 0.729 & 0.796 \\\\\n",
      "DANet & 2 & 19 & 10.1 & 10.0 & 0.712 & 0.758 \\\\\n",
      "STG & 2 & 19 & 11.6 & 12.5 & 0.587 & 0.672 \\\\\n",
      "MLP-rtdl & 1 & 19 & 11.6 & 12.0 & 0.616 & 0.725 \\\\\n",
      "LinearRegression & 1 & 19 & 12.4 & 14.0 & 0.562 & 0.592 \\\\\n",
      "MLP & 1 & 19 & 12.6 & 14.0 & 0.566 & 0.583 \\\\\n",
      "TabNet & 2 & 19 & 12.8 & 13.8 & 0.575 & 0.666 \\\\\n",
      "DecisionTree & 1 & 19 & 13.3 & 14.0 & 0.500 & 0.551 \\\\\n",
      "KNN & 2 & 19 & 13.9 & 15.0 & 0.471 & 0.478 \\\\\n",
      "VIME & 1 & 19 & 15.8 & 17.0 & 0.341 & 0.240 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(df)\n",
    "print(\"\")\n",
    "df[['rank_min', 'rank_max']] = df[['rank_min', 'rank_max']].astype(int)\n",
    "print(df.to_latex(formatters=format_mapping))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tab",
   "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
}
