{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "67afdff9",
   "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": 28,
   "id": "325a01fe",
   "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": 29,
   "id": "34db94b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = pd.read_csv(\"/home/SemiTab/motivation/correlation.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "4f72b376",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['Test', 'masking', 'shuffling', 'noisemasking', 'rq',\n",
       "       'binshuffling-2', 'binsampling-2', 'binshuffling-3',\n",
       "       'binsampling-3', 'binshuffling-4', 'binsampling-4',\n",
       "       'binshuffling-5', 'binsampling-5', 'binshuffling-6',\n",
       "       'binsampling-6', 'binshuffling-7', 'binsampling-7',\n",
       "       'binshuffling-8', 'binsampling-8', 'binshuffling-9',\n",
       "       'binsampling-9', 'binshuffling-10', 'binsampling-10', 'scarf',\n",
       "       'cutmix'], dtype=object)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[\"transform\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "157185f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = data.groupby(\"transform\").mean(\"correlation\").reset_index()\n",
    "p = p[p[\"transform\"].isin([\n",
    "    \"Test\", \"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"cutmix\",\n",
    "    \"binshuffling-4\", \"binsampling-4\"])].reset_index(drop=True)\n",
    "p = p.set_index(\"transform\").loc[[\n",
    "    \"Test\", \"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"cutmix\",\n",
    "    \"binshuffling-4\", \"binsampling-4\"]].reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "2320b150",
   "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.grid(axis='y')\n",
    "plt.bar(p[\"transform\"], p[\"correlation\"])\n",
    "plt.yscale('log')\n",
    "plt.xticks(ticks=[0, 1, 2, 3, 4, 5, 6, 7, 8], \n",
    "           labels=[\n",
    "               'No aug.(Test)', 'Masking', 'Sampling', 'Shuffling',\n",
    "               'Noise', 'RQ', 'CutMix', 'Ours(Shuffling)', 'Ours(Sampling)'], \n",
    "           rotation=90, fontsize=12)\n",
    "plt.ylabel(\"Inter-feature correlation\\nchanges (log scale)\", fontsize=11.5)\n",
    "plt.savefig(\"figs/correlation.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "de88becf",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = data.groupby(\"transform\").mean(\"correlation\").reset_index()\n",
    "p = p[p[\"transform\"].str.startswith(\"bin\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "efb2969c",
   "metadata": {},
   "outputs": [],
   "source": [
    "q1, q2 = [], []\n",
    "for nb in range(2, 11):\n",
    "    q1.append(p[p[\"transform\"] == f'binsampling-{nb}'][\"correlation\"].values)\n",
    "    q2.append(p[p[\"transform\"] == f'binshuffling-{nb}'][\"correlation\"].values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "6535f9a7",
   "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": [
    "import matplotlib.pyplot as plt\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid()\n",
    "plt.plot(range(2, 11), q2, marker=\"o\", label=\"Range-limited shuffling\")\n",
    "plt.plot(range(2, 11), q1, marker=\"o\", label=\"Range-limited sampling\")\n",
    "plt.legend()\n",
    "plt.xlabel(\"Number of Ranges\")\n",
    "plt.ylabel(\"Inter-feature correlation changes\")\n",
    "plt.savefig(\"figs/numbins_corr.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f5cc579",
   "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
}
