{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "7c186e5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ce0b2a94",
   "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": 30,
   "id": "12ddd6e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "keys = [\n",
    "    'train', 'masking', 'shuffling', 'noisemasking', 'scarf', 'rq', \"cm\",\n",
    "    'binshuffling-2', 'binsampling-2', 'binshuffling-3', 'binsampling-3',\n",
    "    'binshuffling-4', 'binsampling-4', 'binshuffling-5', 'binsampling-5',\n",
    "    'binshuffling-6', 'binsampling-6', 'binshuffling-7', 'binsampling-7',\n",
    "    'binshuffling-8', 'binsampling-8', 'binshuffling-9', 'binsampling-9',\n",
    "    'binshuffling-10', 'binsampling-10'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "43e23ce6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1503\n",
      "40922\n",
      "44161\n",
      "39/42\n"
     ]
    }
   ],
   "source": [
    "done = 0\n",
    "result = dict()\n",
    "for k in keys:\n",
    "    result[k] = []\n",
    "for d in datalist:\n",
    "    fname = f'/home/SemiTab/motivation/usable-information-cutmix/model=mlp/train=transform/{d}.npy'\n",
    "    try:\n",
    "        data = np.load(fname, allow_pickle=True).item()\n",
    "        if data[\"train-acc\"] >= 0.95:\n",
    "            for k in keys:\n",
    "                result[k].append(data.get(k, 0))\n",
    "        done += 1\n",
    "    except FileNotFoundError:\n",
    "        print(d)\n",
    "        pass\n",
    "print(f'{done}/{len(datalist)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "f4ec8e1e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train 1.093\n",
      "masking 0.237\n",
      "shuffling 0.505\n",
      "noisemasking 0.481\n",
      "scarf 0.285\n",
      "rq -2.844\n",
      "cm 0.889\n",
      "binshuffling-2 0.0\n",
      "binsampling-2 0.0\n",
      "binshuffling-3 0.0\n",
      "binsampling-3 0.0\n",
      "binshuffling-4 1.058\n",
      "binsampling-4 1.054\n",
      "binshuffling-5 0.0\n",
      "binsampling-5 0.0\n",
      "binshuffling-6 0.0\n",
      "binsampling-6 0.0\n",
      "binshuffling-7 0.0\n",
      "binsampling-7 0.0\n",
      "binshuffling-8 0.0\n",
      "binsampling-8 0.0\n",
      "binshuffling-9 0.0\n",
      "binsampling-9 0.0\n",
      "binshuffling-10 0.0\n",
      "binsampling-10 0.0\n"
     ]
    }
   ],
   "source": [
    "for k in keys:\n",
    "    print(k, np.round(np.mean(np.ma.masked_invalid(np.array(result[k])), axis=0), 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1164a68a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "42/42\n"
     ]
    }
   ],
   "source": [
    "done = 0\n",
    "result = dict()    \n",
    "for k in keys:\n",
    "    result[k] = []\n",
    "for d in datalist:\n",
    "    fname = f'/home/SemiTab/motivation/usable-information/model=mlp/train=transform/{d}.npy'\n",
    "    try:  #mlp 16\n",
    "        data = np.load(fname, allow_pickle=True).item()\n",
    "        for k in keys:\n",
    "            if data.get(f'{k}-acc', 0) >= 0.95:\n",
    "                result[k].append(data[k])\n",
    "        done += 1\n",
    "    except FileNotFoundError:\n",
    "        print(d, end=\" \")\n",
    "        pass\n",
    "    \n",
    "print(f'{done}/{len(datalist)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "02f5da84",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train 1.058\n",
      "masking 0.138\n",
      "shuffling 0.42\n",
      "noisemasking 0.404\n",
      "scarf 0.052\n",
      "rq -3.264\n",
      "binshuffling-2 0.943\n",
      "binsampling-2 0.957\n",
      "binshuffling-3 1.135\n",
      "binsampling-3 1.114\n",
      "binshuffling-4 1.048\n",
      "binsampling-4 1.034\n",
      "binshuffling-5 1.062\n",
      "binsampling-5 1.055\n",
      "binshuffling-6 1.059\n",
      "binsampling-6 1.063\n",
      "binshuffling-7 1.069\n",
      "binsampling-7 1.06\n",
      "binshuffling-8 1.071\n",
      "binsampling-8 1.071\n",
      "binshuffling-9 1.073\n",
      "binsampling-9 1.063\n",
      "binshuffling-10 1.075\n",
      "binsampling-10 1.073\n"
     ]
    }
   ],
   "source": [
    "for k in result:\n",
    "    print(k, np.round(np.mean((np.array(result[k])), axis=0), 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca996df4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8b2a6bbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a69f2a32",
   "metadata": {},
   "outputs": [],
   "source": [
    "p1 = [np.mean(np.array(result['shuffling']))]\n",
    "p2 = [np.mean(np.array(result['scarf']))]\n",
    "for nb in range(2, 11):\n",
    "    p1.append(np.mean(np.array(result[f'binshuffling-{nb}'])))\n",
    "    p2.append(np.mean(np.array(result[f'binsampling-{nb}'])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4675ad28",
   "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(1, 11), p1, marker=\"o\", label=\"Range-limited shuffling\")\n",
    "plt.plot(range(1, 11), p2, marker=\"o\", label=\"Range-limited sampling\")\n",
    "plt.legend()\n",
    "plt.xlabel(\"Number of Ranges\")\n",
    "plt.ylabel(\"Usable Information\")\n",
    "plt.savefig(\"figs/numbins_usableinfo.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40991c6c",
   "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
}
