{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "95ebf436",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2116a606",
   "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": 22,
   "id": "299bdab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = pd.read_csv(\"/home/SemiTab/motivation/clustering.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "f0fae98a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['masking', 'shuffling', 'noisemasking', 'rq', 'binshuffling-2',\n",
       "       'binsampling-2', 'binshuffling-3', 'binsampling-3',\n",
       "       'binshuffling-4', 'binsampling-4', 'binshuffling-5',\n",
       "       'binsampling-5', 'binshuffling-6', 'binsampling-6',\n",
       "       'binshuffling-7', 'binsampling-7', 'binshuffling-8',\n",
       "       'binsampling-8', 'binshuffling-9', 'binsampling-9',\n",
       "       'binshuffling-10', 'binsampling-10', 'scarf', 'cutmix'],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[\"transform\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "099a87b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = data.groupby(\"transform\").mean(\"correlation\").reset_index()\n",
    "p = p[p[\"transform\"].isin([\n",
    "    \"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"cutmix\",\n",
    "    \"binshuffling-4\", \"binsampling-4\"])].reset_index(drop=True)\n",
    "p = p.set_index(\"transform\").loc[[\n",
    "    \"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"cutmix\", \"binshuffling-4\", \"binsampling-4\"]].reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "0441a498",
   "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>transform</th>\n",
       "      <th>data_id</th>\n",
       "      <th>clustering</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>masking</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>0.388184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>scarf</td>\n",
       "      <td>18056.261905</td>\n",
       "      <td>0.399868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>shuffling</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>0.471507</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>noisemasking</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>0.467287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>rq</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>-0.000249</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>cutmix</td>\n",
       "      <td>17636.860465</td>\n",
       "      <td>0.681398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>binshuffling-4</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>0.842730</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>binsampling-4</td>\n",
       "      <td>16182.326531</td>\n",
       "      <td>0.826398</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        transform       data_id  clustering\n",
       "0         masking  16182.326531    0.388184\n",
       "1           scarf  18056.261905    0.399868\n",
       "2       shuffling  16182.326531    0.471507\n",
       "3    noisemasking  16182.326531    0.467287\n",
       "4              rq  16182.326531   -0.000249\n",
       "5          cutmix  17636.860465    0.681398\n",
       "6  binshuffling-4  16182.326531    0.842730\n",
       "7   binsampling-4  16182.326531    0.826398"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "61c4f7ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.bar(p[\"transform\"], p[\"clustering\"])\n",
    "plt.xticks(ticks=[0, 1, 2, 3, 4, 5, 6, 7], \n",
    "           labels=[\n",
    "               'Masking', 'Sampling', 'Shuffling',\n",
    "               'Noise', 'RQ', 'CutMix', 'Ours(Shuffling)', 'Ours(Sampling)'], \n",
    "           rotation=90, fontsize=12)\n",
    "plt.yscale('log')\n",
    "plt.grid(axis='y', which='both')\n",
    "plt.minorticks_on() \n",
    "plt.ylabel(\"ARI Score\", fontsize=11.5)\n",
    "plt.savefig(\"figs/clustering.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3a99679f",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = data.groupby(\"transform\").mean(\"correlation\").reset_index()\n",
    "# p = p[p[\"transform\"].str.startswith(\"bin\")].reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "6998b0fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "p1, p2 = [], []\n",
    "for nb in range(2, 11):\n",
    "    p1.append(p.loc[p[\"transform\"] == f'binshuffling-{nb}', \"clustering\"].values[0])\n",
    "    p2.append(p.loc[p[\"transform\"] == f'binsampling-{nb}', \"clustering\"].values[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "fadd4e43",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Y4mOjmbIkCEkJSX5zJa+ffuydu1aAK677rpS2TJt2jReftnaGz1lyhS2bdtWQonC1KlTx+28kZGRnDhxolT1v/POO3Ts2JHbb7+djIwMrrnmGmJjY/n+++/L5bs3MMGnCKbFJdK6YShdWoQVn3HzZDi00tq/FVxC3irAlA0J9H55AW2emEnvlxcwZUNCuesMCQkhLi6OLVu20KBBAyZOnOgBS8vPrFmzCA8Pdzv/0KFDeeKJJ4CyBx9v8/777zN37ly+/vprNmzYAEBcXBy33nprvnyl9d0bmODjgmMp6Szfc4IbujQvvjmZkQpz/wnNu0LsqIoz0EtM2ZDAuJ82k5CUhmKJp437abNHApCDXr16kZBg1bd69Wp69epF165dufzyy9m5cycAn3/+OcOHD2fgwIHExsYyZsyYvPKffPIJ7dq1o2fPntx777089JC1pOH48ePceOON9OjRgx49erBs2bISbXG0LPbv30+HDh24++67adeuHbfffjvz5s2jd+/etG3bltWrV+fZ9dBDD7F8+XKmTZvG6NGjiY2NZc+ePezZs4eBAwfSrVs3rrjiCnbs2AHAvn376NWrFzExMUyY4Fqz++zZs1x//fV06dKF6Ohovv/++7x77777LpdccgkxMTF5dY4fP57XX389L090dDT79+/n/vvvZ+/evQwaNIhXXnmFUaNGsWbNmjwbi/K9Y8eO3HvvvURFRdG/f3/S0iy98TVr1tC5c2diY2MZPXo00dHRJX6mpcHMdrlg5qbD5Coln0a69E1IOQy3fAl+lT+OPzd9K9sSzxR5f8PBJDJzcvOlpWXlMGbyJr5dfdBlmU7N6/HskCi3np+Tk8P8+fP505+sI6I7dOjAkiVLCAgIYN68eTz55JP8+OOPgPXfesOGDWRmZtK9e3cefvhh/P39ef7551m/fj1169bl6quvpkuXLgA8+uijPPbYY/Tp04eDBw8yYMCAUk1r7969m0mTJvHpp5/So0cPvvnmG5YuXcq0adN48cUXmTJlSl7eyy+/nKFDhzJ48GBuuukmAPr168eHH35I27ZtWbVqFQ888AALFizg0Ucf5a9//St33nknb7zxhstnz549m+bNmzNz5kwAkpOT8+41atSI9evX8/777/P666/z8ccfF+nDhx9+yOzZs1m4cCGNGjXi0ksv5fXXX2fGjBnF+r5r1y6+/fZbPvroI2655RZ+/PFHRo0axT333MNHH31Er1698lp8nsQEHxdMjUskqnk9Lr6gmGnRU3th+bvQeQS07FlxxnmRgoGnpHR3SUtLIzY2loSEBDp27Mi1114LWF+yu+66i127diEiZGVl5ZXp168fYWFhpKSk0KlTJw4cOMCJEye48soradCgAQA333wzv//+OwDz5s3L1w06c+YMqampbo+xtGnThpiYGACioqLo168fIkJMTAz79+8vtmxqairLly/n5ptvzkvLyMgAYNmyZXkBdcSIETz77LOFysfExPD3v/+dsWPHMnjwYK644oq8e8OHDwegW7du/PTTT275UlratGlDbGxs3nP2799PUlISKSkp9OrVC4DbbrutxCBWWkzwKcCBk2eJO5TEuEEdis845ynr8L9rxleIXZ6gpBZK75cXkJCUVig9IjyE7+/rVebnOsZ8zp07x4ABA5g4cSKPPPII//znP7nqqqv4+eef2b9/P3379s0rU6vWeekSf39/srOzi31Gbm4uK1euJDg4/+LOAQMGcPToUbp3715sq8H5eX5+fnnXfn5+bj07PDycuLg4l/dLmglq164d69evZ9asWTz99NP069ePZ555Jp9dzp9BQEAAubnn/yGUdwFpwc/a0e3yNpW/r1DBTIuzdJqHFKfTvHse7JwFfxgN9ZpVkGXeZ/SA9oQUWMkdEujP6AGeWT4QGhrKO++8wxtvvEF2djbJyclERFiziZ9//nmJ5Xv06MHixYs5ffo02dnZeS0KgP79+/Puu+/mXTsCwZw5c4iLiys28JSFunXrkpKSAkC9evVo06YNkyZZB/mqKhs3bgSgd+/efPfddwD88MMPLutKTEwkNDSUUaNGMXr0aNavX1/ssyMjI/PyrF+/nn379nnEJ2fCw8OpW7cuq1atAsjzwZOY4OOEqjIlLoGebRrQPLyIY4yzM639Ww0uhMv+WrEGeplhXSN4aXgMEeEhCFaL56XhMQzr6rkNsl27dqVz5858++23jBkzhnHjxtG1a9cSWxcAERERPPnkk/Ts2ZPevXsTGRlJWJg1w/jOO++wdu1aOnfuTKdOnfjwww89ZrMrRowYwWuvvUbXrl3Zs2cPX3/9NZ988gldunQhKiqKqVOnAvD2228zceJEYmJiSExMdFnX5s2b6dmzJ7GxsTz33HM8/fTTxT77xhtv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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()\n",
    "plt.plot(p1, marker=\"o\", label=\"Range-limited shuffling\")\n",
    "plt.plot(p2, marker=\"o\", label=\"Range-limited sampling\")\n",
    "plt.xlabel(\"Number of ranges\", fontsize=11)\n",
    "plt.ylabel(\"ARI Score\", fontsize=11)\n",
    "plt.legend()\n",
    "plt.savefig(\"figs/clustering-numbins.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd3b07dc",
   "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
}
