{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b14c13d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d0d8c6c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "datalist = [\n",
    "    22, 54, 1063, 1067, 12, 18, 23, 59, 188, 307, 1043, 1459, 1475, 1489, 1492, 1497, 1503, 4153, 40499, 44125,\n",
    "    44131, 45062, 44157, 1462, 44160, 29, 37, 53, 49, 1504, 1494, 41143, 44126, 40981, 41168, 44091, 44158, 44123, 44090,\n",
    "    40922, 44161, 45714]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b7554af3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'22 54 1063 1067 12 18 23 59 188 307 1043 1459 1475 1489 1492 1497 1503 4153 40499 44125 44131 45062 44157 1462 44160 29 37 53 49 1504 1494 41143 44126 40981 41168 44091 44158 44123 44090 40922 44161 45714'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\" \".join(map(str, datalist))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ca28b0f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "models = [\"lr\", \"knn\", \"xgboost\", \"catboost\", \"lightgbm\", \"mlp\", \n",
    "          \"ae\", \"ict\", \"meanteacher\", \"sslrecon\", \"sslbinning\", \"sslsubtab\", \n",
    "          \"sslvime\", \"semivime\", \"sslscarf\", \"sslbinshuffling\", \"sslbinsampling\",\n",
    "          \"sslmasking\", \"sslshuffling\", \"sslnoisemasking\", \"sslrq\",\n",
    "          \"pseudolabel-masking\", \"pseudolabel-shuffling\", \"pseudolabel-noisemasking\", \n",
    "          \"pseudolabel-rq\", \"pseudolabel-sampling\", \"pseudolabel-cutmix\",\n",
    "          \"stunt\", \"tabpfn\", \"sslsaint\", \"hyperfast\"]\n",
    "len(models)\n",
    "\n",
    "clist = []\n",
    "for m in models:\n",
    "    if m.startswith(\"ssl\"):\n",
    "        clist.append(f'{m}-lr')\n",
    "        clist.append(f'{m}-knn')\n",
    "        clist.append(f'{m}-lineareval')\n",
    "        clist.append(f'{m}-finetuning')\n",
    "    else:\n",
    "        clist.append(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "66ae86ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "result = pd.read_csv(\"result.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a70af1ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "# def get_results(seed):\n",
    "#     try:\n",
    "#         result = pd.read_csv(f'/home/SemiTab/result-summary/result-{seed}.csv', index_col=0)\n",
    "#     except FileNotFoundError:\n",
    "#         result = pd.DataFrame(columns=(\"trial\", \"shots\", \"data_id\", \"model\", \"acc\", \"auroc\"))\n",
    "#     print(seed, result.shape)\n",
    "#     i = len(result)\n",
    "#     if i < 5040:\n",
    "#         for shot in [1, 5]:\n",
    "#             for model in models: #[\"lightgbm\"]: #models:\n",
    "#                 print(seed, shot, model, end=\": \")\n",
    "#                 for d in datalist:\n",
    "#                     go = True\n",
    "#                     if model.startswith(\"ssl\"):\n",
    "#                         if len(result[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == f'{model}-lr')]) > 0:\n",
    "#                             go = False\n",
    "#                     elif len(result[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == f'{model}')]) > 0:\n",
    "#                         go = False\n",
    "\n",
    "#                     if go:\n",
    "#                         fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "#                         try:\n",
    "#                             perf = np.load(fname, allow_pickle=True).item()\n",
    "#                             if model.startswith(\"ssl\"):\n",
    "#                                 for e in [\"lr\", \"knn\", \"lineareval\", \"finetuning\"]:\n",
    "#                                     result.loc[i] = [seed, shot, d, f'{model}-{e}', perf[\"Test\"][e][0], perf[\"Test\"][e][1]]\n",
    "#                                     i += 1\n",
    "#                             elif model == \"stunt\":\n",
    "#                                 result.loc[i] = [seed, shot, d, model, perf[\"Test\"], np.nan]; i += 1\n",
    "#                             else:\n",
    "#                                 result.loc[i] = [seed, shot, d, model, perf[\"Test\"][0], perf[\"Test\"][1]]; i += 1\n",
    "#                         except FileNotFoundError:\n",
    "#                             print(d, end=\" \")\n",
    "#                             pass\n",
    "#                 print(\" \")\n",
    "#         print(result.shape)\n",
    "#         result.to_csv(f'/home/SemiTab/result-summary/result-{seed}.csv')\n",
    "\n",
    "#     return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6b4e44b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# \" \".join(map(str, datalist))\n",
    "# # \" \".join(map(str, models))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "21d1c689",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for seed in [97]:\n",
    "#     get_results(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "17b7473a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# from random import shuffle\n",
    "# datalist = [\n",
    "#     22, 54, 1063, 1067, 12, 18, 23, 59, 188, 307, 1043, 1459, 1475, 1489, 1492, 1497, 1503, 4153, 40499, 44125,\n",
    "#     44131, 45062, 44157, 1462, 44160, 29, 37, 53, 49, 1504, 1494, 41143, 44126, 40981, 41168, 44091, 44158, 44123, 44090,\n",
    "#     40922, 44161, 45714]\n",
    "# shuffle(datalist)\n",
    "# \" \".join(map(str, datalist))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "dff3efa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# result = pd.DataFrame(columns=(\"trial\", \"shots\", \"data_id\", \"model\", \"acc\", \"auroc\"))\n",
    "# for seed in range(100):\n",
    "#     p = pd.read_csv(f'/home/SemiTab/result-summary/result-{seed}.csv', index_col=0)\n",
    "#     result = pd.concat([result, p], axis=0)\n",
    "# result.to_csv(\"/home/SemiTab/result-summary/result.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9279371",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9ba182bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def UpdateResults(model, seeds, shot, d):\n",
    "    result = pd.read_csv(\"/home/SemiTab/result-summary/result.csv\", index_col=0)\n",
    "    for seed in seeds:\n",
    "#         print(seed, end=\" \")\n",
    "        fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "        try:\n",
    "            perf = np.load(fname, allow_pickle=True).item()\n",
    "            if model.startswith(\"ssl\"):\n",
    "                for e in [\"lr\", \"knn\", \"lineareval\", \"finetuning\"]:\n",
    "                    result.loc[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == f'{model}-{e}'), \"acc\"] = perf[\"Test\"][e][0]\n",
    "                    i += 1\n",
    "            else:\n",
    "                result.loc[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == model), \"acc\"] = perf[\"Test\"][0]\n",
    "                i += 1\n",
    "        except Exception:\n",
    "#             print(\"###\", d, shot)\n",
    "            pass\n",
    "    result.to_csv(\"/home/SemiTab/result-summary/result.csv\")\n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6c4cb928",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5628"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(datalist)*len(clist)*2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "79236c66",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_results(seed):\n",
    "    try:\n",
    "        result = pd.read_csv(f'/home/SemiTab/result-summary/result-{seed}.csv', index_col=0)\n",
    "    except FileNotFoundError:\n",
    "        result = pd.DataFrame(columns=(\"trial\", \"shots\", \"data_id\", \"model\", \"acc\", \"auroc\"))\n",
    "    print(seed, result.shape)\n",
    "    i = len(result)\n",
    "    if i < 42*len(clist)*2:\n",
    "        for shot in [1, 5]:\n",
    "            for model in [\"sslsaint\", \"pseudolabel-cutmix\", \"hyperfast\"]: #, \"hyperfast\"]: #models: #[\"lightgbm\"]: #models:\n",
    "                print(seed, shot, model, end=\": \")\n",
    "                for d in datalist:\n",
    "                    go = True\n",
    "                    if model.startswith(\"ssl\"):\n",
    "                        if len(result[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == f'{model}-lr')]) > 0:\n",
    "                            go = False\n",
    "                    elif len(result[(result[\"trial\"] == seed) & (result[\"shots\"] == shot) & (result[\"data_id\"] == d) & (result[\"model\"] == f'{model}')]) > 0:\n",
    "                        go = False\n",
    "\n",
    "                    if go:\n",
    "                        fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                        try:\n",
    "                            perf = np.load(fname, allow_pickle=True).item()\n",
    "                            if model.startswith(\"ssl\"):\n",
    "                                for e in [\"lr\", \"knn\", \"lineareval\", \"finetuning\"]:\n",
    "                                    result.loc[i] = [seed, shot, d, f'{model}-{e}', perf[\"Test\"][e][0], perf[\"Test\"][e][1]]\n",
    "                                    i += 1\n",
    "                            elif model == \"stunt\":\n",
    "                                result.loc[i] = [seed, shot, d, model, perf[\"Test\"], np.nan]; i += 1\n",
    "                            else:\n",
    "                                result.loc[i] = [seed, shot, d, model, perf[\"Test\"][0], perf[\"Test\"][1]]; i += 1\n",
    "                        except FileNotFoundError:\n",
    "                            if (model == \"hyperfast\") & (d == 1492):\n",
    "                                result.loc[i] = [seed, shot, d, model, 0., np.nan]; i += 1\n",
    "                            else:\n",
    "                                print(d, end=\" \")\n",
    "                            pass\n",
    "                print(\" \")\n",
    "        print(result.shape)\n",
    "        result.to_csv(f'/home/SemiTab/result-summary/result-{seed}.csv')\n",
    "\n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "160573ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=== 50 ===\n",
      "50 (5578, 6)\n",
      "50 1 sslsaint: 1503 44131 41168 40922 44161  \n",
      "50 1 pseudolabel-cutmix:  \n",
      "50 1 hyperfast:  \n",
      "50 5 sslsaint: 1503 44131 41168 40922 44161  \n",
      "50 5 pseudolabel-cutmix:  \n",
      "50 5 hyperfast:  \n",
      "(5588, 6)\n",
      "=== 51 ===\n",
      "51 (5570, 6)\n",
      "51 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "51 1 pseudolabel-cutmix:  \n",
      "51 1 hyperfast:  \n",
      "51 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "51 5 pseudolabel-cutmix:  \n",
      "51 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 52 ===\n",
      "52 (5570, 6)\n",
      "52 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "52 1 pseudolabel-cutmix:  \n",
      "52 1 hyperfast:  \n",
      "52 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "52 5 pseudolabel-cutmix:  \n",
      "52 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 53 ===\n",
      "53 (5568, 6)\n",
      "53 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "53 1 pseudolabel-cutmix:  \n",
      "53 1 hyperfast:  \n",
      "53 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "53 5 pseudolabel-cutmix:  \n",
      "53 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 54 ===\n",
      "54 (5534, 6)\n",
      "54 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "54 1 pseudolabel-cutmix:  \n",
      "54 1 hyperfast:  \n",
      "54 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "54 5 pseudolabel-cutmix:  \n",
      "54 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 55 ===\n",
      "55 (5500, 6)\n",
      "55 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "55 1 pseudolabel-cutmix:  \n",
      "55 1 hyperfast:  \n",
      "55 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "55 5 pseudolabel-cutmix:  \n",
      "55 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 56 ===\n",
      "56 (5500, 6)\n",
      "56 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "56 1 pseudolabel-cutmix:  \n",
      "56 1 hyperfast:  \n",
      "56 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "56 5 pseudolabel-cutmix:  \n",
      "56 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 57 ===\n",
      "57 (5500, 6)\n",
      "57 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "57 1 pseudolabel-cutmix:  \n",
      "57 1 hyperfast:  \n",
      "57 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "57 5 pseudolabel-cutmix:  \n",
      "57 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 58 ===\n",
      "58 (5500, 6)\n",
      "58 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "58 1 pseudolabel-cutmix:  \n",
      "58 1 hyperfast:  \n",
      "58 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "58 5 pseudolabel-cutmix:  \n",
      "58 5 hyperfast:  \n",
      "(5580, 6)\n",
      "=== 59 ===\n",
      "59 (5500, 6)\n",
      "59 1 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "59 1 pseudolabel-cutmix:  \n",
      "59 1 hyperfast:  \n",
      "59 5 sslsaint: 1503 40499 44131 41168 40922 44161  \n",
      "59 5 pseudolabel-cutmix:  \n",
      "59 5 hyperfast:  \n",
      "(5580, 6)\n"
     ]
    }
   ],
   "source": [
    "for seed in range(50, 60):\n",
    "    print(\"===\", seed, \"===\")\n",
    "    get_results(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "78a19186",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "21ba6f4f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for d in [22, 59, 307, 4153, 41143, 44090, 44091, 44125, 44160, 44161]:\n",
    "    result = UpdateResults(\"sslbinshuffling\", range(50), 1, d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "20731a3a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tabpfn 0.62182\n",
      "sslbinshuffling-lr 0.61370\n"
     ]
    }
   ],
   "source": [
    "q = result[result[\"trial\"] < 50]\n",
    "#62182 // 6201\n",
    "excl = [12, 307, 1492, 40499, 41143, 41168]# , 45714, 53, 40981, 188]#, 45714, 53, 40981, 188] #53, 188, 45714, 40981\n",
    "for c in [\"tabpfn\", \"sslbinshuffling-lr\"]:\n",
    "    dt = q[(q[\"shots\"] == 5) & (q[\"model\"] == c) & (~q[\"data_id\"].isin(excl))]\n",
    "    print(c, \"%.5f\" %dt[\"acc\"].mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0c90bcc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "530621a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7284caba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b85b6b16",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "f3fb76b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = pd.read_csv(\"/home/SemiTab/result-summary/result.csv\", index_col=0)\n",
    "for s in range(100):\n",
    "    b = pd.read_csv(f'/home/SemiTab/result-summary/result-{s}.csv', index_col=0)\n",
    "    b = b[b[\"model\"].isin([\"sslsaint-lr\", \"hyperfast\", \"pseudolabel-sampling\"])].reset_index(drop=True)\n",
    "    p = pd.concat([p, b], axis=0)\n",
    "p = p.reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "0851ca0d",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = p.drop_duplicates().reset_index(drop=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b218a294",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "e6adb32e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['lr', 'knn', 'xgboost', 'catboost', 'lightgbm', 'mlp', 'ae', 'ict',\n",
       "       'meanteacher', 'sslrecon-lr', 'sslrecon-knn',\n",
       "       'sslrecon-lineareval', 'sslrecon-finetuning', 'sslbinning-lr',\n",
       "       'sslbinning-knn', 'sslbinning-lineareval', 'sslbinning-finetuning',\n",
       "       'sslsubtab-lr', 'sslsubtab-knn', 'sslsubtab-lineareval',\n",
       "       'sslsubtab-finetuning', 'sslvime-lr', 'sslvime-knn',\n",
       "       'sslvime-lineareval', 'sslvime-finetuning', 'semivime',\n",
       "       'sslscarf-lr', 'sslscarf-knn', 'sslscarf-lineareval',\n",
       "       'sslscarf-finetuning', 'sslbinshuffling-lr', 'sslbinshuffling-knn',\n",
       "       'sslbinshuffling-lineareval', 'sslbinshuffling-finetuning',\n",
       "       'sslbinsampling-lr', 'sslbinsampling-knn',\n",
       "       'sslbinsampling-lineareval', 'sslbinsampling-finetuning',\n",
       "       'sslmasking-lr', 'sslmasking-knn', 'sslmasking-lineareval',\n",
       "       'sslmasking-finetuning', 'sslshuffling-lr', 'sslshuffling-knn',\n",
       "       'sslshuffling-lineareval', 'sslshuffling-finetuning',\n",
       "       'sslnoisemasking-lr', 'sslnoisemasking-knn',\n",
       "       'sslnoisemasking-lineareval', 'sslnoisemasking-finetuning',\n",
       "       'sslrq-lr', 'sslrq-knn', 'sslrq-lineareval', 'sslrq-finetuning',\n",
       "       'pseudolabel-masking', 'pseudolabel-shuffling',\n",
       "       'pseudolabel-noisemasking', 'pseudolabel-rq', 'stunt', 'tabpfn',\n",
       "       'pseudolabel-sampling', 'sslsaint-lr'], dtype=object)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# b = pd.read_csv(f'/home/SemiTab/result-summary/result-0.csv', index_col=0)\n",
    "# b[b[\"model\"].isin([\"sslsaint-lr\", \"hyperfast\"])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "24ab91f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "clist = [c for c in clist if (not c.startswith(\"ssl\")) or (c.endswith(\"-lr\"))]\n",
    "p = p.groupby([\"data_id\", \"shots\", \"model\"]).agg(\n",
    "    acc_mean=('acc', 'mean'),\n",
    "    acc_count=('acc', lambda x: x.notna().sum())\n",
    ").reset_index()\n",
    "p = p[(p[\"model\"].isin(clist))].reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ff91b116",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "4659963f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "rankdata = copy.deepcopy(p)\n",
    "\n",
    "for shot in [1, 5]:\n",
    "    for data in datalist:\n",
    "        q = p[(p[\"data_id\"] == data) & (p[\"shots\"] == shot)]\n",
    "        q = q.reset_index(drop=True)\n",
    "    \n",
    "        q['rank'] = q[\"acc_mean\"].rank(ascending=False, method=\"min\")\n",
    "\n",
    "        for i, row in q.iterrows():\n",
    "            rankdata.loc[(rankdata[\"data_id\"] == row[\"data_id\"]) & \n",
    "                         (rankdata[\"shots\"] == shot) & \n",
    "                         (rankdata[\"acc_mean\"] == row[\"acc_mean\"]), 'rank'] = row['rank']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "b420158f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "42\n",
      "                         data_id  shots  acc_mean  acc_count       rank\n",
      "model                                                                  \n",
      "sslbinshuffling-lr  18056.261905    1.0  0.515875      100.0   2.666667\n",
      "sslbinsampling-lr   18056.261905    1.0  0.505740      100.0   5.000000\n",
      "knn                 18056.261905    1.0  0.490723      100.0   9.047619\n",
      "lr                  18056.261905    1.0  0.484706      100.0   9.500000\n",
      "mlp                 18056.261905    1.0  0.482371      100.0  10.047619\n",
      "                         data_id  shots  acc_mean   acc_count      rank\n",
      "model                                                                  \n",
      "sslbinshuffling-lr  18056.261905    5.0  0.612377  100.000000  5.547619\n",
      "sslbinsampling-lr   18056.261905    5.0  0.604830  100.000000  7.714286\n",
      "tabpfn              18056.261905    5.0  0.542788  100.000000  8.404762\n",
      "hyperfast           18056.261905    5.0  0.595647    7.619048  9.571429\n",
      "catboost            18056.261905    5.0  0.595197  100.000000  9.714286\n",
      "                         data_id  shots  acc_mean  acc_count       rank\n",
      "model                                                                  \n",
      "sslbinshuffling-lr  18056.261905    1.0  0.515875      100.0   2.666667\n",
      "sslbinsampling-lr   18056.261905    1.0  0.505740      100.0   5.000000\n",
      "sslshuffling-lr     18056.261905    1.0  0.492450      100.0  10.428571\n",
      "sslnoisemasking-lr  18056.261905    1.0  0.492417      100.0  10.642857\n",
      "knn                 18056.261905    1.0  0.490723      100.0   9.047619\n",
      "                         data_id  shots  acc_mean   acc_count       rank\n",
      "model                                                                   \n",
      "sslbinshuffling-lr  18056.261905    5.0  0.612377  100.000000   5.547619\n",
      "sslbinsampling-lr   18056.261905    5.0  0.604830  100.000000   7.714286\n",
      "hyperfast           18056.261905    5.0  0.595647    7.619048   9.571429\n",
      "catboost            18056.261905    5.0  0.595197  100.000000   9.714286\n",
      "sslnoisemasking-lr  18056.261905    5.0  0.595117  100.000000  10.380952\n"
     ]
    }
   ],
   "source": [
    "q = rankdata.loc[(~rankdata[\"rank\"].isna())]\n",
    "print(len(q[\"data_id\"].unique()))\n",
    "print(q[q[\"shots\"] == 1].groupby([\"model\"]).mean(\"rank\", \"acc_mean\").sort_values(\n",
    "    [\"shots\", \"rank\"]).head())\n",
    "print(q[q[\"shots\"] == 5].groupby([\"model\"]).mean(\"rank\", \"acc_mean\").sort_values(\n",
    "    [\"shots\", \"rank\"]).head())\n",
    "\n",
    "print(q[q[\"shots\"] == 1].groupby([\"model\"]).mean(\"rank\", \"acc_mean\").sort_values(\n",
    "    [\"acc_mean\", \"rank\"], ascending=False).head())\n",
    "print(q[q[\"shots\"] == 5].groupby([\"model\"]).mean(\"rank\", \"acc_mean\").sort_values(\n",
    "    [\"acc_mean\", \"rank\"], ascending=False).head())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aece7166",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "5ba70e8f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lr: 48.471$\\pm$15.396 & 9.524$\\pm$4.576 & 0 & 57.583$\\pm$17.350 & 9.905$\\pm$6.618 & 4\n",
      "knn: 49.072$\\pm$14.322 & 9.071$\\pm$4.134 & 0 & 54.185$\\pm$16.066 & 16.738$\\pm$6.251 & 0\n",
      "xgboost: 41.312$\\pm$23.741 & 18.095$\\pm$10.711 & 8 & 56.940$\\pm$15.069 & 14.762$\\pm$6.917 & 1\n",
      "catboost: 48.207$\\pm$15.766 & 10.357$\\pm$6.706 & 4 & 59.520$\\pm$18.265 & 9.690$\\pm$7.141 & 5\n",
      "lightgbm: 41.682$\\pm$23.214 & 18.024$\\pm$10.680 & 8 & 50.179$\\pm$19.842 & 19.881$\\pm$10.158 & 4\n",
      "mlp: 48.237$\\pm$15.048 & 10.071$\\pm$4.480 & 0 & 58.021$\\pm$17.559 & 10.024$\\pm$5.761 & 0\n",
      "ae: 47.363$\\pm$15.582 & 11.595$\\pm$6.298 & 1 & 57.039$\\pm$18.209 & 12.071$\\pm$6.546 & 1\n",
      "ict: 44.586$\\pm$13.577 & 16.357$\\pm$7.733 & 0 & 50.890$\\pm$18.664 & 18.643$\\pm$7.160 & 0\n",
      "meanteacher: 45.324$\\pm$13.717 & 16.500$\\pm$6.326 & 1 & 54.337$\\pm$16.393 & 17.310$\\pm$5.994 & 1\n",
      "sslrecon-lr: 33.441$\\pm$16.792 & 27.214$\\pm$3.120 & 0 & 32.954$\\pm$17.415 & 28.310$\\pm$1.854 & 0\n",
      "sslbinning-lr: 34.638$\\pm$17.036 & 26.333$\\pm$4.223 & 0 & 34.085$\\pm$17.123 & 27.667$\\pm$1.959 & 0\n",
      "sslsubtab-lr: 36.380$\\pm$17.651 & 25.476$\\pm$3.255 & 0 & 36.841$\\pm$18.071 & 27.119$\\pm$3.054 & 0\n",
      "sslvime-lr: 35.571$\\pm$17.440 & 25.738$\\pm$4.294 & 0 & 36.261$\\pm$17.907 & 26.833$\\pm$2.378 & 0\n",
      "semivime: 41.942$\\pm$13.507 & 20.286$\\pm$7.222 & 0 & 51.182$\\pm$14.956 & 19.571$\\pm$6.619 & 0\n",
      "sslscarf-lr: 48.925$\\pm$14.641 & 11.214$\\pm$6.119 & 1 & 59.193$\\pm$16.096 & 11.690$\\pm$5.372 & 1\n",
      "sslbinshuffling-lr: 51.587$\\pm$14.959 & 2.667$\\pm$1.408 & 14 & 61.238$\\pm$16.505 & 5.571$\\pm$3.670 & 6\n",
      "sslbinsampling-lr: 50.574$\\pm$14.644 & 4.976$\\pm$2.136 & 0 & 60.483$\\pm$16.199 & 7.738$\\pm$4.505 & 0\n",
      "sslmasking-lr: 48.057$\\pm$14.892 & 11.857$\\pm$4.393 & 0 & 56.809$\\pm$17.367 & 13.714$\\pm$4.850 & 1\n",
      "sslshuffling-lr: 49.245$\\pm$14.773 & 10.357$\\pm$5.481 & 2 & 59.464$\\pm$16.250 & 10.429$\\pm$5.683 & 0\n",
      "sslnoisemasking-lr: 49.242$\\pm$14.779 & 10.595$\\pm$6.101 & 1 & 59.512$\\pm$16.307 & 10.429$\\pm$5.442 & 1\n",
      "sslrq-lr: 47.038$\\pm$15.864 & 13.310$\\pm$4.719 & 0 & 55.851$\\pm$18.468 & 13.381$\\pm$5.831 & 1\n",
      "pseudolabel-masking: 43.755$\\pm$13.765 & 18.571$\\pm$6.279 & 0 & 55.244$\\pm$17.551 & 14.119$\\pm$6.674 & 0\n",
      "pseudolabel-shuffling: 43.498$\\pm$13.459 & 20.238$\\pm$5.921 & 0 & 52.964$\\pm$17.444 & 17.833$\\pm$7.190 & 0\n",
      "pseudolabel-noisemasking: 43.327$\\pm$13.571 & 20.452$\\pm$5.840 & 0 & 53.132$\\pm$17.178 & 17.595$\\pm$7.279 & 0\n",
      "pseudolabel-rq: 44.553$\\pm$14.343 & 18.024$\\pm$5.668 & 0 & 54.090$\\pm$17.776 & 15.524$\\pm$6.641 & 1\n",
      "pseudolabel-sampling: 43.713$\\pm$13.695 & 20.071$\\pm$6.190 & 0 & 53.554$\\pm$17.425 & 17.238$\\pm$6.570 & 0\n",
      "stunt: 47.002$\\pm$15.197 & 13.167$\\pm$6.064 & 1 & 53.302$\\pm$16.918 & 15.238$\\pm$8.069 & 2\n",
      "tabpfn: 42.290$\\pm$19.955 & 15.262$\\pm$7.812 & 1 & 54.279$\\pm$25.539 & 8.381$\\pm$9.066 & 3\n",
      "sslsaint-lr: 45.023$\\pm$18.480 & 16.214$\\pm$7.785 & 1 & 50.768$\\pm$20.647 & 17.690$\\pm$7.722 & 0\n",
      "hyperfast: 48.791$\\pm$15.371 & 11.512$\\pm$9.165 & 7 & 61.030$\\pm$16.479 & 9.195$\\pm$7.659 & 10\n"
     ]
    }
   ],
   "source": [
    "# xgboost: 41.406$\\pm$23.738 & 16.786$\\pm$9.832 & 8 & 57.294$\\pm$15.113 & 12.857$\\pm$7.155 & 2\n",
    "# sslbinshuffling-lr: 52.928$\\pm$15.667 & 2.119$\\pm$1.418 & 17 & 62.161$\\pm$16.403 & 3.786$\\pm$2.719 & 12\n",
    "for c in clist: #[\"xgboost\", \"sslbinshuffling-lr\"]: #clist: #[\"tabpfn\", \"sslbinsampling-lr\", \"sslbinshuffling-lr\"]: #clist:\n",
    "    dt = q[(q[\"shots\"] == 1) & (q[\"model\"] == c)]# & (~q[\"data_id\"].isin(excl))]\n",
    "    v1 = dt[\"acc_mean\"].mean()\n",
    "    v2 = dt[\"rank\"].mean()\n",
    "    v3 = dt[\"acc_mean\"].std()\n",
    "    v4 = dt[\"rank\"].std()\n",
    "    \n",
    "    dt2 = q[(q[\"shots\"] == 5) & (q[\"model\"] == c)]# & (~q[\"data_id\"].isin(excl))]\n",
    "    v21 = dt2[\"acc_mean\"].mean()\n",
    "    v22 = dt2[\"rank\"].mean()\n",
    "    v23 = dt2[\"acc_mean\"].std()\n",
    "    v24 = dt2[\"rank\"].std()\n",
    "    \n",
    "    print(f'{c}: {v1*100:.3f}$\\pm${v3*100:.3f} & {v2:.3f}$\\pm${v4:.3f} & {dt[dt[\"rank\"] == 1].shape[0]} & {v21*100:.3f}$\\pm${v23*100:.3f} & {v22:.3f}$\\pm${v24:.3f} & {dt2[dt2[\"rank\"] == 1].shape[0]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 978,
   "id": "b861c888",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([   49,    53,   188,  1459,  1494, 41168])"
      ]
     },
     "execution_count": 978,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dt2[dt2[\"rank\"] == 1][\"data_id\"].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a964f41",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 989,
   "id": "c1e8ea59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tabpfn: 48.419$\\pm$13.096 & 13.645$\\pm$4.916 & 0 & 60.482$\\pm$15.999 & 5.839$\\pm$4.734 & 2\n",
      "sslbinshuffling-lr: 52.705$\\pm$14.371 & 2.065$\\pm$1.093 & 14 & 60.550$\\pm$16.506 & 5.000$\\pm$3.615 & 8\n",
      "sslbinsampling-lr: 51.621$\\pm$13.994 & 4.548$\\pm$2.047 & 1 & 59.976$\\pm$16.170 & 6.774$\\pm$4.006 & 0\n"
     ]
    }
   ],
   "source": [
    "excl = [12, 307, 1492, 40499, 41143, 41168, \n",
    "        53, 49, 188, 45714, 40981\n",
    "       ] #, 45714, 40981, 53, 49, 41168]\n",
    "for c in [\"tabpfn\", \"sslbinshuffling-lr\", \"sslbinsampling-lr\"]: #clist:\n",
    "    dt = q[(q[\"shots\"] == 1) & (q[\"model\"] == c) & (~q[\"data_id\"].isin(excl))]\n",
    "    v1 = dt[\"acc_mean\"].mean()\n",
    "    v2 = dt[\"rank\"].mean()\n",
    "    v3 = dt[\"acc_mean\"].std()\n",
    "    v4 = dt[\"rank\"].std()\n",
    "    \n",
    "    dt2 = q[(q[\"shots\"] == 5) & (q[\"model\"] == c) & (~q[\"data_id\"].isin(excl))]\n",
    "    v21 = dt2[\"acc_mean\"].mean()\n",
    "    v22 = dt2[\"rank\"].mean()\n",
    "    v23 = dt2[\"acc_mean\"].std()\n",
    "    v24 = dt2[\"rank\"].std()\n",
    "    \n",
    "    print(f'{c}: {v1*100:.3f}$\\pm${v3*100:.3f} & {v2:.3f}$\\pm${v4:.3f} & {dt[dt[\"rank\"] == 1].shape[0]} & {v21*100:.3f}$\\pm${v23*100:.3f} & {v22:.3f}$\\pm${v24:.3f} & {dt2[dt2[\"rank\"] == 1].shape[0]}')\n",
    "#     print(f'{c}: {v21*100:.3f}$\\pm${v23*100:.3f} & {v22:.3f}$\\pm${v24:.3f} & {dt2[dt2[\"rank\"] == 1].shape[0]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 670,
   "id": "c5dd6c9c",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2350</th>\n",
       "      <td>45714</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.956575</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>446</th>\n",
       "      <td>53</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.747778</td>\n",
       "      <td>100</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>390</th>\n",
       "      <td>49</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.737667</td>\n",
       "      <td>100</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1566</th>\n",
       "      <td>40981</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.737029</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>278</th>\n",
       "      <td>29</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.732595</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1174</th>\n",
       "      <td>1494</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.723839</td>\n",
       "      <td>100</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>726</th>\n",
       "      <td>1043</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.674567</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1902</th>\n",
       "      <td>44125</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.650673</td>\n",
       "      <td>100</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1958</th>\n",
       "      <td>44126</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.649386</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1342</th>\n",
       "      <td>1504</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.635835</td>\n",
       "      <td>100</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      data_id  shots   model  acc_mean  acc_count  rank\n",
       "2350    45714      5  tabpfn  0.956575        100   2.0\n",
       "446        53      5  tabpfn  0.747778        100   1.0\n",
       "390        49      5  tabpfn  0.737667        100   1.0\n",
       "1566    40981      5  tabpfn  0.737029        100   2.0\n",
       "278        29      5  tabpfn  0.732595        100   2.0\n",
       "1174     1494      5  tabpfn  0.723839        100   1.0\n",
       "726      1043      5  tabpfn  0.674567        100   2.0\n",
       "1902    44125      5  tabpfn  0.650673        100   1.0\n",
       "1958    44126      5  tabpfn  0.649386        100   2.0\n",
       "1342     1504      5  tabpfn  0.635835        100   2.0"
      ]
     },
     "execution_count": 670,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[(q[\"shots\"] == 5) & (q[\"model\"] == \"tabpfn\") & (~q[\"data_id\"].isin(excl)) & (q[\"rank\"] < 1)].sort_values(\"acc_mean\", ascending=False).head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 682,
   "id": "6f9b1205",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>436</th>\n",
       "      <td>53</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.645556</td>\n",
       "      <td>100</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id  shots               model  acc_mean  acc_count  rank\n",
       "436       53      5  sslbinshuffling-lr  0.645556        100   5.0"
      ]
     },
     "execution_count": 682,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[(q[\"shots\"] == 5) & (q[\"model\"] == \"sslbinshuffling-lr\") & (q[\"data_id\"] == 53)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 565,
   "id": "e6f1dd38",
   "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>trial</th>\n",
       "      <th>shots</th>\n",
       "      <th>data_id</th>\n",
       "      <th>model</th>\n",
       "      <th>acc</th>\n",
       "      <th>auroc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3944</th>\n",
       "      <td>9</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.923654</td>\n",
       "      <td>0.987194</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3944</th>\n",
       "      <td>59</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.908074</td>\n",
       "      <td>0.987323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4992</th>\n",
       "      <td>45</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.900567</td>\n",
       "      <td>0.977955</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4438</th>\n",
       "      <td>76</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.863173</td>\n",
       "      <td>0.979493</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4958</th>\n",
       "      <td>73</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.857649</td>\n",
       "      <td>0.963085</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3944</th>\n",
       "      <td>56</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.653683</td>\n",
       "      <td>0.950766</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3944</th>\n",
       "      <td>46</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.647592</td>\n",
       "      <td>0.900926</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4958</th>\n",
       "      <td>62</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.644334</td>\n",
       "      <td>0.941063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3944</th>\n",
       "      <td>44</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.634844</td>\n",
       "      <td>0.923004</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4984</th>\n",
       "      <td>78</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.619263</td>\n",
       "      <td>0.923578</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>100 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      trial  shots  data_id               model       acc     auroc\n",
       "3944      9      5    45714  sslbinshuffling-lr  0.923654  0.987194\n",
       "3944     59      5    45714  sslbinshuffling-lr  0.908074  0.987323\n",
       "4992     45      5    45714  sslbinshuffling-lr  0.900567  0.977955\n",
       "4438     76      5    45714  sslbinshuffling-lr  0.863173  0.979493\n",
       "4958     73      5    45714  sslbinshuffling-lr  0.857649  0.963085\n",
       "...     ...    ...      ...                 ...       ...       ...\n",
       "3944     56      5    45714  sslbinshuffling-lr  0.653683  0.950766\n",
       "3944     46      5    45714  sslbinshuffling-lr  0.647592  0.900926\n",
       "4958     62      5    45714  sslbinshuffling-lr  0.644334  0.941063\n",
       "3944     44      5    45714  sslbinshuffling-lr  0.634844  0.923004\n",
       "4984     78      5    45714  sslbinshuffling-lr  0.619263  0.923578\n",
       "\n",
       "[100 rows x 6 columns]"
      ]
     },
     "execution_count": 565,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result[(result[\"data_id\"] == 45714) & (result[\"shots\"] == 5) & (result[\"model\"] == \"sslbinshuffling-lr\")].sort_values(\"acc\", ascending=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aab71df1",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 366,
   "id": "03a5de6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# excl = p[(p[\"acc_mean\"] == 0) & (p[\"model\"] == \"tabpfn\")][\"data_id\"].unique()\n",
    "# excl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 335,
   "id": "2e759a4e",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2350</th>\n",
       "      <td>45714</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.958555</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>950</th>\n",
       "      <td>1462</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.925455</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1398</th>\n",
       "      <td>4153</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.855556</td>\n",
       "      <td>10</td>\n",
       "      <td>13.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>390</th>\n",
       "      <td>49</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.755000</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>782</th>\n",
       "      <td>1063</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.745714</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>446</th>\n",
       "      <td>53</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.735185</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1566</th>\n",
       "      <td>40981</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.717391</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>558</th>\n",
       "      <td>59</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.715493</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1510</th>\n",
       "      <td>40922</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.708850</td>\n",
       "      <td>10</td>\n",
       "      <td>14.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1846</th>\n",
       "      <td>44123</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.698629</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>278</th>\n",
       "      <td>29</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.693893</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>726</th>\n",
       "      <td>1043</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.693209</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1174</th>\n",
       "      <td>1494</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.689100</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>110</th>\n",
       "      <td>18</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.671750</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>334</th>\n",
       "      <td>37</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.668831</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1902</th>\n",
       "      <td>44125</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.667377</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1958</th>\n",
       "      <td>44126</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.664414</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1734</th>\n",
       "      <td>44090</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.650400</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1342</th>\n",
       "      <td>1504</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.643959</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>838</th>\n",
       "      <td>1067</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.635545</td>\n",
       "      <td>10</td>\n",
       "      <td>11.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1062</th>\n",
       "      <td>1489</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.626920</td>\n",
       "      <td>10</td>\n",
       "      <td>18.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1790</th>\n",
       "      <td>44091</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.624070</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2014</th>\n",
       "      <td>44131</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.613746</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>166</th>\n",
       "      <td>22</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.606750</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2294</th>\n",
       "      <td>45062</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.604350</td>\n",
       "      <td>10</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1230</th>\n",
       "      <td>1497</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.569231</td>\n",
       "      <td>10</td>\n",
       "      <td>11.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2126</th>\n",
       "      <td>44158</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.561569</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>502</th>\n",
       "      <td>54</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.544118</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2238</th>\n",
       "      <td>44161</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.541619</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2182</th>\n",
       "      <td>44160</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.506640</td>\n",
       "      <td>10</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2070</th>\n",
       "      <td>44157</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.500657</td>\n",
       "      <td>10</td>\n",
       "      <td>20.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>614</th>\n",
       "      <td>188</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.453488</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>222</th>\n",
       "      <td>23</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.424068</td>\n",
       "      <td>10</td>\n",
       "      <td>10.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1678</th>\n",
       "      <td>41168</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.395408</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>894</th>\n",
       "      <td>1459</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.340802</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1006</th>\n",
       "      <td>1475</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.259886</td>\n",
       "      <td>10</td>\n",
       "      <td>11.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1286</th>\n",
       "      <td>1503</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.100032</td>\n",
       "      <td>10</td>\n",
       "      <td>21.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1454</th>\n",
       "      <td>40499</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1622</th>\n",
       "      <td>41143</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1118</th>\n",
       "      <td>1492</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>670</th>\n",
       "      <td>307</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>12</td>\n",
       "      <td>5</td>\n",
       "      <td>tabpfn</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      data_id  shots   model  acc_mean  acc_count  rank\n",
       "2350    45714      5  tabpfn  0.958555         10   2.0\n",
       "950      1462      5  tabpfn  0.925455         10   4.0\n",
       "1398     4153      5  tabpfn  0.855556         10  13.0\n",
       "390        49      5  tabpfn  0.755000         10   1.0\n",
       "782      1063      5  tabpfn  0.745714         10   6.0\n",
       "446        53      5  tabpfn  0.735185         10   1.0\n",
       "1566    40981      5  tabpfn  0.717391         10   1.0\n",
       "558        59      5  tabpfn  0.715493         10   8.0\n",
       "1510    40922      5  tabpfn  0.708850         10  14.0\n",
       "1846    44123      5  tabpfn  0.698629         10   1.0\n",
       "278        29      5  tabpfn  0.693893         10   4.0\n",
       "726      1043      5  tabpfn  0.693209         10   2.0\n",
       "1174     1494      5  tabpfn  0.689100         10   4.0\n",
       "110        18      5  tabpfn  0.671750         10   6.0\n",
       "334        37      5  tabpfn  0.668831         10   6.0\n",
       "1902    44125      5  tabpfn  0.667377         10   4.0\n",
       "1958    44126      5  tabpfn  0.664414         10   8.0\n",
       "1734    44090      5  tabpfn  0.650400         10   3.0\n",
       "1342     1504      5  tabpfn  0.643959         10   2.0\n",
       "838      1067      5  tabpfn  0.635545         10  11.0\n",
       "1062     1489      5  tabpfn  0.626920         10  18.0\n",
       "1790    44091      5  tabpfn  0.624070         10   2.0\n",
       "2014    44131      5  tabpfn  0.613746         10   6.0\n",
       "166        22      5  tabpfn  0.606750         10   3.0\n",
       "2294    45062      5  tabpfn  0.604350         10   5.0\n",
       "1230     1497      5  tabpfn  0.569231         10  11.0\n",
       "2126    44158      5  tabpfn  0.561569         10   2.0\n",
       "502        54      5  tabpfn  0.544118         10   4.0\n",
       "2238    44161      5  tabpfn  0.541619         10   3.0\n",
       "2182    44160      5  tabpfn  0.506640         10   7.0\n",
       "2070    44157      5  tabpfn  0.500657         10  20.0\n",
       "614       188      5  tabpfn  0.453488         10   1.0\n",
       "222        23      5  tabpfn  0.424068         10  10.0\n",
       "1678    41168      5  tabpfn  0.395408         10   3.0\n",
       "894      1459      5  tabpfn  0.340802         10   1.0\n",
       "1006     1475      5  tabpfn  0.259886         10  11.0\n",
       "1286     1503      5  tabpfn  0.100032         10  21.0\n",
       "1454    40499      5  tabpfn  0.000000         10  28.0\n",
       "1622    41143      5  tabpfn  0.000000         10  28.0\n",
       "1118     1492      5  tabpfn  0.000000         10  28.0\n",
       "670       307      5  tabpfn  0.000000         10  28.0\n",
       "54         12      5  tabpfn  0.000000         10  28.0"
      ]
     },
     "execution_count": 335,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[(q[\"shots\"] == 5) & (q[\"model\"] == \"tabpfn\")].sort_values(\"acc_mean\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95daeb16",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04d90983",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a16c370",
   "metadata": {},
   "outputs": [],
   "source": [
    "excl = result[(result[\"model\"] == \"tabpfn\") & (result[\"trial\"] < 10) & (result[\"acc\"] == 0)][\"data_id\"].unique()\n",
    "result[(result[\"trial\"] < 10) & (result[\"shots\"] == 5) & (result[\"model\"] == \"sslbinshuffling-lr\") & ~(result[\"data_id\"].isin(excl)) & (result[\"data_id\"].isin(datalist))][\"acc\"].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b419417d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'22 54 1063 1067 18 23 59 188 1043 1459 1475 1489 1497 1503 4153 44125 44131 45062 44157 1462 44160 29 37 53 49 1504 1494 44126 40981 41168 44091 44158 44123 44090 40922 44161 45714'"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\" \".join(map(str, [d for d in datalist if d not in excl]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ee51438",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac9236ac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "6987a7eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# result[(result[\"trial\"] < 10) & (result[\"shots\"] == 5) & (result[\"model\"] == \"sslbinshuffling-lr\")][\"data_id\"]\n",
    "# result[(result[\"trial\"] < 10) & (result[\"shots\"] == 5) & (result[\"model\"] == \"sslbinshuffling-lr\") & (result[\"data_id\"] == 1063)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "d1ea7bbf",
   "metadata": {},
   "outputs": [],
   "source": [
    "clist = [c for c in clist if (not c.startswith(\"ssl\")) or (c.endswith(\"-lr\"))]\n",
    "\n",
    "# result = result[result[\"trial\"] < 10]\n",
    "result = pd.DataFrame(columns=(\"trial\", \"shots\", \"data_id\", \"model\", \"acc\", \"auroc\"))\n",
    "for seed in range(100):\n",
    "    result = pd.concat([result, pd.read_csv(f'/home/SemiTab/result-summary/result-{seed}.csv')], axis=0)\n",
    "p = result.groupby([\"data_id\", \"shots\", \"model\"]).agg(\n",
    "    acc_mean=('acc', 'mean'),\n",
    "    acc_count=('acc', lambda x: x.notna().sum())\n",
    ").reset_index()\n",
    "\n",
    "# p = p[(p[\"model\"].isin(clist)) & (p[\"shots\"] == 5)].reset_index(drop=True)\n",
    "p = p[(p[\"model\"].isin(clist))].reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a83bead",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "47ca765a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7713237187741437\n"
     ]
    },
    {
     "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>trial</th>\n",
       "      <th>shots</th>\n",
       "      <th>data_id</th>\n",
       "      <th>model</th>\n",
       "      <th>acc</th>\n",
       "      <th>auroc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>169652</th>\n",
       "      <td>2</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.674504</td>\n",
       "      <td>0.897981</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>198515</th>\n",
       "      <td>13</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.690227</td>\n",
       "      <td>0.951178</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169612</th>\n",
       "      <td>8</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.734844</td>\n",
       "      <td>0.967523</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169495</th>\n",
       "      <td>7</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.758924</td>\n",
       "      <td>0.962401</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169636</th>\n",
       "      <td>3</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.759348</td>\n",
       "      <td>0.966452</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169664</th>\n",
       "      <td>4</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.762323</td>\n",
       "      <td>0.974996</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>136258</th>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.780878</td>\n",
       "      <td>0.963609</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169632</th>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.798725</td>\n",
       "      <td>0.98076</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169559</th>\n",
       "      <td>5</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.824504</td>\n",
       "      <td>0.97911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169596</th>\n",
       "      <td>6</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.840793</td>\n",
       "      <td>0.98426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>169624</th>\n",
       "      <td>9</td>\n",
       "      <td>5</td>\n",
       "      <td>45714</td>\n",
       "      <td>sslbinsampling-lr</td>\n",
       "      <td>0.859490</td>\n",
       "      <td>0.978432</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        trial  shots  data_id              model       acc     auroc\n",
       "169652      2      5    45714  sslbinsampling-lr  0.674504  0.897981\n",
       "198515     13      5    45714  sslbinsampling-lr  0.690227  0.951178\n",
       "169612      8      5    45714  sslbinsampling-lr  0.734844  0.967523\n",
       "169495      7      5    45714  sslbinsampling-lr  0.758924  0.962401\n",
       "169636      3      5    45714  sslbinsampling-lr  0.759348  0.966452\n",
       "169664      4      5    45714  sslbinsampling-lr  0.762323  0.974996\n",
       "136258      0      5    45714  sslbinsampling-lr  0.780878  0.963609\n",
       "169632      1      5    45714  sslbinsampling-lr  0.798725   0.98076\n",
       "169559      5      5    45714  sslbinsampling-lr  0.824504   0.97911\n",
       "169596      6      5    45714  sslbinsampling-lr  0.840793   0.98426\n",
       "169624      9      5    45714  sslbinsampling-lr  0.859490  0.978432"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(result[(result[\"shots\"] == 5) & (result[\"data_id\"] == d) & (result[\"model\"] == \"sslbinsampling-lr\")][\"acc\"].mean())\n",
    "result[(result[\"shots\"] == 5) & (result[\"data_id\"] == d) & (result[\"model\"] == \"sslbinsampling-lr\")].sort_values(\"acc\")\n",
    "# print(result[(result[\"shots\"] == 1) & (result[\"data_id\"] == d) & (result[\"model\"] == \"ict\")][\"acc\"].mean())\n",
    "# result[(result[\"shots\"] == 1) & (result[\"data_id\"] == d) & (result[\"model\"] == \"ict\")].sort_values(\"acc\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "7cb7ab46",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "rankdata = copy.deepcopy(p)\n",
    "\n",
    "for shot in [1, 5]:\n",
    "    for data in datalist:\n",
    "        q = p[(p[\"data_id\"] == data) & (p[\"shots\"] == shot)]\n",
    "        q = q.reset_index(drop=True)\n",
    "    \n",
    "#         if len(q[q[\"acc_count\"] == 100]) == len(clist):\n",
    "        q['rank'] = q[\"acc_mean\"].rank(ascending=False, method=\"min\")\n",
    "\n",
    "        for i, row in q.iterrows():\n",
    "            rankdata.loc[(rankdata[\"data_id\"] == row[\"data_id\"]) & \n",
    "                         (rankdata[\"shots\"] == shot) & \n",
    "                         (rankdata[\"acc_mean\"] == row[\"acc_mean\"]), 'rank'] = row['rank']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "a0722e9f",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>ae</td>\n",
       "      <td>0.573775</td>\n",
       "      <td>100</td>\n",
       "      <td>16.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>catboost</td>\n",
       "      <td>0.519525</td>\n",
       "      <td>100</td>\n",
       "      <td>18.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>ict</td>\n",
       "      <td>0.509625</td>\n",
       "      <td>100</td>\n",
       "      <td>19.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>knn</td>\n",
       "      <td>0.645025</td>\n",
       "      <td>100</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>lightgbm</td>\n",
       "      <td>0.100050</td>\n",
       "      <td>100</td>\n",
       "      <td>24.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   data_id  shots     model  acc_mean  acc_count  rank\n",
       "0       12      1        ae  0.573775        100  16.0\n",
       "1       12      1  catboost  0.519525        100  18.0\n",
       "2       12      1       ict  0.509625        100  19.0\n",
       "3       12      1       knn  0.645025        100   5.0\n",
       "4       12      1  lightgbm  0.100050        100  24.0"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "6b9382e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "42\n",
      "                         data_id  shots  acc_mean  acc_count      rank\n",
      "model                                                                 \n",
      "sslbinshuffling-lr  18056.261905    1.0  0.500338      100.0  6.833333\n",
      "sslbinsampling-lr   18056.261905    1.0  0.499769      100.0  7.404762\n",
      "knn                 18056.261905    1.0  0.490723      100.0  7.714286\n",
      "lr                  18056.261905    1.0  0.484706      100.0  8.214286\n",
      "mlp                 18056.261905    1.0  0.482371      100.0  9.071429\n",
      "                         data_id  shots  acc_mean  acc_count      rank\n",
      "model                                                                 \n",
      "tabpfn              18056.261905    5.0  0.542791      100.0  7.619048\n",
      "sslbinsampling-lr   18056.261905    5.0  0.601485      100.0  7.952381\n",
      "sslbinshuffling-lr  18056.261905    5.0  0.600408      100.0  8.428571\n",
      "mlp                 18056.261905    5.0  0.580205      100.0  8.714286\n",
      "catboost            18056.261905    5.0  0.595197      100.0  8.785714\n"
     ]
    }
   ],
   "source": [
    "dlist = [\n",
    "    22, 54, 1063, 1067, 12, 18, 23, 59, 188, 307, 1043, 1459, 1475, 1489, 1492, 1497, 1503, 4153, 40499, 44125,\n",
    "    44131, 45062, 44157, 1462, 44160, 29, 37, 53, 49, 1504, 1494, 41143, 44126, 40981, 41168, 44091, 44158, 44123, 44090,\n",
    "    40922, 44161, 45714]\n",
    "\n",
    "q = rankdata.loc[(~rankdata[\"rank\"].isna()) & (rankdata[\"data_id\"].isin(dlist))]\n",
    "print(len(q[\"data_id\"].unique()))\n",
    "print(q[q[\"shots\"] == 1].groupby([\"model\"]).mean(\"rank\", \"acc_mean\").sort_values([\"shots\", \"rank\"]).head(5))\n",
    "print(q[q[\"shots\"] == 5].groupby([\"model\"]).mean(\"rank\").sort_values([\"shots\", \"rank\"]).head(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "db8c986b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5148840420842874\n",
      "2.59375\n",
      "0.5055646783807005\n",
      "4.53125\n",
      "0.4682477788392785\n",
      "13.0625\n"
     ]
    }
   ],
   "source": [
    "excl = [1486, 1493, 1492, 41145, 12, 41143, 40499, 40536, \n",
    "        40985, 1476, 1509, 41169, 307, \n",
    "        45714, 49, 1063, 53, 40981]\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"sslbinshuffling-lr\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"acc_mean\"].mean())\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"sslbinshuffling-lr\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"rank\"].mean())\n",
    "\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"sslbinsampling-lr\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"acc_mean\"].mean())\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"sslbinsampling-lr\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"rank\"].mean())\n",
    "\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"tabpfn\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"acc_mean\"].mean())\n",
    "print(q[(q[\"shots\"] == 1) & (q[\"model\"] == \"tabpfn\") & ~(\n",
    "    q[\"data_id\"].isin(excl))][\"rank\"].mean())\n",
    "\n",
    "# print(q[(q[\"shots\"] == 5) & (q[\"model\"] == \"sslbinshuffling-lr\") & ~(q[\"data_id\"].isin(excl))][\"acc_mean\"].std())\n",
    "# print(q[(q[\"shots\"] == 5) & (q[\"model\"] == \"sslbinshuffling-lr\") & ~(q[\"data_id\"].isin(excl))][\"rank\"].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "id": "bc545310",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "24"
      ]
     },
     "execution_count": 129,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(datalist) - len(excl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "1496dc3c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 141,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(\n",
    "    q[(q[\"shots\"] == 5) & (q[\"model\"] == \"tabpfn\") & ~(\n",
    "    q[\"data_id\"].isin(excl)) & (q[\"rank\"] == 1)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1207a5a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "6ae440b6",
   "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>data_id</th>\n",
       "      <th>dataname</th>\n",
       "      <th>tasktype</th>\n",
       "      <th>num_raw_data</th>\n",
       "      <th>num_raw_features</th>\n",
       "      <th>datasize</th>\n",
       "      <th>num_prep_data</th>\n",
       "      <th>num_prep_features</th>\n",
       "      <th>feature_sample_ratio</th>\n",
       "      <th>num_prep_cells</th>\n",
       "      <th>...</th>\n",
       "      <th>entropy_indv_max</th>\n",
       "      <th>entropy_indv_avg</th>\n",
       "      <th>entropy_cond_min</th>\n",
       "      <th>entropy_cond_max</th>\n",
       "      <th>entropy_cond_avg</th>\n",
       "      <th>cor_train</th>\n",
       "      <th>cor_val</th>\n",
       "      <th>cor_test</th>\n",
       "      <th>cor_full</th>\n",
       "      <th>avg_cardinality</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>196</th>\n",
       "      <td>1503</td>\n",
       "      <td>SAD</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>263256</td>\n",
       "      <td>14</td>\n",
       "      <td>Large</td>\n",
       "      <td>263256</td>\n",
       "      <td>14</td>\n",
       "      <td>0.000053</td>\n",
       "      <td>3685584</td>\n",
       "      <td>...</td>\n",
       "      <td>0.967896</td>\n",
       "      <td>0.938514</td>\n",
       "      <td>14.368732</td>\n",
       "      <td>14.657270</td>\n",
       "      <td>14.466336</td>\n",
       "      <td>0.020958</td>\n",
       "      <td>0.021205</td>\n",
       "      <td>0.021170</td>\n",
       "      <td>0.021003</td>\n",
       "      <td>2.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>189</th>\n",
       "      <td>40922</td>\n",
       "      <td>RW</td>\n",
       "      <td>binclass</td>\n",
       "      <td>88588</td>\n",
       "      <td>6</td>\n",
       "      <td>Large</td>\n",
       "      <td>88588</td>\n",
       "      <td>6</td>\n",
       "      <td>0.000068</td>\n",
       "      <td>531528</td>\n",
       "      <td>...</td>\n",
       "      <td>0.854431</td>\n",
       "      <td>0.633366</td>\n",
       "      <td>7.509057</td>\n",
       "      <td>9.097907</td>\n",
       "      <td>8.243417</td>\n",
       "      <td>0.034408</td>\n",
       "      <td>0.034453</td>\n",
       "      <td>0.034068</td>\n",
       "      <td>0.034350</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>158</th>\n",
       "      <td>41168</td>\n",
       "      <td>JM</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>83733</td>\n",
       "      <td>54</td>\n",
       "      <td>Large</td>\n",
       "      <td>83733</td>\n",
       "      <td>54</td>\n",
       "      <td>0.000645</td>\n",
       "      <td>4521582</td>\n",
       "      <td>...</td>\n",
       "      <td>0.996981</td>\n",
       "      <td>0.882752</td>\n",
       "      <td>12.719671</td>\n",
       "      <td>14.061614</td>\n",
       "      <td>13.099133</td>\n",
       "      <td>0.002941</td>\n",
       "      <td>0.002913</td>\n",
       "      <td>0.002952</td>\n",
       "      <td>0.002937</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>141</th>\n",
       "      <td>44131</td>\n",
       "      <td>JN</td>\n",
       "      <td>binclass</td>\n",
       "      <td>57580</td>\n",
       "      <td>54</td>\n",
       "      <td>Large</td>\n",
       "      <td>57580</td>\n",
       "      <td>54</td>\n",
       "      <td>0.000938</td>\n",
       "      <td>3109320</td>\n",
       "      <td>...</td>\n",
       "      <td>0.998600</td>\n",
       "      <td>0.883499</td>\n",
       "      <td>12.174075</td>\n",
       "      <td>13.463155</td>\n",
       "      <td>12.556432</td>\n",
       "      <td>0.002914</td>\n",
       "      <td>0.002917</td>\n",
       "      <td>0.002891</td>\n",
       "      <td>0.002908</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>165</th>\n",
       "      <td>45714</td>\n",
       "      <td>PC</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>35300</td>\n",
       "      <td>5</td>\n",
       "      <td>Large</td>\n",
       "      <td>35300</td>\n",
       "      <td>5</td>\n",
       "      <td>0.000142</td>\n",
       "      <td>176500</td>\n",
       "      <td>...</td>\n",
       "      <td>0.999539</td>\n",
       "      <td>0.967325</td>\n",
       "      <td>5.743618</td>\n",
       "      <td>6.119234</td>\n",
       "      <td>5.850630</td>\n",
       "      <td>0.118204</td>\n",
       "      <td>0.117428</td>\n",
       "      <td>0.118379</td>\n",
       "      <td>0.118138</td>\n",
       "      <td>10.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>159</th>\n",
       "      <td>44090</td>\n",
       "      <td>CAB</td>\n",
       "      <td>binclass</td>\n",
       "      <td>20634</td>\n",
       "      <td>8</td>\n",
       "      <td>Large</td>\n",
       "      <td>20634</td>\n",
       "      <td>8</td>\n",
       "      <td>0.000388</td>\n",
       "      <td>165072</td>\n",
       "      <td>...</td>\n",
       "      <td>0.984875</td>\n",
       "      <td>0.743260</td>\n",
       "      <td>10.235487</td>\n",
       "      <td>12.145199</td>\n",
       "      <td>11.038115</td>\n",
       "      <td>0.034812</td>\n",
       "      <td>0.035018</td>\n",
       "      <td>0.034972</td>\n",
       "      <td>0.034702</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>176</th>\n",
       "      <td>44123</td>\n",
       "      <td>HOB</td>\n",
       "      <td>binclass</td>\n",
       "      <td>13488</td>\n",
       "      <td>16</td>\n",
       "      <td>Large</td>\n",
       "      <td>13488</td>\n",
       "      <td>16</td>\n",
       "      <td>0.001186</td>\n",
       "      <td>215808</td>\n",
       "      <td>...</td>\n",
       "      <td>0.973481</td>\n",
       "      <td>0.709948</td>\n",
       "      <td>10.162462</td>\n",
       "      <td>12.507682</td>\n",
       "      <td>11.037899</td>\n",
       "      <td>0.015384</td>\n",
       "      <td>0.015054</td>\n",
       "      <td>0.015281</td>\n",
       "      <td>0.015275</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>146</th>\n",
       "      <td>44125</td>\n",
       "      <td>MT</td>\n",
       "      <td>binclass</td>\n",
       "      <td>13376</td>\n",
       "      <td>10</td>\n",
       "      <td>Large</td>\n",
       "      <td>13376</td>\n",
       "      <td>10</td>\n",
       "      <td>0.000748</td>\n",
       "      <td>133760</td>\n",
       "      <td>...</td>\n",
       "      <td>0.978796</td>\n",
       "      <td>0.872625</td>\n",
       "      <td>10.058919</td>\n",
       "      <td>10.897994</td>\n",
       "      <td>10.411612</td>\n",
       "      <td>0.040798</td>\n",
       "      <td>0.041756</td>\n",
       "      <td>0.041031</td>\n",
       "      <td>0.040860</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>138</th>\n",
       "      <td>44126</td>\n",
       "      <td>BM</td>\n",
       "      <td>binclass</td>\n",
       "      <td>10578</td>\n",
       "      <td>7</td>\n",
       "      <td>Large</td>\n",
       "      <td>10578</td>\n",
       "      <td>7</td>\n",
       "      <td>0.000662</td>\n",
       "      <td>74046</td>\n",
       "      <td>...</td>\n",
       "      <td>0.989800</td>\n",
       "      <td>0.689867</td>\n",
       "      <td>9.015195</td>\n",
       "      <td>10.826738</td>\n",
       "      <td>10.011551</td>\n",
       "      <td>0.019449</td>\n",
       "      <td>0.020207</td>\n",
       "      <td>0.019498</td>\n",
       "      <td>0.019434</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>137</th>\n",
       "      <td>1459</td>\n",
       "      <td>AC</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>10218</td>\n",
       "      <td>7</td>\n",
       "      <td>Large</td>\n",
       "      <td>10218</td>\n",
       "      <td>7</td>\n",
       "      <td>0.000685</td>\n",
       "      <td>71526</td>\n",
       "      <td>...</td>\n",
       "      <td>1.081121</td>\n",
       "      <td>0.947669</td>\n",
       "      <td>7.871872</td>\n",
       "      <td>8.223680</td>\n",
       "      <td>8.025155</td>\n",
       "      <td>0.056897</td>\n",
       "      <td>0.055597</td>\n",
       "      <td>0.058551</td>\n",
       "      <td>0.056895</td>\n",
       "      <td>8.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>133</th>\n",
       "      <td>45062</td>\n",
       "      <td>CH</td>\n",
       "      <td>binclass</td>\n",
       "      <td>10000</td>\n",
       "      <td>10</td>\n",
       "      <td>Large</td>\n",
       "      <td>10000</td>\n",
       "      <td>10</td>\n",
       "      <td>0.001000</td>\n",
       "      <td>100000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.999433</td>\n",
       "      <td>0.933223</td>\n",
       "      <td>8.302845</td>\n",
       "      <td>8.794209</td>\n",
       "      <td>8.522789</td>\n",
       "      <td>0.003907</td>\n",
       "      <td>0.012596</td>\n",
       "      <td>0.010023</td>\n",
       "      <td>0.003860</td>\n",
       "      <td>4.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>132</th>\n",
       "      <td>44157</td>\n",
       "      <td>EM</td>\n",
       "      <td>binclass</td>\n",
       "      <td>7608</td>\n",
       "      <td>23</td>\n",
       "      <td>Medium</td>\n",
       "      <td>7608</td>\n",
       "      <td>23</td>\n",
       "      <td>0.003023</td>\n",
       "      <td>174984</td>\n",
       "      <td>...</td>\n",
       "      <td>10.588738</td>\n",
       "      <td>1.671726</td>\n",
       "      <td>1.982541</td>\n",
       "      <td>11.480322</td>\n",
       "      <td>9.399735</td>\n",
       "      <td>0.012674</td>\n",
       "      <td>0.014052</td>\n",
       "      <td>0.013553</td>\n",
       "      <td>0.012829</td>\n",
       "      <td>5.200000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>1475</td>\n",
       "      <td>FT</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>6118</td>\n",
       "      <td>51</td>\n",
       "      <td>Medium</td>\n",
       "      <td>6118</td>\n",
       "      <td>51</td>\n",
       "      <td>0.008336</td>\n",
       "      <td>312018</td>\n",
       "      <td>...</td>\n",
       "      <td>0.952418</td>\n",
       "      <td>0.664208</td>\n",
       "      <td>7.484138</td>\n",
       "      <td>10.261850</td>\n",
       "      <td>8.441550</td>\n",
       "      <td>0.006423</td>\n",
       "      <td>0.006299</td>\n",
       "      <td>0.006465</td>\n",
       "      <td>0.006379</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>123</th>\n",
       "      <td>1497</td>\n",
       "      <td>WN</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>5456</td>\n",
       "      <td>24</td>\n",
       "      <td>Medium</td>\n",
       "      <td>5456</td>\n",
       "      <td>24</td>\n",
       "      <td>0.004399</td>\n",
       "      <td>130944</td>\n",
       "      <td>...</td>\n",
       "      <td>0.974126</td>\n",
       "      <td>0.877425</td>\n",
       "      <td>8.693971</td>\n",
       "      <td>9.485585</td>\n",
       "      <td>9.015204</td>\n",
       "      <td>0.008895</td>\n",
       "      <td>0.009835</td>\n",
       "      <td>0.008910</td>\n",
       "      <td>0.008958</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>112</th>\n",
       "      <td>1489</td>\n",
       "      <td>PO</td>\n",
       "      <td>binclass</td>\n",
       "      <td>5404</td>\n",
       "      <td>5</td>\n",
       "      <td>Medium</td>\n",
       "      <td>5404</td>\n",
       "      <td>5</td>\n",
       "      <td>0.000925</td>\n",
       "      <td>27020</td>\n",
       "      <td>...</td>\n",
       "      <td>0.982484</td>\n",
       "      <td>0.930798</td>\n",
       "      <td>7.348127</td>\n",
       "      <td>7.747225</td>\n",
       "      <td>7.519823</td>\n",
       "      <td>0.036239</td>\n",
       "      <td>0.036678</td>\n",
       "      <td>0.038387</td>\n",
       "      <td>0.036372</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>116</th>\n",
       "      <td>44158</td>\n",
       "      <td>KU</td>\n",
       "      <td>binclass</td>\n",
       "      <td>5032</td>\n",
       "      <td>45</td>\n",
       "      <td>Medium</td>\n",
       "      <td>5032</td>\n",
       "      <td>45</td>\n",
       "      <td>0.008943</td>\n",
       "      <td>226440</td>\n",
       "      <td>...</td>\n",
       "      <td>3.182232</td>\n",
       "      <td>0.846023</td>\n",
       "      <td>1.887335</td>\n",
       "      <td>10.440562</td>\n",
       "      <td>9.162391</td>\n",
       "      <td>0.011095</td>\n",
       "      <td>0.010074</td>\n",
       "      <td>0.010455</td>\n",
       "      <td>0.010920</td>\n",
       "      <td>6.312500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108</th>\n",
       "      <td>44160</td>\n",
       "      <td>RL</td>\n",
       "      <td>binclass</td>\n",
       "      <td>4970</td>\n",
       "      <td>12</td>\n",
       "      <td>Medium</td>\n",
       "      <td>4970</td>\n",
       "      <td>12</td>\n",
       "      <td>0.002414</td>\n",
       "      <td>59640</td>\n",
       "      <td>...</td>\n",
       "      <td>7.903201</td>\n",
       "      <td>3.025394</td>\n",
       "      <td>4.031265</td>\n",
       "      <td>9.340849</td>\n",
       "      <td>7.184906</td>\n",
       "      <td>0.069265</td>\n",
       "      <td>0.062495</td>\n",
       "      <td>0.066106</td>\n",
       "      <td>0.068209</td>\n",
       "      <td>4.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>114</th>\n",
       "      <td>1043</td>\n",
       "      <td>AA</td>\n",
       "      <td>binclass</td>\n",
       "      <td>4562</td>\n",
       "      <td>48</td>\n",
       "      <td>Medium</td>\n",
       "      <td>4562</td>\n",
       "      <td>48</td>\n",
       "      <td>0.010522</td>\n",
       "      <td>218976</td>\n",
       "      <td>...</td>\n",
       "      <td>5.637599</td>\n",
       "      <td>2.248019</td>\n",
       "      <td>5.027473</td>\n",
       "      <td>10.164384</td>\n",
       "      <td>8.013068</td>\n",
       "      <td>0.014098</td>\n",
       "      <td>0.016584</td>\n",
       "      <td>0.019021</td>\n",
       "      <td>0.014511</td>\n",
       "      <td>2.302326</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>44091</td>\n",
       "      <td>WB</td>\n",
       "      <td>binclass</td>\n",
       "      <td>2554</td>\n",
       "      <td>11</td>\n",
       "      <td>Medium</td>\n",
       "      <td>2554</td>\n",
       "      <td>11</td>\n",
       "      <td>0.004307</td>\n",
       "      <td>28094</td>\n",
       "      <td>...</td>\n",
       "      <td>0.988053</td>\n",
       "      <td>0.895051</td>\n",
       "      <td>7.445447</td>\n",
       "      <td>8.181904</td>\n",
       "      <td>7.754391</td>\n",
       "      <td>0.027774</td>\n",
       "      <td>0.028992</td>\n",
       "      <td>0.027893</td>\n",
       "      <td>0.027770</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>1067</td>\n",
       "      <td>KC</td>\n",
       "      <td>binclass</td>\n",
       "      <td>2109</td>\n",
       "      <td>21</td>\n",
       "      <td>Medium</td>\n",
       "      <td>2109</td>\n",
       "      <td>21</td>\n",
       "      <td>0.009957</td>\n",
       "      <td>44289</td>\n",
       "      <td>...</td>\n",
       "      <td>1.164145</td>\n",
       "      <td>0.624163</td>\n",
       "      <td>3.588363</td>\n",
       "      <td>6.851798</td>\n",
       "      <td>5.673046</td>\n",
       "      <td>0.040282</td>\n",
       "      <td>0.041824</td>\n",
       "      <td>0.041207</td>\n",
       "      <td>0.040410</td>\n",
       "      <td>12.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>93</th>\n",
       "      <td>22</td>\n",
       "      <td>MZ</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>2000</td>\n",
       "      <td>47</td>\n",
       "      <td>Medium</td>\n",
       "      <td>2000</td>\n",
       "      <td>47</td>\n",
       "      <td>0.023500</td>\n",
       "      <td>94000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.990900</td>\n",
       "      <td>0.938450</td>\n",
       "      <td>7.259659</td>\n",
       "      <td>7.825354</td>\n",
       "      <td>7.433892</td>\n",
       "      <td>0.007182</td>\n",
       "      <td>0.007487</td>\n",
       "      <td>0.007203</td>\n",
       "      <td>0.007190</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>92</th>\n",
       "      <td>18</td>\n",
       "      <td>MR</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>2000</td>\n",
       "      <td>6</td>\n",
       "      <td>Medium</td>\n",
       "      <td>2000</td>\n",
       "      <td>6</td>\n",
       "      <td>0.003000</td>\n",
       "      <td>12000</td>\n",
       "      <td>...</td>\n",
       "      <td>6.559389</td>\n",
       "      <td>4.799596</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.154970</td>\n",
       "      <td>0.052490</td>\n",
       "      <td>0.388877</td>\n",
       "      <td>0.390519</td>\n",
       "      <td>0.390137</td>\n",
       "      <td>0.389132</td>\n",
       "      <td>5.333333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75</th>\n",
       "      <td>1504</td>\n",
       "      <td>SPF</td>\n",
       "      <td>binclass</td>\n",
       "      <td>1941</td>\n",
       "      <td>33</td>\n",
       "      <td>Medium</td>\n",
       "      <td>1941</td>\n",
       "      <td>33</td>\n",
       "      <td>0.017002</td>\n",
       "      <td>64053</td>\n",
       "      <td>...</td>\n",
       "      <td>9.678946</td>\n",
       "      <td>1.399774</td>\n",
       "      <td>0.920966</td>\n",
       "      <td>9.257122</td>\n",
       "      <td>7.474365</td>\n",
       "      <td>0.016673</td>\n",
       "      <td>0.016333</td>\n",
       "      <td>0.015812</td>\n",
       "      <td>0.014982</td>\n",
       "      <td>2.111111</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>79</th>\n",
       "      <td>23</td>\n",
       "      <td>CE</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>1473</td>\n",
       "      <td>9</td>\n",
       "      <td>Medium</td>\n",
       "      <td>1473</td>\n",
       "      <td>9</td>\n",
       "      <td>0.006110</td>\n",
       "      <td>13257</td>\n",
       "      <td>...</td>\n",
       "      <td>0.979338</td>\n",
       "      <td>0.979338</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>4.625000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>78</th>\n",
       "      <td>1462</td>\n",
       "      <td>BNB</td>\n",
       "      <td>binclass</td>\n",
       "      <td>1372</td>\n",
       "      <td>4</td>\n",
       "      <td>Medium</td>\n",
       "      <td>1372</td>\n",
       "      <td>4</td>\n",
       "      <td>0.002915</td>\n",
       "      <td>5488</td>\n",
       "      <td>...</td>\n",
       "      <td>0.970643</td>\n",
       "      <td>0.952071</td>\n",
       "      <td>5.104524</td>\n",
       "      <td>5.246705</td>\n",
       "      <td>5.166221</td>\n",
       "      <td>0.134162</td>\n",
       "      <td>0.129542</td>\n",
       "      <td>0.135614</td>\n",
       "      <td>0.133815</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>117</th>\n",
       "      <td>1494</td>\n",
       "      <td>QB</td>\n",
       "      <td>binclass</td>\n",
       "      <td>1055</td>\n",
       "      <td>41</td>\n",
       "      <td>Medium</td>\n",
       "      <td>1055</td>\n",
       "      <td>41</td>\n",
       "      <td>0.038863</td>\n",
       "      <td>43255</td>\n",
       "      <td>...</td>\n",
       "      <td>5.923395</td>\n",
       "      <td>1.356762</td>\n",
       "      <td>0.295407</td>\n",
       "      <td>8.068748</td>\n",
       "      <td>5.578378</td>\n",
       "      <td>0.017894</td>\n",
       "      <td>0.018723</td>\n",
       "      <td>0.017211</td>\n",
       "      <td>0.017675</td>\n",
       "      <td>8.772727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>54</td>\n",
       "      <td>VE</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>846</td>\n",
       "      <td>18</td>\n",
       "      <td>Small</td>\n",
       "      <td>846</td>\n",
       "      <td>18</td>\n",
       "      <td>0.021277</td>\n",
       "      <td>15228</td>\n",
       "      <td>...</td>\n",
       "      <td>1.546961</td>\n",
       "      <td>0.978458</td>\n",
       "      <td>3.676444</td>\n",
       "      <td>6.374832</td>\n",
       "      <td>6.116069</td>\n",
       "      <td>0.031532</td>\n",
       "      <td>0.033523</td>\n",
       "      <td>0.032114</td>\n",
       "      <td>0.031622</td>\n",
       "      <td>13.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>37</td>\n",
       "      <td>PD</td>\n",
       "      <td>binclass</td>\n",
       "      <td>768</td>\n",
       "      <td>8</td>\n",
       "      <td>Small</td>\n",
       "      <td>768</td>\n",
       "      <td>8</td>\n",
       "      <td>0.010417</td>\n",
       "      <td>6144</td>\n",
       "      <td>...</td>\n",
       "      <td>1.632884</td>\n",
       "      <td>0.972542</td>\n",
       "      <td>2.587744</td>\n",
       "      <td>6.907499</td>\n",
       "      <td>5.852805</td>\n",
       "      <td>0.033331</td>\n",
       "      <td>0.038275</td>\n",
       "      <td>0.031516</td>\n",
       "      <td>0.032855</td>\n",
       "      <td>17.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>40981</td>\n",
       "      <td>AT</td>\n",
       "      <td>binclass</td>\n",
       "      <td>690</td>\n",
       "      <td>14</td>\n",
       "      <td>Small</td>\n",
       "      <td>690</td>\n",
       "      <td>14</td>\n",
       "      <td>0.020290</td>\n",
       "      <td>9660</td>\n",
       "      <td>...</td>\n",
       "      <td>8.059000</td>\n",
       "      <td>2.460303</td>\n",
       "      <td>1.045901</td>\n",
       "      <td>6.538735</td>\n",
       "      <td>4.494342</td>\n",
       "      <td>0.042454</td>\n",
       "      <td>0.041536</td>\n",
       "      <td>0.040331</td>\n",
       "      <td>0.040651</td>\n",
       "      <td>4.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>29</td>\n",
       "      <td>CV</td>\n",
       "      <td>binclass</td>\n",
       "      <td>690</td>\n",
       "      <td>15</td>\n",
       "      <td>Small</td>\n",
       "      <td>653</td>\n",
       "      <td>15</td>\n",
       "      <td>0.022971</td>\n",
       "      <td>9795</td>\n",
       "      <td>...</td>\n",
       "      <td>8.041394</td>\n",
       "      <td>2.703408</td>\n",
       "      <td>0.975018</td>\n",
       "      <td>6.469384</td>\n",
       "      <td>4.536188</td>\n",
       "      <td>0.034670</td>\n",
       "      <td>0.058742</td>\n",
       "      <td>0.051038</td>\n",
       "      <td>0.037418</td>\n",
       "      <td>4.444444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>188</td>\n",
       "      <td>EU</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>736</td>\n",
       "      <td>19</td>\n",
       "      <td>Small</td>\n",
       "      <td>641</td>\n",
       "      <td>19</td>\n",
       "      <td>0.029641</td>\n",
       "      <td>12179</td>\n",
       "      <td>...</td>\n",
       "      <td>3.354710</td>\n",
       "      <td>1.881867</td>\n",
       "      <td>0.324295</td>\n",
       "      <td>6.419369</td>\n",
       "      <td>4.340549</td>\n",
       "      <td>0.026244</td>\n",
       "      <td>0.031600</td>\n",
       "      <td>0.032984</td>\n",
       "      <td>0.026249</td>\n",
       "      <td>7.111111</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>1063</td>\n",
       "      <td>KD</td>\n",
       "      <td>binclass</td>\n",
       "      <td>522</td>\n",
       "      <td>21</td>\n",
       "      <td>Small</td>\n",
       "      <td>522</td>\n",
       "      <td>21</td>\n",
       "      <td>0.040230</td>\n",
       "      <td>10962</td>\n",
       "      <td>...</td>\n",
       "      <td>1.370611</td>\n",
       "      <td>0.647422</td>\n",
       "      <td>2.858916</td>\n",
       "      <td>5.793396</td>\n",
       "      <td>4.842122</td>\n",
       "      <td>0.041733</td>\n",
       "      <td>0.042080</td>\n",
       "      <td>0.042139</td>\n",
       "      <td>0.041438</td>\n",
       "      <td>8.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>59</td>\n",
       "      <td>IO</td>\n",
       "      <td>binclass</td>\n",
       "      <td>351</td>\n",
       "      <td>34</td>\n",
       "      <td>Small</td>\n",
       "      <td>351</td>\n",
       "      <td>34</td>\n",
       "      <td>0.096866</td>\n",
       "      <td>11934</td>\n",
       "      <td>...</td>\n",
       "      <td>inf</td>\n",
       "      <td>inf</td>\n",
       "      <td>0.969431</td>\n",
       "      <td>5.309034</td>\n",
       "      <td>4.876570</td>\n",
       "      <td>0.009632</td>\n",
       "      <td>0.011244</td>\n",
       "      <td>0.010742</td>\n",
       "      <td>0.009407</td>\n",
       "      <td>1.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>49</td>\n",
       "      <td>HC</td>\n",
       "      <td>binclass</td>\n",
       "      <td>303</td>\n",
       "      <td>13</td>\n",
       "      <td>Small</td>\n",
       "      <td>296</td>\n",
       "      <td>13</td>\n",
       "      <td>0.043919</td>\n",
       "      <td>3848</td>\n",
       "      <td>...</td>\n",
       "      <td>4.694184</td>\n",
       "      <td>2.165703</td>\n",
       "      <td>0.961580</td>\n",
       "      <td>5.117375</td>\n",
       "      <td>3.783160</td>\n",
       "      <td>0.047563</td>\n",
       "      <td>0.061382</td>\n",
       "      <td>0.075153</td>\n",
       "      <td>0.049988</td>\n",
       "      <td>2.875000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>53</td>\n",
       "      <td>HT</td>\n",
       "      <td>binclass</td>\n",
       "      <td>270</td>\n",
       "      <td>13</td>\n",
       "      <td>Small</td>\n",
       "      <td>270</td>\n",
       "      <td>13</td>\n",
       "      <td>0.048148</td>\n",
       "      <td>3510</td>\n",
       "      <td>...</td>\n",
       "      <td>4.614099</td>\n",
       "      <td>2.161253</td>\n",
       "      <td>0.864205</td>\n",
       "      <td>5.075282</td>\n",
       "      <td>3.628980</td>\n",
       "      <td>0.056301</td>\n",
       "      <td>0.052270</td>\n",
       "      <td>0.055753</td>\n",
       "      <td>0.051523</td>\n",
       "      <td>2.875000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>4153</td>\n",
       "      <td>RH</td>\n",
       "      <td>multiclass</td>\n",
       "      <td>180</td>\n",
       "      <td>66</td>\n",
       "      <td>Small</td>\n",
       "      <td>180</td>\n",
       "      <td>66</td>\n",
       "      <td>0.366667</td>\n",
       "      <td>11880</td>\n",
       "      <td>...</td>\n",
       "      <td>0.944277</td>\n",
       "      <td>0.809019</td>\n",
       "      <td>4.033106</td>\n",
       "      <td>4.804726</td>\n",
       "      <td>4.482422</td>\n",
       "      <td>0.010670</td>\n",
       "      <td>0.011191</td>\n",
       "      <td>0.011885</td>\n",
       "      <td>0.010695</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>36 rows × 43 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id dataname    tasktype  num_raw_data  num_raw_features datasize  \\\n",
       "196     1503      SAD  multiclass        263256                14    Large   \n",
       "189    40922       RW    binclass         88588                 6    Large   \n",
       "158    41168       JM  multiclass         83733                54    Large   \n",
       "141    44131       JN    binclass         57580                54    Large   \n",
       "165    45714       PC  multiclass         35300                 5    Large   \n",
       "159    44090      CAB    binclass         20634                 8    Large   \n",
       "176    44123      HOB    binclass         13488                16    Large   \n",
       "146    44125       MT    binclass         13376                10    Large   \n",
       "138    44126       BM    binclass         10578                 7    Large   \n",
       "137     1459       AC  multiclass         10218                 7    Large   \n",
       "133    45062       CH    binclass         10000                10    Large   \n",
       "132    44157       EM    binclass          7608                23   Medium   \n",
       "128     1475       FT  multiclass          6118                51   Medium   \n",
       "123     1497       WN  multiclass          5456                24   Medium   \n",
       "112     1489       PO    binclass          5404                 5   Medium   \n",
       "116    44158       KU    binclass          5032                45   Medium   \n",
       "108    44160       RL    binclass          4970                12   Medium   \n",
       "114     1043       AA    binclass          4562                48   Medium   \n",
       "98     44091       WB    binclass          2554                11   Medium   \n",
       "95      1067       KC    binclass          2109                21   Medium   \n",
       "93        22       MZ  multiclass          2000                47   Medium   \n",
       "92        18       MR  multiclass          2000                 6   Medium   \n",
       "75      1504      SPF    binclass          1941                33   Medium   \n",
       "79        23       CE  multiclass          1473                 9   Medium   \n",
       "78      1462      BNB    binclass          1372                 4   Medium   \n",
       "117     1494       QB    binclass          1055                41   Medium   \n",
       "55        54       VE  multiclass           846                18    Small   \n",
       "59        37       PD    binclass           768                 8    Small   \n",
       "52     40981       AT    binclass           690                14    Small   \n",
       "51        29       CV    binclass           690                15    Small   \n",
       "47       188       EU  multiclass           736                19    Small   \n",
       "33      1063       KD    binclass           522                21    Small   \n",
       "31        59       IO    binclass           351                34    Small   \n",
       "24        49       HC    binclass           303                13    Small   \n",
       "22        53       HT    binclass           270                13    Small   \n",
       "15      4153       RH  multiclass           180                66    Small   \n",
       "\n",
       "     num_prep_data  num_prep_features  feature_sample_ratio  num_prep_cells  \\\n",
       "196         263256                 14              0.000053         3685584   \n",
       "189          88588                  6              0.000068          531528   \n",
       "158          83733                 54              0.000645         4521582   \n",
       "141          57580                 54              0.000938         3109320   \n",
       "165          35300                  5              0.000142          176500   \n",
       "159          20634                  8              0.000388          165072   \n",
       "176          13488                 16              0.001186          215808   \n",
       "146          13376                 10              0.000748          133760   \n",
       "138          10578                  7              0.000662           74046   \n",
       "137          10218                  7              0.000685           71526   \n",
       "133          10000                 10              0.001000          100000   \n",
       "132           7608                 23              0.003023          174984   \n",
       "128           6118                 51              0.008336          312018   \n",
       "123           5456                 24              0.004399          130944   \n",
       "112           5404                  5              0.000925           27020   \n",
       "116           5032                 45              0.008943          226440   \n",
       "108           4970                 12              0.002414           59640   \n",
       "114           4562                 48              0.010522          218976   \n",
       "98            2554                 11              0.004307           28094   \n",
       "95            2109                 21              0.009957           44289   \n",
       "93            2000                 47              0.023500           94000   \n",
       "92            2000                  6              0.003000           12000   \n",
       "75            1941                 33              0.017002           64053   \n",
       "79            1473                  9              0.006110           13257   \n",
       "78            1372                  4              0.002915            5488   \n",
       "117           1055                 41              0.038863           43255   \n",
       "55             846                 18              0.021277           15228   \n",
       "59             768                  8              0.010417            6144   \n",
       "52             690                 14              0.020290            9660   \n",
       "51             653                 15              0.022971            9795   \n",
       "47             641                 19              0.029641           12179   \n",
       "33             522                 21              0.040230           10962   \n",
       "31             351                 34              0.096866           11934   \n",
       "24             296                 13              0.043919            3848   \n",
       "22             270                 13              0.048148            3510   \n",
       "15             180                 66              0.366667           11880   \n",
       "\n",
       "     ...  entropy_indv_max  entropy_indv_avg  entropy_cond_min  \\\n",
       "196  ...          0.967896          0.938514         14.368732   \n",
       "189  ...          0.854431          0.633366          7.509057   \n",
       "158  ...          0.996981          0.882752         12.719671   \n",
       "141  ...          0.998600          0.883499         12.174075   \n",
       "165  ...          0.999539          0.967325          5.743618   \n",
       "159  ...          0.984875          0.743260         10.235487   \n",
       "176  ...          0.973481          0.709948         10.162462   \n",
       "146  ...          0.978796          0.872625         10.058919   \n",
       "138  ...          0.989800          0.689867          9.015195   \n",
       "137  ...          1.081121          0.947669          7.871872   \n",
       "133  ...          0.999433          0.933223          8.302845   \n",
       "132  ...         10.588738          1.671726          1.982541   \n",
       "128  ...          0.952418          0.664208          7.484138   \n",
       "123  ...          0.974126          0.877425          8.693971   \n",
       "112  ...          0.982484          0.930798          7.348127   \n",
       "116  ...          3.182232          0.846023          1.887335   \n",
       "108  ...          7.903201          3.025394          4.031265   \n",
       "114  ...          5.637599          2.248019          5.027473   \n",
       "98   ...          0.988053          0.895051          7.445447   \n",
       "95   ...          1.164145          0.624163          3.588363   \n",
       "93   ...          0.990900          0.938450          7.259659   \n",
       "92   ...          6.559389          4.799596          0.000000   \n",
       "75   ...          9.678946          1.399774          0.920966   \n",
       "79   ...          0.979338          0.979338          0.000000   \n",
       "78   ...          0.970643          0.952071          5.104524   \n",
       "117  ...          5.923395          1.356762          0.295407   \n",
       "55   ...          1.546961          0.978458          3.676444   \n",
       "59   ...          1.632884          0.972542          2.587744   \n",
       "52   ...          8.059000          2.460303          1.045901   \n",
       "51   ...          8.041394          2.703408          0.975018   \n",
       "47   ...          3.354710          1.881867          0.324295   \n",
       "33   ...          1.370611          0.647422          2.858916   \n",
       "31   ...               inf               inf          0.969431   \n",
       "24   ...          4.694184          2.165703          0.961580   \n",
       "22   ...          4.614099          2.161253          0.864205   \n",
       "15   ...          0.944277          0.809019          4.033106   \n",
       "\n",
       "     entropy_cond_max  entropy_cond_avg  cor_train   cor_val  cor_test  \\\n",
       "196         14.657270         14.466336   0.020958  0.021205  0.021170   \n",
       "189          9.097907          8.243417   0.034408  0.034453  0.034068   \n",
       "158         14.061614         13.099133   0.002941  0.002913  0.002952   \n",
       "141         13.463155         12.556432   0.002914  0.002917  0.002891   \n",
       "165          6.119234          5.850630   0.118204  0.117428  0.118379   \n",
       "159         12.145199         11.038115   0.034812  0.035018  0.034972   \n",
       "176         12.507682         11.037899   0.015384  0.015054  0.015281   \n",
       "146         10.897994         10.411612   0.040798  0.041756  0.041031   \n",
       "138         10.826738         10.011551   0.019449  0.020207  0.019498   \n",
       "137          8.223680          8.025155   0.056897  0.055597  0.058551   \n",
       "133          8.794209          8.522789   0.003907  0.012596  0.010023   \n",
       "132         11.480322          9.399735   0.012674  0.014052  0.013553   \n",
       "128         10.261850          8.441550   0.006423  0.006299  0.006465   \n",
       "123          9.485585          9.015204   0.008895  0.009835  0.008910   \n",
       "112          7.747225          7.519823   0.036239  0.036678  0.038387   \n",
       "116         10.440562          9.162391   0.011095  0.010074  0.010455   \n",
       "108          9.340849          7.184906   0.069265  0.062495  0.066106   \n",
       "114         10.164384          8.013068   0.014098  0.016584  0.019021   \n",
       "98           8.181904          7.754391   0.027774  0.028992  0.027893   \n",
       "95           6.851798          5.673046   0.040282  0.041824  0.041207   \n",
       "93           7.825354          7.433892   0.007182  0.007487  0.007203   \n",
       "92           0.154970          0.052490   0.388877  0.390519  0.390137   \n",
       "75           9.257122          7.474365   0.016673  0.016333  0.015812   \n",
       "79           0.000000          0.000000        NaN       NaN       NaN   \n",
       "78           5.246705          5.166221   0.134162  0.129542  0.135614   \n",
       "117          8.068748          5.578378   0.017894  0.018723  0.017211   \n",
       "55           6.374832          6.116069   0.031532  0.033523  0.032114   \n",
       "59           6.907499          5.852805   0.033331  0.038275  0.031516   \n",
       "52           6.538735          4.494342   0.042454  0.041536  0.040331   \n",
       "51           6.469384          4.536188   0.034670  0.058742  0.051038   \n",
       "47           6.419369          4.340549   0.026244  0.031600  0.032984   \n",
       "33           5.793396          4.842122   0.041733  0.042080  0.042139   \n",
       "31           5.309034          4.876570   0.009632  0.011244  0.010742   \n",
       "24           5.117375          3.783160   0.047563  0.061382  0.075153   \n",
       "22           5.075282          3.628980   0.056301  0.052270  0.055753   \n",
       "15           4.804726          4.482422   0.010670  0.011191  0.011885   \n",
       "\n",
       "     cor_full  avg_cardinality  \n",
       "196  0.021003         2.000000  \n",
       "189  0.034350         0.000000  \n",
       "158  0.002937         0.000000  \n",
       "141  0.002908         0.000000  \n",
       "165  0.118138        10.000000  \n",
       "159  0.034702         0.000000  \n",
       "176  0.015275         0.000000  \n",
       "146  0.040860         0.000000  \n",
       "138  0.019434         0.000000  \n",
       "137  0.056895         8.000000  \n",
       "133  0.003860         4.000000  \n",
       "132  0.012829         5.200000  \n",
       "128  0.006379         0.000000  \n",
       "123  0.008958         0.000000  \n",
       "112  0.036372         0.000000  \n",
       "116  0.010920         6.312500  \n",
       "108  0.068209         4.714286  \n",
       "114  0.014511         2.302326  \n",
       "98   0.027770         0.000000  \n",
       "95   0.040410        12.000000  \n",
       "93   0.007190         0.000000  \n",
       "92   0.389132         5.333333  \n",
       "75   0.014982         2.111111  \n",
       "79   0.000000         4.625000  \n",
       "78   0.133815         0.000000  \n",
       "117  0.017675         8.772727  \n",
       "55   0.031622        13.000000  \n",
       "59   0.032855        17.000000  \n",
       "52   0.040651         4.500000  \n",
       "51   0.037418         4.444444  \n",
       "47   0.026249         7.111111  \n",
       "33   0.041438         8.000000  \n",
       "31   0.009407         1.500000  \n",
       "24   0.049988         2.875000  \n",
       "22   0.051523         2.875000  \n",
       "15   0.010695         0.000000  \n",
       "\n",
       "[36 rows x 43 columns]"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d2 = [d for d in datalist if d not in excl]\n",
    "info = pd.read_csv(\"/home/tabsemi_v2/results/benchmark_stats.csv\", index_col=0)\n",
    "info[info[\"data_id\"].isin(d2)].sort_values(\"num_prep_data\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b407c21d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5f779ab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "489b70ff",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>4284</th>\n",
       "      <td>1503</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.101478</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3512</th>\n",
       "      <td>1475</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.255637</td>\n",
       "      <td>10</td>\n",
       "      <td>12.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3018</th>\n",
       "      <td>1459</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.319276</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6092</th>\n",
       "      <td>41168</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.398346</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1783</th>\n",
       "      <td>188</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.402326</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>459</th>\n",
       "      <td>23</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.464407</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7505</th>\n",
       "      <td>44160</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.505835</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7335</th>\n",
       "      <td>44157</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.511170</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7590</th>\n",
       "      <td>44161</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.512191</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1370</th>\n",
       "      <td>54</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.561176</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7420</th>\n",
       "      <td>44158</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.563357</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4369</th>\n",
       "      <td>1504</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.570951</td>\n",
       "      <td>10</td>\n",
       "      <td>11.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4199</th>\n",
       "      <td>1497</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.584066</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7837</th>\n",
       "      <td>45062</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.589450</td>\n",
       "      <td>10</td>\n",
       "      <td>10.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1285</th>\n",
       "      <td>53</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.609259</td>\n",
       "      <td>10</td>\n",
       "      <td>10.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>374</th>\n",
       "      <td>22</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.610750</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>544</th>\n",
       "      <td>29</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.619847</td>\n",
       "      <td>10</td>\n",
       "      <td>13.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6748</th>\n",
       "      <td>44091</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.622505</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7250</th>\n",
       "      <td>44131</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.635524</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2763</th>\n",
       "      <td>1043</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.637788</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6663</th>\n",
       "      <td>44090</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.640950</td>\n",
       "      <td>10</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3921</th>\n",
       "      <td>1489</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.650694</td>\n",
       "      <td>10</td>\n",
       "      <td>9.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2933</th>\n",
       "      <td>1067</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.652133</td>\n",
       "      <td>10</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1119</th>\n",
       "      <td>49</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.655000</td>\n",
       "      <td>10</td>\n",
       "      <td>15.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7080</th>\n",
       "      <td>44125</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.664013</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6914</th>\n",
       "      <td>44123</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.664678</td>\n",
       "      <td>10</td>\n",
       "      <td>9.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>953</th>\n",
       "      <td>37</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.666234</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5517</th>\n",
       "      <td>40981</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.671739</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4114</th>\n",
       "      <td>1494</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.672986</td>\n",
       "      <td>10</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7165</th>\n",
       "      <td>44126</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.675898</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>289</th>\n",
       "      <td>18</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.680000</td>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2848</th>\n",
       "      <td>1063</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.702857</td>\n",
       "      <td>10</td>\n",
       "      <td>10.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1455</th>\n",
       "      <td>59</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.769014</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8084</th>\n",
       "      <td>45714</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.772195</td>\n",
       "      <td>10</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5432</th>\n",
       "      <td>40922</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.818072</td>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4940</th>\n",
       "      <td>4153</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.922222</td>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3103</th>\n",
       "      <td>1462</td>\n",
       "      <td>5</td>\n",
       "      <td>sslbinshuffling-lr</td>\n",
       "      <td>0.931636</td>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      data_id  shots               model  acc_mean  acc_count  rank\n",
       "4284     1503      5  sslbinshuffling-lr  0.101478         10   2.0\n",
       "3512     1475      5  sslbinshuffling-lr  0.255637         10  12.0\n",
       "3018     1459      5  sslbinshuffling-lr  0.319276         10   4.0\n",
       "6092    41168      5  sslbinshuffling-lr  0.398346         10   1.0\n",
       "1783      188      5  sslbinshuffling-lr  0.402326         10   3.0\n",
       "459        23      5  sslbinshuffling-lr  0.464407         10   1.0\n",
       "7505    44160      5  sslbinshuffling-lr  0.505835         10   8.0\n",
       "7335    44157      5  sslbinshuffling-lr  0.511170         10   3.0\n",
       "7590    44161      5  sslbinshuffling-lr  0.512191         10   8.0\n",
       "1370       54      5  sslbinshuffling-lr  0.561176         10   1.0\n",
       "7420    44158      5  sslbinshuffling-lr  0.563357         10   1.0\n",
       "4369     1504      5  sslbinshuffling-lr  0.570951         10  11.0\n",
       "4199     1497      5  sslbinshuffling-lr  0.584066         10   6.0\n",
       "7837    45062      5  sslbinshuffling-lr  0.589450         10  10.0\n",
       "1285       53      5  sslbinshuffling-lr  0.609259         10  10.0\n",
       "374        22      5  sslbinshuffling-lr  0.610750         10   1.0\n",
       "544        29      5  sslbinshuffling-lr  0.619847         10  13.0\n",
       "6748    44091      5  sslbinshuffling-lr  0.622505         10   2.0\n",
       "7250    44131      5  sslbinshuffling-lr  0.635524         10   2.0\n",
       "2763     1043      5  sslbinshuffling-lr  0.637788         10   6.0\n",
       "6663    44090      5  sslbinshuffling-lr  0.640950         10   7.0\n",
       "3921     1489      5  sslbinshuffling-lr  0.650694         10   9.0\n",
       "2933     1067      5  sslbinshuffling-lr  0.652133         10   7.0\n",
       "1119       49      5  sslbinshuffling-lr  0.655000         10  15.0\n",
       "7080    44125      5  sslbinshuffling-lr  0.664013         10   6.0\n",
       "6914    44123      5  sslbinshuffling-lr  0.664678         10   9.0\n",
       "953        37      5  sslbinshuffling-lr  0.666234         10   6.0\n",
       "5517    40981      5  sslbinshuffling-lr  0.671739         10   8.0\n",
       "4114     1494      5  sslbinshuffling-lr  0.672986         10   8.0\n",
       "7165    44126      5  sslbinshuffling-lr  0.675898         10   4.0\n",
       "289        18      5  sslbinshuffling-lr  0.680000         10   3.0\n",
       "2848     1063      5  sslbinshuffling-lr  0.702857         10  10.0\n",
       "1455       59      5  sslbinshuffling-lr  0.769014         10   2.0\n",
       "8084    45714      5  sslbinshuffling-lr  0.772195         10   6.0\n",
       "5432    40922      5  sslbinshuffling-lr  0.818072         10   4.0\n",
       "4940     4153      5  sslbinshuffling-lr  0.922222         10   1.0\n",
       "3103     1462      5  sslbinshuffling-lr  0.931636         10   2.0"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[(q[\"shots\"] == 5) & (q[\"model\"] == \"sslbinshuffling-lr\") & ~(q[\"data_id\"].isin(excl))].sort_values(\"acc_mean\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d207809",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "60a4b631",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lr\n",
      "48.296$\\pm$15.413 & 8.905$\\pm$4.74 & 0 & 57.274$\\pm$17.298 & 9.095$\\pm$6.055 & 0 &  \n",
      "knn\n",
      "48.916$\\pm$14.26 & 8.571$\\pm$3.698 & 0 & 53.96$\\pm$15.896 & 14.667$\\pm$5.432 & 0 &  \n",
      "xgboost\n",
      "41.406$\\pm$23.454 & 16.214$\\pm$9.39 & 9 & 57.294$\\pm$14.932 & 12.381$\\pm$6.81 & 2 &  \n",
      "catboost\n",
      "48.573$\\pm$16.201 & 9.19$\\pm$6.677 & 6 & 59.21$\\pm$18.109 & 9.571$\\pm$6.455 & 3 &  \n",
      "lightgbm\n",
      "41.786$\\pm$22.917 & 16.143$\\pm$9.349 & 9 & 50.36$\\pm$19.653 & 17.405$\\pm$9.098 & 5 &  \n",
      "mlp\n",
      "48.374$\\pm$15.276 & 8.833$\\pm$3.872 & 0 & 57.651$\\pm$17.348 & 10.643$\\pm$5.051 & 0 &  \n",
      "sslrecon-lr\n",
      "33.226$\\pm$16.682 & 23.333$\\pm$4.179 & 0 & 32.79$\\pm$17.134 & 25.286$\\pm$1.402 & 0 &  \n",
      "sslbinning-lr\n",
      "34.859$\\pm$16.864 & 23.452$\\pm$2.745 & 0 & 33.706$\\pm$17.094 & 24.595$\\pm$2.247 & 0 &  \n",
      "sslsubtab-lr\n",
      "36.02$\\pm$17.277 & 22.095$\\pm$4.179 & 0 & 36.586$\\pm$18.193 & 23.786$\\pm$2.512 & 0 &  \n",
      "sslvime-lr\n",
      "35.054$\\pm$17.339 & 22.595$\\pm$4.123 & 0 & 35.777$\\pm$17.754 & 23.333$\\pm$3.649 & 0 &  \n",
      "sslscarf-lr\n",
      "48.118$\\pm$14.305 & 11.429$\\pm$5.043 & 0 & 58.904$\\pm$15.72 & 10.667$\\pm$4.926 & 2 &  \n",
      "sslmasking-lr\n",
      "48.372$\\pm$14.861 & 10.119$\\pm$4.414 & 0 & 56.564$\\pm$17.242 & 13.357$\\pm$5.66 & 1 &  \n",
      "sslshuffling-lr\n",
      "48.794$\\pm$14.582 & 10.048$\\pm$4.593 & 1 & 59.388$\\pm$15.825 & 9.595$\\pm$5.169 & 1 &  \n",
      "sslnoisemasking-lr\n",
      "48.903$\\pm$14.452 & 9.69$\\pm$5.129 & 0 & 59.503$\\pm$15.929 & 9.286$\\pm$4.968 & 0 &  \n",
      "sslrq-lr\n",
      "46.641$\\pm$15.656 & 12.738$\\pm$4.629 & 0 & 55.61$\\pm$18.265 & 12.19$\\pm$5.721 & 2 &  \n",
      "sslbinsampling-lr\n",
      "51.267$\\pm$14.953 & 4.333$\\pm$2.436 & 4 & 61.198$\\pm$16.135 & 5.5$\\pm$3.868 & 3 &  \n",
      "sslbinshuffling-lr\n",
      "52.087$\\pm$15.165 & 2.643$\\pm$1.81 & 14 & 61.227$\\pm$16.294 & 5.524$\\pm$3.756 & 8 &  \n",
      "semivime\n",
      "41.546$\\pm$13.826 & 19.119$\\pm$6.31 & 0 & 51.158$\\pm$14.729 & 17.5$\\pm$6.142 & 1 &  \n",
      "ae\n",
      "47.593$\\pm$15.847 & 10.429$\\pm$5.737 & 1 & 56.67$\\pm$18.044 & 11.571$\\pm$5.766 & 1 &  \n",
      "ict\n",
      "44.83$\\pm$13.689 & 14.571$\\pm$6.673 & 1 & 50.646$\\pm$18.461 & 16.238$\\pm$6.782 & 1 &  \n",
      "meanteacher\n",
      "45.479$\\pm$13.826 & 14.5$\\pm$6.437 & 1 & 54.424$\\pm$15.659 & 14.762$\\pm$5.719 & 1 &  \n",
      "pseudolabel-masking\n",
      "44.514$\\pm$13.733 & 16.69$\\pm$5.064 & 0 & 54.843$\\pm$17.286 & 13.31$\\pm$5.203 & 0 &  \n",
      "pseudolabel-shuffling\n",
      "43.621$\\pm$14.771 & 18.071$\\pm$5.565 & 0 & 52.921$\\pm$17.501 & 15.595$\\pm$6.253 & 0 &  \n",
      "pseudolabel-noisemasking\n",
      "43.544$\\pm$14.948 & 18.048$\\pm$6.245 & 0 & 52.989$\\pm$17.277 & 15.548$\\pm$5.547 & 0 &  \n",
      "pseudolabel-rq\n",
      "44.657$\\pm$14.94 & 16.024$\\pm$6.319 & 1 & 53.667$\\pm$17.736 & 14.238$\\pm$6.023 & 1 &  \n",
      "stunt\n",
      "46.367$\\pm$14.823 & 13.714$\\pm$5.138 & 1 & 53.914$\\pm$16.466 & 12.833$\\pm$8.138 & 3 &  \n",
      "tabpfn\n",
      "42.387$\\pm$20.109 & 14.119$\\pm$7.847 & 3 & 54.209$\\pm$25.247 & 8.405$\\pm$8.474 & 7 &  \n"
     ]
    }
   ],
   "source": [
    "pd.set_option('display.max_rows', None)\n",
    "# s = 1\n",
    "# q[q[\"shots\"] == 1].groupby([\"model\"]).mean(\"rank\", \"acc_mean\")#.sort_values([\"shots\", \"rank\"])\n",
    "for m in [\n",
    "    \"lr\", \"knn\", \"xgboost\", \"catboost\", \"lightgbm\", \"mlp\", \"sslrecon-lr\", \"sslbinning-lr\", \"sslsubtab-lr\",\n",
    "    \"sslvime-lr\", \"sslscarf-lr\", \"sslmasking-lr\", \"sslshuffling-lr\", \"sslnoisemasking-lr\",\n",
    "    \"sslrq-lr\", \"sslbinsampling-lr\", \"sslbinshuffling-lr\", \"semivime\", \"ae\", \"ict\",\n",
    "    \"meanteacher\", \"pseudolabel-masking\", \"pseudolabel-shuffling\", \"pseudolabel-noisemasking\",\n",
    "    \"pseudolabel-rq\", \"stunt\", \"tabpfn\"\n",
    "]:\n",
    "    print(m)\n",
    "    for s in [1, 5]:\n",
    "        print(np.round(np.mean(q[(q[\"shots\"] == s) & (q[\"model\"] == m)][\"acc_mean\"] * 100), 3), end=\"$\\pm$\")\n",
    "        print(np.round(np.std(q[(q[\"shots\"] == s) & (q[\"model\"] == m)][\"acc_mean\"] * 100), 3), end=\" & \")\n",
    "        print(np.round(np.mean(q[(q[\"shots\"] == s) & (q[\"model\"] == m)][\"rank\"]), 3), end=\"$\\pm$\")\n",
    "        print(np.round(np.std(q[(q[\"shots\"] == s) & (q[\"model\"] == m)][\"rank\"]), 3), end=\" & \")\n",
    "        print(len(q[(q[\"shots\"] == s) & (q[\"model\"] == m) & (q[\"rank\"] == 1)]), end=\" & \")\n",
    "    print(\" \")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "43bd3d1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "clist2 = [c for c in clist if (not c.startswith(\"ssl\") or c.endswith(\"-lr\"))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "947113ec",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [data_id, shots, model, acc_mean, acc_count, rank]\n",
       "Index: []"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "1f0e5412",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'22 54 1063 1067 12 18 23 59 188 307 1043 1459 1475 1489 1492 1497 1503 4153 40499 44125 44131 45062 44157 1462 44160 29 37 53 49 1504 1494 41143 44126 40981 41168 44091 44158 44123 44090 40922 44161 45714'"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\" \".join(map(str, datalist))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ad0319a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c7f1f4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68ed0ffa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fa5a67c8",
   "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>data_id</th>\n",
       "      <th>num_class</th>\n",
       "      <th>train_samples</th>\n",
       "      <th>features</th>\n",
       "      <th>cat</th>\n",
       "      <th>num</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>22</td>\n",
       "      <td>10</td>\n",
       "      <td>1600</td>\n",
       "      <td>47</td>\n",
       "      <td>0</td>\n",
       "      <td>47</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>54</td>\n",
       "      <td>4</td>\n",
       "      <td>676</td>\n",
       "      <td>18</td>\n",
       "      <td>1</td>\n",
       "      <td>17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1063</td>\n",
       "      <td>2</td>\n",
       "      <td>417</td>\n",
       "      <td>21</td>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1067</td>\n",
       "      <td>2</td>\n",
       "      <td>1687</td>\n",
       "      <td>21</td>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>1600</td>\n",
       "      <td>216</td>\n",
       "      <td>22</td>\n",
       "      <td>194</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   data_id  num_class  train_samples  features  cat  num\n",
       "0       22         10           1600        47    0   47\n",
       "1       54          4            676        18    1   17\n",
       "2     1063          2            417        21    1   20\n",
       "3     1067          2           1687        21    1   20\n",
       "4       12         10           1600       216   22  194"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "datainfo = pd.read_csv(\"data_info.csv\", index_col=0)\n",
    "datainfo.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fe22dc0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "z = rankdata.groupby([\"data_id\", \"shots\"]).agg(\n",
    "    acc_max=('acc_mean', 'max'), acc_min=('acc_mean', 'min')).reset_index()\n",
    "rankdata = rankdata.merge(z, on=['data_id', 'shots'], how='left')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6f4bc0ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "rankdata[\"acc_norm\"] = (rankdata[\"acc_mean\"] - rankdata[\"acc_min\"]) / (rankdata[\"acc_max\"] - rankdata[\"acc_min\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "55c787c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pd.set_option('display.max_rows', None)\n",
    "# for m in clist2:\n",
    "#     print(m)\n",
    "#     print(np.round(np.mean(rankdata[(rankdata[\"shots\"] == 1) & (rankdata[\"model\"] == m)][\"acc_norm\"] * 100), 3), end=\"$\\pm$\")\n",
    "#     print(np.round(np.std(rankdata[(rankdata[\"shots\"] == 1) & (rankdata[\"model\"] == m)][\"acc_norm\"] * 100), 3), end=\" & \")\n",
    "# #     print(np.round(np.mean(q[(q[\"shots\"] == 1) & (q[\"model\"] == m)][\"rank\"]), 3), end=\"$\\pm$\")\n",
    "# #     print(np.round(np.std(q[(q[\"shots\"] == 1) & (q[\"model\"] == m)][\"rank\"]), 3), end=\" & \")\n",
    "# #     print(len(q[(q[\"shots\"] == 5) & (q[\"model\"] == m) & (q[\"rank\"] == 1)]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "484daf58",
   "metadata": {},
   "outputs": [],
   "source": [
    "rankdata = rankdata.merge(datainfo, on=\"data_id\", how=\"left\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "608d6c52",
   "metadata": {},
   "outputs": [],
   "source": [
    "rankdata[\"labeled\"] = rankdata[\"shots\"] * rankdata[\"num_class\"]\n",
    "rankdata[\"unlabeled\"] = rankdata[\"train_samples\"] - rankdata[\"labeled\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "e07256fa",
   "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>data_id</th>\n",
       "      <th>shots</th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_count</th>\n",
       "      <th>rank</th>\n",
       "      <th>acc_max</th>\n",
       "      <th>acc_min</th>\n",
       "      <th>acc_norm</th>\n",
       "      <th>num_class</th>\n",
       "      <th>train_samples</th>\n",
       "      <th>features</th>\n",
       "      <th>cat</th>\n",
       "      <th>num</th>\n",
       "      <th>labeled</th>\n",
       "      <th>unlabeled</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>ae</td>\n",
       "      <td>0.56475</td>\n",
       "      <td>10</td>\n",
       "      <td>24.0</td>\n",
       "      <td>0.688</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.820858</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1600.0</td>\n",
       "      <td>216.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>194.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1590.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>catboost</td>\n",
       "      <td>0.50925</td>\n",
       "      <td>10</td>\n",
       "      <td>27.0</td>\n",
       "      <td>0.688</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.740189</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1600.0</td>\n",
       "      <td>216.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>194.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1590.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>ict</td>\n",
       "      <td>0.49850</td>\n",
       "      <td>10</td>\n",
       "      <td>28.0</td>\n",
       "      <td>0.688</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.724564</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1600.0</td>\n",
       "      <td>216.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>194.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1590.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>knn</td>\n",
       "      <td>0.63500</td>\n",
       "      <td>10</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.688</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.922965</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1600.0</td>\n",
       "      <td>216.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>194.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1590.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>lightgbm</td>\n",
       "      <td>0.10100</td>\n",
       "      <td>10</td>\n",
       "      <td>46.0</td>\n",
       "      <td>0.688</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.146802</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1600.0</td>\n",
       "      <td>216.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>194.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1590.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   data_id  shots     model  acc_mean  acc_count  rank  acc_max  acc_min  \\\n",
       "0       12      1        ae   0.56475         10  24.0    0.688      0.0   \n",
       "1       12      1  catboost   0.50925         10  27.0    0.688      0.0   \n",
       "2       12      1       ict   0.49850         10  28.0    0.688      0.0   \n",
       "3       12      1       knn   0.63500         10  10.0    0.688      0.0   \n",
       "4       12      1  lightgbm   0.10100         10  46.0    0.688      0.0   \n",
       "\n",
       "   acc_norm  num_class  train_samples  features   cat    num  labeled  \\\n",
       "0  0.820858       10.0         1600.0     216.0  22.0  194.0     10.0   \n",
       "1  0.740189       10.0         1600.0     216.0  22.0  194.0     10.0   \n",
       "2  0.724564       10.0         1600.0     216.0  22.0  194.0     10.0   \n",
       "3  0.922965       10.0         1600.0     216.0  22.0  194.0     10.0   \n",
       "4  0.146802       10.0         1600.0     216.0  22.0  194.0     10.0   \n",
       "\n",
       "   unlabeled  \n",
       "0     1590.0  \n",
       "1     1590.0  \n",
       "2     1590.0  \n",
       "3     1590.0  \n",
       "4     1590.0  "
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "acf96118",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "q = rankdata[rankdata[\"model\"] == 'sslbinsampling-lr']\n",
    "# plt.scatter(q[\"num\"]/q[\"features\"], q[\"unlabeled\"]/q[\"labeled\"], c=q[\"acc_norm\"])\n",
    "plt.figure(figsize=(5, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid()\n",
    "plt.scatter(q[\"num\"]/q[\"features\"], q[\"unlabeled\"]/q[\"labeled\"], c=q[\"rank\"], vmin=1, vmax=25, cmap=\"coolwarm\")\n",
    "plt.yscale('log')\n",
    "plt.xlim(0, 1.05)\n",
    "plt.xlabel(\"Ratio of Numerical Features\", fontsize=12)\n",
    "plt.xticks(fontsize=11)\n",
    "plt.ylabel(\"Ratio of Unlabeled Samples\", fontsize=12)\n",
    "plt.yticks(fontsize=11)\n",
    "plt.colorbar()\n",
    "plt.savefig(\"binsampling.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "249a839e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6da06692",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
