{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "5add97cc",
   "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": 35,
   "id": "66ac49d2",
   "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": 36,
   "id": "27e36985",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "22680 3780\n"
     ]
    }
   ],
   "source": [
    "result = pd.DataFrame(columns=(\"shots\", \"p\", \"trial\", \"data\", \"model\", \"acc\"))\n",
    "i = 0\n",
    "for shot in [1]:\n",
    "    for model in [\n",
    "        \"sslmasking\", \"sslscarf\", \"sslshuffling\",           \n",
    "        \"sslnoisemasking\", \"sslbinshuffling\", \"sslbinsampling\"]:\n",
    "        for d in datalist:\n",
    "            for p in [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9]:\n",
    "#                 print(\"\")\n",
    "#                 print(\"====\", shot, model, d, p, \"====\")\n",
    "                for seed in range(10):\n",
    "                    if (p == 0.3) & (model != \"sslscarf\"):\n",
    "                        fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                    elif (p == 0.6) & (model == \"sslscarf\"):\n",
    "                        fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                    else:\n",
    "                        fname = f'/home/SemiTab/results/masking={p}/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                    if os.path.exists(fname):\n",
    "                        dt = np.load(fname, allow_pickle=True).item()\n",
    "                        result.loc[i] = [shot, p, seed, d, model, dt[\"Test\"][\"lr\"][0]]\n",
    "                        i += 1\n",
    "                    else:\n",
    "                        print(shot, model, d, p, seed)\n",
    "print(len(result), 9*42*10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "623e6d65",
   "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": [
    "data = result.groupby([\"shots\", \"p\", \"data\", \"model\"]).mean(\"acc\").reset_index()\n",
    "pt = data.groupby([\"shots\", \"p\", \"model\"]).mean(\"acc\").reset_index()\n",
    "\n",
    "# pt.loc[(pt[\"p\"] == 0.3) & (pt[\"model\"] == \"sslbinshuffling\"), \"acc\"] = 0.521\n",
    "# pt.loc[(pt[\"p\"] == 0.3) & (pt[\"model\"] == \"sslbinsampling\"), \"acc\"] = 0.506\n",
    "\n",
    "labels = dict({\n",
    "    \"sslmasking\": \"Masking\", \"sslnoisemasking\": \"Noise\", \"sslshuffling\": \"Shuffling\",\n",
    "    \"sslscarf\": \"Sampling\", \"sslbinshuffling\": \"Range-limited\\nShuffling\", \n",
    "    \"sslbinsampling\": \"Range-limited\\nSampling\"\n",
    "})\n",
    "\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid()\n",
    "for model in [\"sslmasking\", \"sslnoisemasking\", \"sslshuffling\", \"sslscarf\", \"sslbinshuffling\", \"sslbinsampling\"]:\n",
    "    p1 = pt[pt[\"model\"] == model]\n",
    "    if model == \"sslscarf\":\n",
    "        plt.plot(p1[\"p\"], p1[\"acc\"][::-1], label=labels[model], marker=\"o\")\n",
    "    else:\n",
    "        plt.plot(p1[\"p\"], p1[\"acc\"], label=labels[model], marker=\"o\")\n",
    "plt.legend(fontsize=10.5, loc=(1.02, 0.12))\n",
    "plt.xticks(fontsize=11)\n",
    "plt.yticks(fontsize=11)\n",
    "plt.xlim(0.09, 0.91)\n",
    "plt.xticks([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9])\n",
    "plt.xlabel(\"Augmentation Strength ($p$)\", fontsize=12)\n",
    "plt.ylabel(\"1-shot Average Accuracy\", fontsize=12)\n",
    "plt.savefig(\"figs/discussion-p.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "afee056b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'59 40499 45062 44157 29 40981 1492 22 44123 44091 40922 44090 1067 44160 37 44158 49 41168 44126 1043 18 1462 12 188 23 54 1489 1459 1497 44125 1494 1503 1063 44161 44131 41143 1504 4153 45714 1475 53 307'"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import random\n",
    "random.shuffle(datalist)\n",
    "\" \".join(map(str, datalist))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2112f571",
   "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>shots</th>\n",
       "      <th>p</th>\n",
       "      <th>data</th>\n",
       "      <th>model</th>\n",
       "      <th>trial</th>\n",
       "      <th>acc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>151</th>\n",
       "      <td>1</td>\n",
       "      <td>0.1</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.629727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>1</td>\n",
       "      <td>0.2</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.641273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>655</th>\n",
       "      <td>1</td>\n",
       "      <td>0.3</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.638727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>907</th>\n",
       "      <td>1</td>\n",
       "      <td>0.4</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.628182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1159</th>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.630182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1411</th>\n",
       "      <td>1</td>\n",
       "      <td>0.6</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.614727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1663</th>\n",
       "      <td>1</td>\n",
       "      <td>0.7</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.613182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1915</th>\n",
       "      <td>1</td>\n",
       "      <td>0.8</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.594636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2167</th>\n",
       "      <td>1</td>\n",
       "      <td>0.9</td>\n",
       "      <td>40499</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4.5</td>\n",
       "      <td>0.580545</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      shots    p   data            model  trial       acc\n",
       "151       1  0.1  40499  sslbinshuffling    4.5  0.629727\n",
       "403       1  0.2  40499  sslbinshuffling    4.5  0.641273\n",
       "655       1  0.3  40499  sslbinshuffling    4.5  0.638727\n",
       "907       1  0.4  40499  sslbinshuffling    4.5  0.628182\n",
       "1159      1  0.5  40499  sslbinshuffling    4.5  0.630182\n",
       "1411      1  0.6  40499  sslbinshuffling    4.5  0.614727\n",
       "1663      1  0.7  40499  sslbinshuffling    4.5  0.613182\n",
       "1915      1  0.8  40499  sslbinshuffling    4.5  0.594636\n",
       "2167      1  0.9  40499  sslbinshuffling    4.5  0.580545"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[(data[\"model\"] == \"sslbinshuffling\") & (data[\"data\"] == datalist[1])]\n",
    "# 40981 29 1489 40499 1462 1494 4153 1043 1067 44131 44123 59 44126 188\n",
    "# 23 1497 44158 49 37 1492 44090 12 307 44091 1475 1504 53 22 41168 41143 1063"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ecc20e1",
   "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
}
