{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6ca805d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2b5d0f8f",
   "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": 27,
   "id": "64f52714",
   "metadata": {},
   "outputs": [],
   "source": [
    "result = pd.read_csv(\"/home/SemiTab/result-summary/result.csv\", index_col=0)\n",
    "result = result[result[\"model\"].str.startswith(\"pseudolabel\")].reset_index(drop=True)\n",
    "result = result[[\"trial\", \"shots\", \"data_id\", \"model\", \"acc\"]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67738454",
   "metadata": {},
   "outputs": [],
   "source": [
    "def update(trial):\n",
    "    result = pd.read_csv(\"/home/SemiTab/result-summary/result.csv\", index_col=0)\n",
    "    result = result[result[\"model\"].str.startswith(\"pseudolabel\")].reset_index(drop=True)\n",
    "    result = result[[\"trial\", \"shots\", \"data_id\", \"model\", \"acc\"]]\n",
    "    i = len(result)\n",
    "    print(result.shape)\n",
    "    print(\"==============================\")\n",
    "    print(trial)\n",
    "    for aug in [\"masking\", \"rq\", \"binshuffling\", \"binsampling\"]:\n",
    "        print(aug)\n",
    "        model = f'pseudolabel-{aug}'\n",
    "        for shot in [1, 5]:\n",
    "            print(\"SHOT\", shot)\n",
    "            for d in datalist:\n",
    "                if len(result[(result[\"shots\"] == shot) & (result[\"trial\"] == trial) & (\n",
    "                    result[\"model\"] == model) & (result[\"data_id\"] == d)]) > 0:\n",
    "                    pass\n",
    "                else:\n",
    "                    fname = f'/home/SemiTab/results/seed={trial}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                    if os.path.exists(fname):\n",
    "                        try:\n",
    "                            perf = np.load(fname, allow_pickle=True)\n",
    "                            perf = perf.item()\n",
    "                            result.loc[i] = [trial, shot, d, model, perf[\"Test\"][0]]\n",
    "                            i += 1\n",
    "                        except Exception:\n",
    "                            os.remove(fname)\n",
    "                            print(d, end=\" \")\n",
    "                    else:\n",
    "                        print(d, end=\" \")\n",
    "                        pass\n",
    "            print(\" \")\n",
    "    result.to_csv(\"/home/SemiTab/result-summary/result-semi.csv\")\n",
    "    print(result.shape)\n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3475127",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "259dcdd6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def UpdateResults(model, seeds, shot, d):\n",
    "    result = pd.read_csv(\"/home/SemiTab/result-summary/result-semi.csv\", index_col=0)\n",
    "    for seed in seeds:\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-semi.csv\")\n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "cd364f7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['pseudolabel-masking', 'pseudolabel-shuffling',\n",
       "       'pseudolabel-noisemasking', 'pseudolabel-rq',\n",
       "       'pseudolabel-sampling', 'pseudolabel-binshuffling',\n",
       "       'pseudolabel-binsampling'], dtype=object)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.read_csv(\"/home/SemiTab/result-summary/result-semi.csv\", index_col=0)\n",
    "result['model'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "13d19a2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for model in [\"pseudolabel-cutmix\"]:\n",
    "    for d in datalist:\n",
    "        result = UpdateResults(model, range(10), 5, d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "9e7d79f3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['pseudolabel-masking', 'pseudolabel-shuffling',\n",
       "       'pseudolabel-noisemasking', 'pseudolabel-rq',\n",
       "       'pseudolabel-sampling', 'pseudolabel-binshuffling',\n",
       "       'pseudolabel-binsampling'], dtype=object)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result['model'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "f7b76a7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "a = []\n",
    "for s in range(10):\n",
    "    d = pd.read_csv(f'/home/SemiTab/result-summary/result-{s}.csv', index_col=0)\n",
    "    a.append(d[(d[\"model\"] == \"pseudolabel-cutmix\") & (d[\"shots\"] == 5)][\"acc\"].mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "6e77aa93",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.5310880350564428"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "655a9c48",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0e2fa4b7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['pseudolabel-masking', 'pseudolabel-shuffling',\n",
       "       'pseudolabel-noisemasking', 'pseudolabel-rq',\n",
       "       'pseudolabel-sampling'], dtype=object)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result[\"model\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5f38208",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "c8e946b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# result = pd.read_csv(\"/home/SemiTab/result-summary/result-semi.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "faec2d28",
   "metadata": {},
   "outputs": [],
   "source": [
    "result = result[result[\"trial\"] < 10]\n",
    "p = result.groupby([\"data_id\", \"model\", \"shots\"]).agg(\n",
    "    acc_mean=('acc', 'mean'), acc_std=('acc', 'std')).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "c6953b44",
   "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": null,
   "id": "cd6194dd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "a64821b0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0    0.108640\n",
       "1    0.160623\n",
       "2    0.108059\n",
       "3    0.109731\n",
       "4    0.090949\n",
       "5    0.102748\n",
       "6    0.105326\n",
       "Name: acc_mean, dtype: float64"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[\"acc_mean\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "0445bed4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# p[p[\"shot\"] == 1].groupby(\"aug\")[\"acc_mean\"].mean() \n",
    "q = rankdata[rankdata[\"shots\"] == 5].groupby(\"model\")[\"acc_mean\"].mean().reset_index()  # 0.435135\n",
    "# rankdata[rankdata[\"shots\"] == 5].groupby(\"model\")[\"acc_mean\"].mean() \n",
    "# p[p[\"shot\"] == 1].sort_values(\"acc_mean\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "73b25791",
   "metadata": {},
   "outputs": [],
   "source": [
    "# q\n",
    "q = q.iloc[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "4ba2e437",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['pseudolabel-binshuffling', 'pseudolabel-masking',\n",
       "       'pseudolabel-noisemasking', 'pseudolabel-rq',\n",
       "       'pseudolabel-sampling', 'pseudolabel-shuffling'], dtype=object)"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[\"model\"].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "0d39c59a",
   "metadata": {},
   "outputs": [],
   "source": [
    "q = q.reset_index(drop=True)\n",
    "q.loc[len(q)] = [\"pseudolabel-cutmix\", np.mean(a)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "0b09d0d1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>acc_mean</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>pseudolabel-binshuffling</td>\n",
       "      <td>0.554644</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>pseudolabel-masking</td>\n",
       "      <td>0.548433</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>pseudolabel-noisemasking</td>\n",
       "      <td>0.529887</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>pseudolabel-rq</td>\n",
       "      <td>0.536668</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>0.527020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>pseudolabel-shuffling</td>\n",
       "      <td>0.529214</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>pseudolabel-cutmix</td>\n",
       "      <td>0.531088</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      model  acc_mean\n",
       "0  pseudolabel-binshuffling  0.554644\n",
       "1       pseudolabel-masking  0.548433\n",
       "2  pseudolabel-noisemasking  0.529887\n",
       "3            pseudolabel-rq  0.536668\n",
       "4      pseudolabel-sampling  0.527020\n",
       "5     pseudolabel-shuffling  0.529214\n",
       "6        pseudolabel-cutmix  0.531088"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfe16d30",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "40116054",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(4, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid(axis=\"y\")\n",
    "\n",
    "plt.bar(q['model'], q['acc_mean'], color='skyblue')\n",
    "\n",
    "plt.ylabel('5-shot Average Accuracy', fontsize=12)\n",
    "plt.ylim(0.5, 0.56)\n",
    "\n",
    "plt.xticks(range(7), [\n",
    "    \"Ours\", \"Masking\", \"Noise\", \"RQ\", \"Sampling\", \"Shuffling\", \"CutMix\"], fontsize=12)\n",
    "plt.xticks(rotation=90)\n",
    "\n",
    "plt.savefig(\"figs/discussion-semi.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "afbf7d35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "d1bd7220",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([   37,   188,  1459,  1494,  4153, 40922, 40981, 44091, 44131,\n",
       "       44160, 45062])"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata[(rankdata[\"model\"] == \"pseudolabel-binsampling\") & (rankdata[\"shots\"] == 5) & (\n",
    "    rankdata[\"rank\"] > 6)][\"data_id\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "f7cb6556",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([   22,    29,    49,    53,    59,  1043,  1459, 41143, 44158,\n",
       "       44160, 44161])"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata[(rankdata[\"shots\"] == 1) & (rankdata[\"model\"] == \"pseudolabel-rq\") & (rankdata[\"rank\"] == 1)][\"data_id\"].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "e40b0ad2",
   "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>model</th>\n",
       "      <th>shots</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_std</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-binsampling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.362500</td>\n",
       "      <td>NaN</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-binshuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.370000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-masking</td>\n",
       "      <td>1</td>\n",
       "      <td>0.391875</td>\n",
       "      <td>0.054150</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.395650</td>\n",
       "      <td>0.055047</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-noisemasking</td>\n",
       "      <td>1</td>\n",
       "      <td>0.396100</td>\n",
       "      <td>0.051150</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-shuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.397000</td>\n",
       "      <td>0.049163</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-rq</td>\n",
       "      <td>1</td>\n",
       "      <td>0.399425</td>\n",
       "      <td>0.050655</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    data_id                     model  shots  acc_mean   acc_std  rank\n",
       "28       22   pseudolabel-binsampling      1  0.362500       NaN   7.0\n",
       "30       22  pseudolabel-binshuffling      1  0.370000       NaN   6.0\n",
       "32       22       pseudolabel-masking      1  0.391875  0.054150   5.0\n",
       "38       22      pseudolabel-sampling      1  0.395650  0.055047   4.0\n",
       "34       22  pseudolabel-noisemasking      1  0.396100  0.051150   3.0\n",
       "40       22     pseudolabel-shuffling      1  0.397000  0.049163   2.0\n",
       "36       22            pseudolabel-rq      1  0.399425  0.050655   1.0"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata[(rankdata[\"shots\"] == 1) & (rankdata[\"data_id\"] == 22)].sort_values(\"acc_mean\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "3b514c12",
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-masking</td>\n",
       "      <td>0.3350</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-shuffling</td>\n",
       "      <td>0.3475</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>84</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-noisemasking</td>\n",
       "      <td>0.3425</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>126</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-rq</td>\n",
       "      <td>0.3300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-masking</td>\n",
       "      <td>0.3800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41774</th>\n",
       "      <td>97</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>0.3800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41789</th>\n",
       "      <td>98</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>0.3700</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41799</th>\n",
       "      <td>99</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>0.4050</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42000</th>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-binshuffling</td>\n",
       "      <td>0.3700</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42084</th>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>pseudolabel-binsampling</td>\n",
       "      <td>0.3625</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>502 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       trial  shots  data_id                     model     acc\n",
       "0          0      1       22       pseudolabel-masking  0.3350\n",
       "42         0      1       22     pseudolabel-shuffling  0.3475\n",
       "84         0      1       22  pseudolabel-noisemasking  0.3425\n",
       "126        0      1       22            pseudolabel-rq  0.3300\n",
       "336        1      1       22       pseudolabel-masking  0.3800\n",
       "...      ...    ...      ...                       ...     ...\n",
       "41774     97      1       22      pseudolabel-sampling  0.3800\n",
       "41789     98      1       22      pseudolabel-sampling  0.3700\n",
       "41799     99      1       22      pseudolabel-sampling  0.4050\n",
       "42000      9      1       22  pseudolabel-binshuffling  0.3700\n",
       "42084      9      1       22   pseudolabel-binsampling  0.3625\n",
       "\n",
       "[502 rows x 5 columns]"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result[(result[\"shots\"] == 1) & (result[\"data_id\"] == 22)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c238777",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fd188f3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "8b8954b6",
   "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>model</th>\n",
       "      <th>shots</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_std</th>\n",
       "      <th>rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>214</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-masking</td>\n",
       "      <td>1</td>\n",
       "      <td>0.184100</td>\n",
       "      <td>0.033195</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>222</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-shuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.179648</td>\n",
       "      <td>0.026174</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>216</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-noisemasking</td>\n",
       "      <td>1</td>\n",
       "      <td>0.179012</td>\n",
       "      <td>0.021724</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>210</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-binsampling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.177446</td>\n",
       "      <td>0.022214</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>218</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-rq</td>\n",
       "      <td>1</td>\n",
       "      <td>0.175587</td>\n",
       "      <td>0.033305</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>212</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-binshuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.170841</td>\n",
       "      <td>0.024573</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>220</th>\n",
       "      <td>1459</td>\n",
       "      <td>pseudolabel-sampling</td>\n",
       "      <td>1</td>\n",
       "      <td>0.165362</td>\n",
       "      <td>0.023896</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id                     model  shots  acc_mean   acc_std  rank\n",
       "214     1459       pseudolabel-masking      1  0.184100  0.033195   1.0\n",
       "222     1459     pseudolabel-shuffling      1  0.179648  0.026174   2.0\n",
       "216     1459  pseudolabel-noisemasking      1  0.179012  0.021724   3.0\n",
       "210     1459   pseudolabel-binsampling      1  0.177446  0.022214   4.0\n",
       "218     1459            pseudolabel-rq      1  0.175587  0.033305   5.0\n",
       "212     1459  pseudolabel-binshuffling      1  0.170841  0.024573   6.0\n",
       "220     1459      pseudolabel-sampling      1  0.165362  0.023896   7.0"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata[(rankdata[\"shots\"] == 1) & (rankdata[\"data_id\"] == 1459)].sort_values(\"acc_mean\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "181a4e87",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "402971f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9fe8570",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "1ea15d19",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "aug\n",
       "binsampling     0.533163\n",
       "binshuffling    0.531919\n",
       "masking         0.546234\n",
       "noisemasking    0.531116\n",
       "rq              0.538034\n",
       "shuffling       0.529361\n",
       "Name: acc_mean, dtype: float64"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p[p[\"shot\"] == 5].groupby(\"aug\")[\"acc_mean\"].mean() \n",
    "# rankdata[rankdata[\"shot\"] == 5].groupby(\"aug\")[\"rank\"].mean() \n",
    "# p[p[\"shot\"] == 5].sort_values(\"acc_mean\", ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "451c930d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8eb45f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25af3956",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "a88afb63",
   "metadata": {},
   "outputs": [],
   "source": [
    "q = result.groupby([\"aug\", \"shot\", \"data_id\"]).agg(\n",
    "    acc_mean=('acc', 'mean'), acc_std=('acc', 'std')).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "9f2c76c7",
   "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>aug</th>\n",
       "      <th>shot</th>\n",
       "      <th>data_id</th>\n",
       "      <th>acc_mean</th>\n",
       "      <th>acc_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>350</th>\n",
       "      <td>rq</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.602607</td>\n",
       "      <td>0.238429</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>182</th>\n",
       "      <td>masking</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.526540</td>\n",
       "      <td>0.251452</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>266</th>\n",
       "      <td>noisemasking</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.499763</td>\n",
       "      <td>0.337272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>434</th>\n",
       "      <td>shuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.499289</td>\n",
       "      <td>0.338244</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>binsampling</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.441943</td>\n",
       "      <td>0.337032</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>binshuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>1067</td>\n",
       "      <td>0.434597</td>\n",
       "      <td>0.343932</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              aug  shot  data_id  acc_mean   acc_std\n",
       "350            rq     1     1067  0.602607  0.238429\n",
       "182       masking     1     1067  0.526540  0.251452\n",
       "266  noisemasking     1     1067  0.499763  0.337272\n",
       "434     shuffling     1     1067  0.499289  0.338244\n",
       "14    binsampling     1     1067  0.441943  0.337032\n",
       "98   binshuffling     1     1067  0.434597  0.343932"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q[(q[\"shot\"] == 1) & (q[\"data_id\"] == 1067)].sort_values('acc_mean', ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "551949da",
   "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": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\" \".join(map(str, datalist))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "c0ed390e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# q1 = p[p[\"shot\"] == 1]\n",
    "# q2 = p[p[\"shot\"] == 5]\n",
    "# plt.figure(figsize=(4, 3))\n",
    "# plt.gca().set_axisbelow(True)\n",
    "# plt.grid()\n",
    "# plt.plot(q1[\"numbins\"], q1[\"acc_mean\"], label=\"1-shot\", marker=\"o\")\n",
    "# plt.fill_between(q1[\"numbins\"], q1[\"acc_mean\"]-q1[\"acc_std\"], q1[\"acc_mean\"]+q1[\"acc_std\"], alpha=0.2)\n",
    "# plt.plot(q2[\"numbins\"], q2[\"acc_mean\"], label=\"5-shot\", marker=\"o\")\n",
    "# plt.fill_between(q2[\"numbins\"], q2[\"acc_mean\"]-q2[\"acc_std\"], q2[\"acc_mean\"]+q2[\"acc_std\"], alpha=0.2)\n",
    "# plt.legend()\n",
    "# plt.xlabel(\"Number of Ranges\", fontsize=12)\n",
    "# plt.ylabel(\"Average Accuracy\", fontsize=12)\n",
    "# plt.title(model)\n",
    "# plt.savefig(f'figs/discussion-numbins-{model}.png', dpi=300, bbox_inches=\"tight\")\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a35ce47",
   "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
}
