{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import StrMethodFormatter\n",
    "import seaborn as sns\n",
    "\n",
    "T = np.array([1,5,10,20,50,100,300])\n",
    "K = np.array([2,4,8,16,32,64])\n",
    "\n",
    "wgp_accuracy = np.array([81.2, 78.2, 76.7, 78.9, 78.9, 75.2])\n",
    "wgp_erm = 60.2\n",
    "wgp_groupdro = 78.4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(7,5))\n",
    "\n",
    "plt.plot(T,wgp_accuracy, marker='o', linewidth=3.0, markersize=8, label='GramCluster')\n",
    "plt.axhline(y=wgp_erm, color='r', linestyle='--', linewidth=3.0, label='ERM')\n",
    "plt.axhline(y=wgp_groupdro, color='g', linestyle='--', linewidth=3.0, label='GroupDRO')\n",
    "plt.xlabel('Number of epochs in identification model (T)', fontsize=16)\n",
    "plt.ylabel('Worst-group Accuracy (%)', fontsize=16)\n",
    "plt.xticks(fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.gca().yaxis.set_major_formatter(StrMethodFormatter('{x:,.0f}')) \n",
    "#plt.ylim(ymin=70, ymax=94)\n",
    "plt.legend(prop={'size': 12},loc='best')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(7,5))\n",
    "\n",
    "plt.plot(K,wgp_accuracy, marker='o', linewidth=3.0, markersize=8, label=r'GramCluster')\n",
    "plt.axhline(y=wgp_erm, color='r', linestyle='--', linewidth=3.0, label='ERM')\n",
    "plt.axhline(y=wgp_groupdro, color='g', linestyle='--', linewidth=3.0, label='GroupDRO')\n",
    "plt.xlabel('Number of clusters (K)', fontsize=16)\n",
    "plt.ylabel('Worst-group Accuracy (%)', fontsize=16)\n",
    "plt.xticks(K, fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.gca().yaxis.set_major_formatter(StrMethodFormatter('{x:,.0f}')) \n",
    "#plt.ylim(ymin=70, ymax=94)\n",
    "plt.legend(prop={'size': 12},loc='best')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "wgp_kmeans_layers = np.array([85.3, 84.8, 84.0, 82.0, 79.5, 78.0, 77.5])\n",
    "wgp_spectral_layers = np.array([85.3, 84.8, 84.0, 82.0, 79.5, 78.0, 77.5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f32aec9e0d0>"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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bEkAfwV8NyJWBx4AVgYOpDhs/hfNClaSJEmSWpx00klsuummXH/99ay88srt1tt9993ZcMMN+elPf8rpp5/OhAkT2Gmnndh0001fU/eyyy7jrrvu4s4772S33XYDYK+99gLg7LPP5rTTTmO99dZj7bXX5qKLLlr2uaVLl7Lffvux/vrrc9lll3HyySe/qt3DDjuMs88+G4C9996be++9l8suu2zZvd/+9rfsu+++fPKTn1z2mQMPPLCLfzP16XBkMDM/BLwbeCfwcEQcUBadADwP/IzicPrfA18EHgQ+3rRoJUmSJKk0ZswYnnjiiVeNsLUlIvjQhz7ExIkTWbx4MVdccUWbo4IAN910ExtttBE77bQTL7/88rJr3333ZcmSJUydOnVZ3SuvvJIddtiBwYMHs+KKK7L66qvz0ksv8fjjj7cZa62tttqKp59+etn70aNH88tf/pIzzjiDu+66i8WLF1f5q+iSTjeQyczJwFuAW4DJEXEJ8FJmbgvsB5xUXvtk5ujMnNm8cCVJkiSp8I1vfINjjjmGs88+m/PPP7/DumPHjuWRRx7h7LPP5t///jeHHnpom/XmzJnDjBkzGDRo0Kuu7bffHoC///3vAEyaNIlDDz2UN7/5zVx66aXce++93HfffQwdOvRVawFbvP71r3/V+5VXXplFixYte/+5z32Os88+mxtuuIFdd92Vddddl6OPPprnn3++0t9JFXWt78vMF4FjI+JyYDzFKOHHMvNa4NamRSdJkiRJ7YgIxo8fz8KFCzn99NNZeeWVOemkk9qs+6Y3vYkddtiB8847j4MPPpjBgwe3WW/ddddl44035sorr2yzfOTIkQBcfvnlbLbZZlx88cXLypYsWdLlNX6DBg3itNNO47TTTmPWrFn84he/4FOf+hTz58/niiuu6FKbnam02Utm3hYRWwHnA1dFxFXAxzKzeemqJEmSJLXjda97HZdccgmLFy/m5JNPZpVVVuEjH/lIm3VPPfVUJkyYwMc/3v7Ktv3335+rr76aNdZYgy233LLdevPnz2fFFV+dTk2cOJGlS5d27QupMWzYMI499lh++ctf8tBDD3W7vfbUlQxGxBBgI2BGmfh9vDx0/iLg0Yg4MTMva1qUkiRJktSOFVZYgUsvvZTFixdzwgknsPLKK3P00Ue/pt7BBx/MwQcf3GFbhx9++LKdPE85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\n",
      "text/plain": [
       "<Figure size 1080x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "results= {}\n",
    "layers = ['conv1_1','conv2_1','conv3_1','conv4_1','conv5_1','conv5_3']\n",
    "#results['Spectral'] =  np.array([85.3, 84.8, 84.0, 82.0, 79.5, 79.5, 78.0])\n",
    "results['KMeans'] = np.array([81.1, 79.2, 73.6, 77.6, 85.1, 51.2])\n",
    "\n",
    "pd.DataFrame(results,index=layers).plot(kind='bar', capsize=0, figsize=(15,5), rot=0)\n",
    "plt.ylim(ymin=50, ymax=90)\n",
    "plt.xticks(fontsize=16)\n",
    "plt.ylabel('Worst-group Accuracy (%)', fontsize=20)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.legend(fontsize=16, loc='best')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from skimage import io\n",
    "\n",
    "biased_colours = np.array([[0,100,0],\n",
    "                  [188, 143, 143],\n",
    "                  [255, 0, 0],\n",
    "                  [255, 215, 0],\n",
    "                  [0, 255, 0],\n",
    "                  [65, 105, 225],\n",
    "                  [0, 225, 225],\n",
    "                  [0, 0, 255],\n",
    "                  [255, 20, 147]],dtype=np.uint8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "indices = np.random.randint(0, len(biased_colours), size=(2, 5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f32aedabad0>"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "io.imshow(biased_colours[ind])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "ind = np.array([[0,1,2,3,4],[5,6,7,8,8]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[8, 5, 0, 3, 8],\n",
       "       [6, 2, 3, 3, 2]])"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
