{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "772bda95",
   "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": 48,
   "id": "553fbcc0",
   "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": 98,
   "id": "e34a2f58",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8400 8400\n"
     ]
    }
   ],
   "source": [
    "result = pd.DataFrame(columns=(\"shots\", \"numbins\", \"trial\", \"data\", \"model\", \"acc\"))\n",
    "i = 0\n",
    "shot = 1\n",
    "for model in [\"sslbinshuffling\", \"sslbinsampling\"]:\n",
    "    for d in datalist:\n",
    "        for p in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:\n",
    "            for seed in range(10):\n",
    "                if (p == 4):\n",
    "                    fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model={model}/data={d}/performance.npy'\n",
    "                elif (p == 1) & (model == \"sslbinshuffling\"):\n",
    "                    fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model=sslshuffling/data={d}/performance.npy'\n",
    "                elif (p == 1) & (model == \"sslbinsampling\"):\n",
    "                    fname = f'/home/SemiTab/results/seed={seed}/shot={shot}/model=sslscarf/data={d}/performance.npy'\n",
    "                else:\n",
    "                    fname = f'/home/SemiTab/results/numbins/bin={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",
    "                    \n",
    "print(len(result), 10*42*10*2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a55c5660",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "595de4a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "p1 = result[result[\"model\"] == \"sslbinshuffling\"].groupby([\"shots\", \"numbins\", \"data\"]).mean(\"acc\").reset_index()\n",
    "p1 = p1.groupby([\"shots\", \"numbins\"]).mean(\"acc\").reset_index()\n",
    "\n",
    "p2 = result[result[\"model\"] == \"sslbinsampling\"].groupby([\"shots\", \"numbins\", \"data\"]).mean(\"acc\").reset_index()\n",
    "p2 = p2.groupby([\"shots\", \"numbins\"]).mean(\"acc\").reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "96dd06a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAR0AAADTCAYAAAC8/8cLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAABA1UlEQVR4nO2deXxU1fXAvycbCQHCEhJ2wr5vYVEQEcVdQbQWl4rgUpRa2vprtS4VkNbdqlVwqbhWq+KOiFIVEBAUgoRFlrBDwpYQSEL25fz+eC9hkkySN8lkJgn3+/m8z7x337v3nplkztx77j3niKpiMBgMviLA3wIYDIYzC6N0DAaDTzFKx2Aw+BSjdAwGg08xSsdgMPgUo3QMBoNPCfK3ALVJZGSkxsTE+FWGzMxMwsPD/SqDpxiZfUN9lBmcy71+/foUVW1dtrxBK52YmBji4uL8KsPy5csZO3asX2XwFCOzb6iPMoNzuUVkv7tyM70yGAw+xSgdg8HgUxr09MrgGZ9tSOKpJTtIOplN+x+Xcs8lvZg4pL2/xTI0MIzSMQCWwrn/k81k5xcCkHQym/s/2QxgFI/Bq5jplQGAp5bsKFE4xWTnF/LUkh1+ksjQUPGZ0hGRniKyRkQS7Ncebp6ZLSLHRCTePua53HtQRDaJyAb73nW+kv1M4NDJbI/KDYbq4kjpiMgfRSSyhn29DMxT1Z7APOCVCp57W1UH28ddLuVzVXWgqg4BLgdeFZEWNZTJYNOueZhH5QZDdXE60rkA2Ccii0TkOhFp5EknIhIFxALv2UXvAbEiUm7jUEWoaprLZRNAMdNDr3HPJb0IFClVFhQg3HNJLz9JZGioODIkq+pVItIKuB74E/CyiHyMNSpZ4aCJjkCSqhba7RWKyCG7PLnMs9eLyMXAEWCWqq4pviEid9r9dwRuVdXjZTsSkWnANIDo6GiWL1/u5C3WGqdOnfK7DE4ozC6iUJXQQMgpVEIChfxCJffQDpan7fS3eFVSXz5nV+qjzOAFuVXV4wMYCGwECoF9wINAk0qeHwr8UqZsKxBbpqwNEGyfXwQcA1q5aW8AsMndPddj6NCh6m+WLVvmbxEc8ciXW7Xr/V/qwdRMXbZsmR5Ny9Z+M7/Wqa//pEVFRf4Wr0rqy+fsSn2UWdW53ECcuvleejQ9EZFxIvIGsBw4CtwMTAaGAF9VUvUg0F5EAu12AoF2drmrAjyiqvn2+Tf2/f5lG1PVzcAhYKwn8hvck5GTz3s/HeCy/m3o0KIxAFHNQvnThT1YtiOZb7cd87OEhoaEU0Py0yKSCDwPbAcGqOrFqvquqq4EbsBSPG5R1WNAvP0c9usGVS01tRKR9i7ng4EYYId93dflXhe7v61O5DdUzoK4RDJyC7j93K6lyqeMiqFndBPmLPqFnDLL6QZDdXE60gkFrlbVfqr6hKomud60RyfDqmjjTmCGiCQAM+xrRGSxiBTXfVREtojIRuBVYLKqHrHvzRaRX0QkHvgI+IOqbnMov6ECCgqLeOOHvQyPacHgjs1L3QsODGD2hH4cTM3m5e93+0dAQ4PD6Y7kx4As1wJ7uTpMVQ8BqOr2yhqw75/lpvxyl/MpldSf5FBWgwcs+eUoiSeyeejKvm7vj+oWyZUD2/LS8t38KrYDHVs29rGEhoaG05HOZ0CHMmUdgE+9Ko3B58xftYfOrRpzYZ/oCp958Io+BAYIcxaZ2ayh5jhVOr1s420J9nVv74tk8BXr96ey4cBJbj2nC4EBUuFzbSPC+MO4Hnyz9SjLdhijsqFmOFU6x0Sku2uBfV1un4yh/jB/5V4iwoL59bCyg9jy3HpOF7q2Dufhhb+QW2CMyobq41TpvA58LCJXikhfERmPZcydX3uiGWqTA8ezWPLLEW48qxONQ6o27YUEBfDwhH7sO57F/JV7fSChoaHi1JD8OJAPPI21G/gglsJ5ppbkMtQyr/+wl8AAYeqoGMd1zu3Rmsv6t+GFpTuZOKQ97Y1flqEaOBrpqGqRqj6lqr1VNdx+fVpVi2pbQIP3ScvOZ0HcQcYPbEd0s1CP6v7NXuX6hzEqG6qJ4x3JIhIiIgNE5HwRuaD4qE3hDLXDe2sPkJVXyG3ndvG4bvvmYfz+/O58teUIK3eWdZszGKrG6Y7k0cB+4HvgGyx7zhKMTafekV9YxJs/7GNUt1b0axdRrTZ+O6YrMa0aM2vhL+QVmMGuwTOcjnSeBZ5U1ZZAhv36d+DFWpPMUCss3nyYI+k53F6NUU4xjYICmTW+H3uSM3n9B2NUNniGU6XTE/hXmbLHgbu9K46hNlFVXl25h26twxnbM6pGbZ3fO4oL+0Tz/Hc7OZKW4yUJDWcCTpVOGtDMPj9sO1+2wAqmZagn/LQ3lS1J6dw2uisBlWwGdMqs8X0pKFIeWWxc4AzOcap0PsEKEQrWnp1lwHos246hnjB/5R5ahodwTax3sjt0bNmY6ed144uNh1i9O8UrbRoaPk6XzP+kqv+1z58GfgX81j4M9YA9yaf4dtsxbjq7M6HBgV5rd/rYbnRsGcbshb+QX2iMyoaqqVLpiEigiOx2jYusqqtU9SuzT6f+8PoPewkJCmDy2Z292m5ocCAzr+xHwtFTvLV6n1fbNjRMqlQ6asU1LsSKqWOoh5zIzOOj9YlcPbg9rZt6FFPfERf2iWJsr9Y89+1OjqUbo7KhcpzadJ4DFojIeSLSTUS6Fh+1KJvBS7z7035y8ouq3gy4aQE825/zlk+EZ/tb1w4QEWaP70deQRGPf1VpWCWDwbHv1Vz79aIy5Qp4z0Bg8Dq5BYW8tWY/5/VsTc/ophU/uGkBfPEHyM9GANIOWtcAA6uOnxYTGc60MV2Zu2wXN5zVieExLb0iv6Hh4dSQHFDBYRROHWdh/CGSM3Kr3gz43RzIL5PNMz/bKnfI787vRruIUB76bAsFxqhsqACTrK4Bo6q8tmovvds0ZXT3KhK0piV6Vu6GxiFBPHRlX7YfyeDdnw54IKnhTMLR9EpEVmJNpcqhqmO8KpHBa6zalcL2Ixk8de1ARKrYDBjeGjLdRAVs1BQKCyDQ2Uz80v5tGN09kqf/t4MrBrYlson3DdeG+o3Tkc584DWX40usxHjfOu1IRHqKyBoRSbBfe7h5ZraIHBORePuY53JvnohsF5GNIvKDSwYJQwXMX7mX1k0bMWFwu8ofTFwPOelAGcUkgZCbDm9cCsedZYMQEWZP6EdOfiFPGKOywQ1ObTpvlTmewNqhXNawXBkvA/NUtScwD3ilgufeVtXB9nGXS/lXWPm2BmFlp/jAg77POBKOZvB9QjJTRnamUVAlprdDG+A/V0OzNnDpExDREUUgoiNc/TJc+zqkJMDL58L6N0HdDnhL0T2qCbeO7sKH6xP5+cAJ770pQ4OgJjadJKz0wlUiIlFALPCeXfQeECsirZ12pqqLirN/AmuADiJibFIV8NrKvYQGB3DjWZVsBjy8Ed6eCGERMGURnH0H3L2F78d+BndvsVat+v8Kpq+BDkPhiz/C+zfCqarj6My4oAfRzRox8/MtFBZVragMZw5O4+ncWub4PdYU60eH/XQEkuyNhsUbDg/Z5WW5XkQ2icj/RGRkBe39HvjS7Ih2T3JGLp/GJ/Gr2A60DA9x/9CRzfD2VZbNZsoiaO7uT2ET0R4mfw6XPAq7voOXRsKOryuVoUmjIB68oi9bktJ5b60xKhtOI+pguCwiy8oUZWKlCX5WVavMCCEiQ7GmTf1cyrYCN6nqzy5lbYDjqpovIhcB7wJ9XPsQkeuBh4ExqnrUTV/TgGkA0dHRQ99///0q319tcurUKZo08a0z/qc78/h8dz6PnxtGm/Dyvyvhp/YzaOPfKAoIJn7wo+SEtSl1vzKZw0/tp8+2Z2iSuY9DbS9hV/dbKQp0v1ldVXliXQ4HM4p44tzGNAmpuWd7Rfjjc64p9VFmcC73+eefv15Vy9teVbXWDyAKOAkE2teB9nXrKuqtB85zub4a2A3EOOl36NCh6m+WLVvm0/6y8wp0yJz/6W1vrnX/wNFtqk90VX26l2rKLrePVClzfo7qkr+pzopQ/ddg1YPrKnx0++F07Xr/l3rfx5ucvYFq4uvP2RvUR5lVncsNxKmb76XT6dXNIjKwTNkgEZnspL6qHsMaGd1gF90AbFDVUsYBEWnvcj4YiAF22NdXYmWfuERV9znp90zkk5+TSM3M4/Zz3XioJCfAW+MhIMiaUrXqVr1OghrBxX+HqYugMB9euxiWPWYtrZehV5umTB0Vw3trDzD8kW/pct+XnPP4Uj7bkFS9vg31HqeG2L9jpZ1x5SDwDw/6uhOYISIJwAz7GhFZ7LL8/aiIbBGRjcCrwGRVPWLfewMIAT5yWVJv5UH/DZ6iIuW1VXvo374ZZ3Up44aQsstSOABTvoDI7uUb8JSY0TD9BxhwLXz/OLx+sdul9R5R4YBla1Ig6WQ293+y2TuKp5r+Yk74bEMS5zy+1ChKL+PU96oZkF6mLA1o7rQjVd0OnOWm/HKX8ymV1He80nWm8n1CMruTM3nuusGlNwMe3w1vXQlFBTD1S2jd03udhkbANf+GnpfCorvh5dGWwXnoVLBleGFpeUWUnV/I3xdtZVhMC9pFhFUvkmEN/cUq47MNSdz/yWay861spsWKEmDiEO8EQTtTcap0tmIF7nL9GbkaMHEq6xCvrtxDm2ahXDGw7enC1L3WCKcwz5pSRdVS+vn+10Cns+Gz6bDoT5DwNUx4AZpEcehkttsqxzPzGP3EMhoFBRDTKpwukeF0aW29do0MJyYynFbhIaUVaFYqHNkEhzfB8sfc+4t9M6tGSie3oJDHv9peonCKyc4v5Imvt3PV4HZV7/CuhHULX6Hjz08xRpM5srw1B2PvYfiEO6rdXn3DqdL5K7BYRK7DMuR2B8ZxOoSpwc/8ciiN1buPc99lvQkOtGfNJ/ZbCic/y5pSRfetXSGatYObPoW1r1hf/BdHwlVzadc8jCQ3iieySQh/vrgXe1My2ZOcyc5jGXy3/Sj5hQoobUhlWOhBRjVOon/AfmLyd9Es90hJfaXcHmqrPOMQ8vZEGDgJ7X0lGYRxIjOP45l5pJ7KIzUrj9TM0sfxzDxO2Oencsvbpoo5nJZDr4e+pnlYMM0bB9M8LISIxsGnrxuHlJQ3bxxMhEt5eEggcV/8m/7r/0aY5IFAG5KJWP831kGdVzyfbUjiqSU7SDqZTfsfl3LPJb2qNepzpHRUdZWI9AduxNpbsxb4o6qWtfMY/MRrK/fSOCSQG0Z0sgpOHrSmVLkZMGUhtBngG0ECAuDs6dB1LHzyW3jvet7t/GtezWrJdD6mnaRwSCN5jusZfcXvrH/aoiJI3QNH9lOUFE9uYjyBxzYTkmvtZi7KEg5KO5YXdOGXovP5RWP4pagzXzT6Gx2kfGzmDA0jc99W2u6ZTo7+ke+LYvm0cDQrigZS4PIv3ygogFbhIbRsEkKLxiF0adWYluGNaBkezPyVezmZnV+u7WahQdxwVifSsvI5mZXPyew8DqZmsSU7nxNZeeTkV7x1rEVgNt8E/d1SOC6ESR4df34K6rDS8eZ006nDZyPgsKo+7lIWLCKNVDXXox4NXudIWg4LNx7iprM7ExEWbHmGv3UlZKfBlM+h7SDfCxXVB27/DpY9SswPz/GPAEFsn+EOksIT8gqBm3+Bn7Ph6BbIOwVAQEAwYVF9oO8V0GYQtB1EQHQ/OjdqQnR+Ib2OZzEk5RR7UjJ58n+TeDx4Po1dvsRZGsLf8m8hq8s1xAYkcHbmd1yU+h3j838kL6QF6V2voHDAJJp2H0VYSFCF06QOLRqX+pIBhAUHMueq/pV+yXLyC0nLthRSWkYGkriW8KQfaHVsDa3TtxJAodt6UZpMckZurUR2rClFRco/vtzqdrr51JIdtaN0sLJ63kvpHchDsXJfjfWoR4PXeXvNPopUufWcLpB+yJpSZaXC5M+g3RD/CRbUCC56GOL/i5TxYA/UfNizHDqeBYNvtBRjm4HQujcEud9FHRocSK82TenVxgpGds6PF3FfOtwbtIB2cpxD2oonCyaxvtlF/DB1ODAc+I21rL97KSGbPiBy+8ew/R1o3hkG/Nqy/bTuVa6v4i/SU0t2cOhkNu2ah1U9nSgqJPTYRkL3fk/0nu/hwI9QkG05zraPhUF3c3zlq7QirVxVRXjwiacI638Fk8/uzNDOLWpkN/IGh9Oy+SgukQ/XJ5JyKo8JAavsz9oarT5ZMIkvTo72uF2nSmcA8FOZsrWAH35C6wmbFsB3czgvLRE2dIBxM2u8ouKOrLwC3v3pAJf0a0OnkHR4c7zlGzX5U8tfqi6QWYmv1m1Lqt3sPZf04v5P8liYd/ofPyw4kMcuKaNEAoOh5yXWkZsB2xbB5gWw6hlY+bSl8AZMspb+m57enT1xSPvKlYwqHN9lKc89y2HfKsg5ad2L6mut4HU9DzqfA6FW2rg9mVE0Lrbp2ORoMHmhrfh37lO8t30Tv4m/ga5tI5l8dmeuGtyO8EZOv6Y1J7egkG+3HmNB3EFW7ExGFUZ1a8U5WUt5SE+PKjtICo8Hz6dlcAhwhUd9OH03aUA0cMSlLBrLHcJQlk0LKPh8BkGFOSVLuQWfz7A+bC8rno/WJ5KWnc+dw5pYI5z0wzD5E+g43Kv91IiIDtZytrvyGuA6Gkk6mU17J6ORRk1h8A3WkXEUtnxsKaD/PQjfPARdxsDA66D3ldYK3HdzrOlqhP3DETMa9nwPe7+3XjMO2e+lE/S5ErqMtdpoGu22++ET7mAd0PHnp4jSFI5JJAeH3sPwy6fCtw9zw4/zuCxyN/cX/JEHPk3nscXb+NXQDtx0dme6R9Wey8TWQ+ksiDvIZ/FJnMzKp11EKDMu6MGvh3agY8vGZD0xlcbZpW1RjSWPe4M/wPJKco5T36t/AkOAPwB7gG5Yu4O3qGqdTS08bNgwjYuL83m/WU/0pnH24XLl+UFNCL56LrQdDC1iSvaxVJfCIuWCfy6nS1gWb8ocOHkAbvoYOo+qUbvLly9n7NixNWqjFC77aUoIDoPxz3tNCddY5pSdlpybF8CJfSBBgIK62jGEklh2YS2tUUyX86zXFl08/nu6lXnXd/DZdDT7JIlD/8ozaWP5cssx8gqLGNWtFTeP7MyFfaIJCqx5gIWTWXks3HiIBXEH2ZKUTkhgAJf0b8OkYR0Y1S2SwOK9U1mp8GRF4W4FZp90f0fEre+V05HOg8A/saZUjYAcrB3C9zmsf0YRmn3EbXlQwSn4cKr9UIQ1rG87yFJCbQdDy67W6o9Dvt12lPTjR3g+6p+QlQi/+bDGCqdWKFYsZUcNtTDdrDaRPeCCB+H8ByAxDv4zscS4fRq1/m5TFkF0f4/+Vo7pPg6mr0Y+v4uOa+fwbLcf+NsfnuP9rXn896cD3PnOz7RpFsqNZ3Xi+uEdiWrmWWaooiLlh90pLIhLZMkvR8grKKJfu2Y8PKEfVw1uR/PGLva07JOwZh78+FLFDVZjtOp0yTwHuMsOaREJpKiq2jnNt3rcawPnUFErOgSUX8o9VNSKe4Pu5dzwJAYF7aNrym4i979CYJE9bA1pCm0H2kpoELQbDK26Q0CZIFy2vejitEQuCA0gKENg8sfQ5dxaf2/VZuCkuqVkKkLEmprmVWA5yEm3/ka1SXgk3PA+xL0GSx6k1Vvnc9fEF7nz3otZuv0Y//lxP898k8Dz3+3k0v5tmHx2Z0Z0aYmIlOylKWv8PpiaxYfrE/l4fSJJJ7OJCAvmxhGduHZoB/q3jyjdf24G/PgyrHkBctKg71XWgsT3T5QfrY6b6fHb88hCZSuaIuD3InIzVhCvurfG52fmh9zE/flzaSSnN5llaQjPB9xIp/6jWJacyWspmSRn5BJEAT0kiYEBezkrKJGBh/fS+cB8gu2dCEXBjZE2A5F2gy1FlHGUguWPl9iLgimkUEIIPOUmvrGh+tSSHcoxIjD8dug8Gj6+Hf47icDhv+Wii//ORX1HsDclk3d/3M+CuIMs2nSYXtFNGdAhgkWbDpXsFUo6mc09H21k3rKd7DyWiQic26M191/emwv7RJdPL52XCWtfhR/+Bdmp0OtyGHv/aSXbrD18NwdNS0RqMFp1uk8nCBgP3Iy1CzkIeBKY4HGPZwCDr5jG0k9XcylrUTi9GW7i9FJGzoyc/JLduHtSMlmafIrXUjI5kJJO2/yD9Je9DCjYy4AD++l38E3CsLJnlv2jBRblkfXVTBrXh5FEfWHcTPd2qGr8steIqN7w2+/g24fhx3nWCtmv5tOlTX/+dmVf/nxxL77YeIi3f9zHR+vLZ+7IL1T2pGTx54t68quhHWjXPKx8H/nZEPc6rHrWWmnsfqE1zWxfZvXTHq1+X0P7WaVKR0SGYyma4pAUH2HFRV6AFcDL/Ly6YeKQ9sQvgR1ZHbk074kKV1WahgYzsENzBnZoXqpcVTmSnsPe5Ex2p2SyODmTeclpFCTv4u2s37u1V1ZkRzJUk7pkhwpqBJc+Ct0vgM9+B69eYO1/OutOwkICmTS8I78e1oGu9y92m7KlqEiZMa5cHgQoyIWf34aV/4SMw9aq2/nvQqdyftnefTtV3P8JOI4ViuJDVS0AEBET9LYyVOmas431TUfz5vBwj38VRIS2EWG0jQhjVKl8VSNJnDnb7db/Q0Wt8NHA/8yhrtmhul8I01fD53fB1/fBrm9h4kvQJAoRqdDHrdzopjAf4t+FFU9bU8hOI+GaV31mE6zK/D4HK6TFfOAdERlvT7WM0qmEI3t/oRkZBHby/l6Z+SE3kaWld+xmaQjzQ27yel+GOkixkfnyp62p1osjIcHaYHnPJb0IK2OnCQsO5J7izZKFBRD/X5g7zAqy3yTa2kR6y1c+XYSoVOmo6mxV7QZcBpwC3sHaINgSa5eywQ1745cD0HngeV5ve/AV05ip00gsiqRIhcSiSGbqNAZfMc3rfRnqKCIw4rcwbbm1g/q/k2DxPUzs35LHrhlA++ZhCNC+eRiPXTOAiYPawOaP4MWzrNAjjZrBjQvg9m+h2wU13i/mKU6XzFcAK0RkBnANlp1niYj8rKojalPA+kjevp84RWM69RrC3qMrvdq2ZRf6HdctGefcJ8jQMInqA79detrIvHclEwdOYmKj1yE0ERq1hyNXwurvIXmb5Zpx3TvWbms/+nV5umSejZWh4V07nrEZ05ehoLCI1umbORzelx5l99d4iSp9ggxnDq5G5gVT4TsXl4S0RPjpZWjSxkqa2Pfq2tnQ6CHVlkBVk9TK9GlwYdOeQ/TU/dChDvk+GRo+3S+E0Kbu7wUGWUkT64DCgZpl+DS4YWf8SoKkiHb9x/hbFMOZRnp5fz8A0upWQHmjdLxM9l4rAkh4t7P9LInhjKOi3dK+2kXtEJ8pHRHpKSJrRCTBfi23W0lEZovIMZcUM/Nc7t1kpxsusH3A6hypmXm0ydjCidBO0Lhl1RUMBm8ybqa1a9oVf+yirgLHSkdELhKR10TkC/t6mIhc4EFfLwPzVLUnMA94pYLn3lbVwfZxl0t5PHA98F8P+vQpq3YmExuwk6L25TOpGgy1zsBJVriQiI6AWK9eDB/iLZz6Xs0A/oi1SfBauzgbeB6oMpaCiEQBsVguFADvAXNFpHXZLJ8Voapb7LYqjnztZzb/soUJcpKinnUwvIThzKCu7aJ2g9ORzp+AC+3A7MVf+u1A+eCy7ukIJKlaEZHs10N2eVmut6dR/xORkQ7b9zuqSuYeK4R0QF2K2mcw1DGc7tNpyum0wsUuEMFAnvvHq83LwCOqmi8iFwGfi0gfVT3utAERmQZMA4iOjmb58uVeFtE9BzOK6Ja7jfzgEFZvT0ETrH5PnTrlMxm8hZHZN9RHmcELcqtqlQeWd/mD9nmq/Xov8F+H9aOAk0CgfR1oX7euot564LwyZW8Cv3fS79ChQ9VXvLx8l65/KFZz/n1xqfJly5b5TAZvYWT2DfVRZlXncgNx6uZ76XR6NQO4WkT2AU1FZAcwCfg/h4rtGJYhuDhExg3ABi1jz7F3ORefDwZigB0OZfQrqxOS6B+wj0YxtRsWwGCo7zj1vTpsx9YZAXTCmmqtVVVPjLp3Am+JyEzgBJb/FiKyGJipqnHAoyIyFCjEmrpNVtUj9nM3AE8BLYCrROQ+4GJV9Xu41Ky8AjL3xxMSVGB2IhsMVeDY98oeLv1E+fxXTutvB8oNA1T1cpfzKZXUfw9r1avO8dOeVAZognVhlssNhkpxumR+EPcxdHKBROAT4CW1g3ydaXyfkMzwwF1osw5Is7b+FsdgqNM4Hek8j+VR/jzW1KoTcBfwIZAK/Blr+fveWpCxzrMiIZm7gvcgHc3+HIOhKpwqnanARap6qLhARL4C/qeq/URkGfAtZ6DSOZiaRUZKIq1Djxp7jsHgAKerV22xIge6kgm0s88TgOZekqlesWJnMkMCdlkXRukYDFXiVOl8gbVR70IR6S0iFwIf2+UAI4F9tSBfnWdFQjLnhu1DA0OsvFQGg6FSnCqdO7BWrV4BNgD/BtZhLYODld/8Cq9LV8fJLyxi9a7jnBO6F2kz0IriZjAYKsWTtML3UUHu8uK9NGcaGw6cJCs3l05BO6DDVH+LYzDUCxzv0xGRECwHz0igJKqzqi6tBbnqBSsSkukbeJCgwmzoYPbnGAxOcLpPZzTW8ngjoBlWLqxiJ9CutSZdHWfFzmTGt0yCDIwR2WBwiFObzrPAk6raEsiwX/8OvFhrktVxUjPz2JyUxuiwfRAeBc07+Vskg6Fe4FTp9AT+VabsceBu74pTf1i5MxlV6JqzzRrl+DGPkMFQn3CqdNKwplUAh0WkL5bjZZNakaoesCIhhc5hOYSm7zH2HIPBA5wqnU+AYsfM14FlWLFuPqoNoeo6qsqKnclc1+6YVdDRJDk1GJzidMn8Ty7nT4vIj1iG5CW1JFedZtvhDJIzcjkvZh9IALQb4m+RDIZ6Q5VKR0QCsdwc+qpqLoCqrqptweoyK3Zasce6526D6H4QEu5niQyG+kOV0yu1gqgXAqG1L079YEVCMr2jwml0dINZKjcYPMSpTec5YIGInCci3USka/FRi7LVSTJzC4jbd4JrOmdBbrpROgaDhzjdkTzXfr2oTLliBVk/Y/hxz3HyCos4P/yAVWCUjsHgEU4NySbnuc2KhGRCgwPokrMVQptDy27+FslgqFd4pExEpKOInF1bwtQHVuxM4eyurQg6tN7anxNg9LHB4AmOvjEi0klEfsDK6vmtXXatiMyvTeHqGgdTs9ibkskFXRrDsa3QwezPMRg8xenP9CvAl1h7c/Ltsm8ob+OpEBHpKSJrRCTBfu3h5pnZInJMROLtY57LvcYi8oGI7BKR7SJypdO+vcX3CdZS+bhmdpx6sxPZYPAYp4bkEcAVqlokIgqgqmkiEuFBXy8D81T1HRG5CUuRXeDmubdV9S9uyv8CpKtqd1thrRSR7qpaNoxqrbEiIZn2zcNol7HeKmg/1FddGwwNBqcjnaNAd9cC2//qgJPKIhIFxHI6b9V7QKyItHbYP8B1WIoKVd0JxAGXeVC/RuQXFrF693HG9GyNJMVBZC8Ia+6r7g2GBoPTkc7TwCIReQwIsrNtPoDlae6EjkCSvdEQVS0UkUN2eXKZZ68XkYuBI8AsVV1jl3cC9rs8d8CuXwoRmQZMA4iOjvZagvodqYWcyi2gVe4R8vau5nir4exw0HaNk837ASOzb6iPMoMX5HaX4NzdAVwFLAZ+Ab4CJnpQdyjwS5myrUBsmbI2QLB9fhFwDGhlX2cArV2efRH4v8r6HTp0qKNE70548utt2vX+LzX90A7VWc1U173uqJ7TZPN1CSOzb6iPMqs6lxuIUzffS6eRAwNV9XPg82rqtoNAe7udQtufq51d7qoAj7icf2NnFu0PfI81sunM6ZFRJyxvd5+wIiGFIR2b0zQ53iowmwK9Rn5+PomJieTk5FS7jYiICLZt2+ZFqWqf+igzlJY7NDSUDh06EBwc7Li+0+nVERH5EHhXVX/wVEhVPSYi8cANwDv26wZVLTW1EpH2qppknw8GYoAd9u0PsbJSxNmG5OF2O7VOyqlcNiel8eeLekLipxDSBKL6+KLrM4LExESaNm1KTEwMUs1gaBkZGTRt2tTLktUu9VFmOC23qnL8+HESExPp0qWL4/pODckXYyXbe09E9orIYyIywENZ7wRmiEgCMMO+RkQWi0jx2vOjIrJFRDYCrwKTXUY/TwHNRWQXsAiYpqoZHspQLVbtTAFgTM/WkLgO2sdCwBnl/VGr5OTk0KpVq2orHIN/EBFatWrl8QjVqRvEBqx8V/eKyHlYI4ylInJYVQc6bGM7cJab8stdzqdUUj8T+LWTvrzNioRkWjQOpn9UCBzZDOf80R9iNGiMwqmfVOfvVp09/NuBbVg2lphq1K9XFBUpK3amMLpHawKPbISiAmPPacCICIMHD2bgwIHExsayapX/Q0dNnTqVN998E4CZM2eycOFCj+rHxcVx++23A7Bv376Stjxl7NixXlltc+oG0VxEbhOR77CyeY4FngCiaixBHWfbkXRSTuUypkekNbUCaG92Ijdk4uPj2bRpE3fccUfJl7WuMGfOHCZMmOBRnWHDhjF/vuWxVBOl4y2cjnQOYU2p/gu0V9WrVXWBWpk/GzQrEix7znnF9pwWMdDEkz2NhvrKmDFjOHDg9P7XGTNmMHz4cAYMGMCNN95YYst48803GT9+PFdddRV9+vRhwoQJ5ObmArB//35Gjx5N//79mT59Op07d2bfvn0AbN26lQsvvJBhw4YxYsQIR6Mq11HP1KlT+d3vfseYMWPo1KkTL7zwAq+++iojRoygR48erFljbXFbvnw5Y8eOBeDuu+8mLi6OwYMHc/fdVjKXlStXcu655zJ06FDGjBnD1q1bAUhNTeWKK66gb9++XHPNNWRnZ9f4MwXnSqebql6oqq+p6kkRaSkid4nIWq9IUYdZkZBM7zZNiWoWColxZmp1BrFw4UJ+/evTZsRZs2axbt06Nm/eTMuWLXnttddK7sXFxTF//ny2bt1KXl4eH3/8MQB/+MMf+M1vfsOWLVuYMGFCiRIrKCjgrrvu4vXXXycuLo7333+fyZMnF+9Bc8yePXtYunQpP/30Ew888AApKSmsXbuWRx55hFmzZpV7/tlnn2XYsGHEx8fz7LPPkpqayl/+8hcWLlzI+vXreeyxx7jtttsAePjhh+nbty9bt27loYceIi4uzuPP0B1ODcmHRSQIuAKYgpUZIhHbLaGhkplbQNz+VG49pwukJUHGIaN0zgAGDx7M8ePHSUtL46effiopX7hwIS+99BI5OTmkpaVRUFBQcm/s2LG0bm2NgIcPH86ePXsAWLFiBf/5z38AuOyyy2jRogUAO3bsYPv27aWmSnl5eRw7dozo6GjHsl599dUEBQXRtm1bmjdvzjXXXAPA0KFDeeCBB6qsv2bNGnbu3Mn5559fUpaamloi+1tvvQXAkCFDGDjQ0ZpRlTgJzD4US9HcYD//CZADjFLVY16Roo6yZvdx8gvVXiq3h75G6TR44uPjKSoq4r777uPmm29m3bp17Nu3r+TXvm3btrzwwgusX7++pE6jRo1KzgMDA0spJHcUFRXRqVMn4uPjy90rHhFFRkby7bffVtpO2X6Lr53IUCzHqFGjWLRoUZXPeotKp1cisgVYibV7+A6gjareBnhnclfHWbEzmbDgQIbFtLDsOUGhEN3f32IZfEBAQAD/+Mc/OH78OF9++SXp6emEhYURGRlJVlZWyeilKsaMGcN771l+zkuWLOHEiRMA9O7dm5ycHBYvXlzybPH0ZeHChcTHx1epcKpDs2bNSE9PL7keNWoU69evZ8OGDYClhH7++WcAzjvvPN59910ANm7cyObNm70iQ1U2ncZYmSCygSwgzyu91hNWJCQzslsrGgUFWkqn7WAICvG3WAYfERISwpw5c3jkkUcYOHAg48aNo3fv3owbN44RI5wFcHvuued4++23GTBgAJ988gnR0dFEREQQHBzM+++/zzPPPMOgQYPo06cPL730Ui2/Ixg4cCBRUVEMHDiQu+++m1atWvHhhx9y1113MWjQIPr168enn34KWMvzW7ZsoW/fvsyZM4ehQ70UysWdQ5aWdsIcA7yGlVr4KPACcAIX58u6etTE4XNfyint/NdF+saqPar5uapzWqt+/YDH7dRHpz5fy7x161aP63z6c6KOeuw7jfnrIh312Hf63uqdtSBZzcnMzNTCwkJVVV21apX26NGj5F56erq/xKoRZeWu6O9HdR0+VXUFsEJEfg/8CrgZK4LgchGZp6ovekf91S1W2FECx/RsDUc3Q2GusefUET7bkMT9n2wmO78QgKST2cz+ciehoWFMHNLe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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.lines import Line2D\n",
    "\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid()\n",
    "plt.plot(p1[\"numbins\"], p1[\"acc\"], marker=\"o\", \n",
    "         label=\"Range-limited\\nshuffling\")\n",
    "plt.plot(p2[\"numbins\"], p2[\"acc\"], marker=\"o\", \n",
    "         label=\"Range-limited\\nsampling\")\n",
    "\n",
    "# Adding the legend\n",
    "plt.legend(fontsize=10.5)\n",
    "\n",
    "plt.xticks(fontsize=11)\n",
    "plt.yticks(fontsize=11)\n",
    "plt.xlabel(\"Number of Ranges\", fontsize=12)\n",
    "plt.ylabel(\"1-shot Average Accuracy\", fontsize=12)\n",
    "# plt.title(model)\n",
    "plt.savefig(f'figs/discussion-numbins-both.png', dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "35ab8971",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66c26840",
   "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
}
