{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "foster-shower",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import csv\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from matplotlib import pyplot as plt\n",
    "import torch\n",
    "from wilds.datasets.waterbirds_dataset import WaterbirdsDataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "tight-matthew",
   "metadata": {},
   "outputs": [],
   "source": [
    "ENV_FILE = '/root/shared/ccorbiere/robustness/waterbirds/resnet18-earlystopping/erm/env_old_layers/env_labels.csv'\n",
    "\n",
    "dataset = WaterbirdsDataset(root_dir='/datasets_master/Waterbirds')\n",
    "env_df = pd.read_csv(ENV_FILE)\n",
    "all_background_true = dataset.metadata_array[env_df['img_id'].values,0]\n",
    "all_y_true = dataset.metadata_array[env_df['img_id'].values,1]\n",
    "all_background_pred = env_df['env'].values\n",
    "\n",
    "env2_c_landbird_land = all_background_pred[(all_y_true==0) & (all_background_true==0)].sum()\n",
    "env2_c_landbird_water = all_background_pred[(all_y_true==0) & (all_background_true==1)].sum()\n",
    "env2_c_waterbird_land = all_background_pred[(all_y_true==1) & (all_background_true==0)].sum()\n",
    "env2_c_waterbird_water = all_background_pred[(all_y_true==1) & (all_background_true==1)].sum()\n",
    "\n",
    "env1_c_landbird_land = len(all_background_pred[(all_y_true==0) & (all_background_true==0)]) - env2_c_landbird_land\n",
    "env1_c_landbird_water = len(all_background_pred[(all_y_true==0) & (all_background_true==1)]) - env2_c_landbird_water\n",
    "env1_c_waterbird_land = len(all_background_pred[(all_y_true==1) & (all_background_true==0)]) - env2_c_waterbird_land\n",
    "env1_c_waterbird_water = len(all_background_pred[(all_y_true==1) & (all_background_true==1)]) - env2_c_waterbird_water"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "searching-market",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fPJJ7rrrLq6//npuvvlmLr30UgAuvfRSzj77bPr168cLL7zA5MmTATjzzDP57W9/y4gRI5g2bRqnnXYaX//617ntrgcatH3aBb/khK8cwrR7x3LAXrsDcN+kqTw+/RluH/0r7r7+chYuWsTuBx/Hmp06cd/Y3/DQuFH07tWTPYd8g4WLFgFww7g7OXP4ZZx78teZevsYttx0Iy65cvQHvq5y2oUsmb9+3J3cfNXF3DlmBI8++U/O+MkIAD690w70XGdtbhx/17L6KSXGjBnDkUceWfbP+I033gCgR48eZT+nXN6kJ0mS1Mq6devG5ZdfTl1dHQMGDODggw/m7rvv5rTTTqN79+507dqVuro6NthgAwDeeustLrnkEu6880523nlnADbeeGP+/ve/M+KaG/jCnjsva/vbRw/hoH32bHC8NTt15OqfnkOnTtlQjauv+xMpJUb+bBgRAcAVF57B+lvvyfi/PMAh+32Wn181hq8cvC9fP+ogAM448Wvc+7cpzJg5q8nXdd0tdzTbLsDSd99l1M+G0b1bVwCOO+JARt4wDoC6ujqG7LcXo2+ewDe+nB37wQcfZNasWRx++OFl/XwXL17MySefzL777ku/fv3Kek4lTJAlSZJa2cCBA6mrq1u23adPHx5++OEm60+bNo23336bvffee1niCdkY4/79ejeoO2ibgcs9/+NbbrYsOQZ45PHp/GfWXLpusVODegsXvc2/n5sNwPQZ/+Frhx/QYP+On9z6AxPkctoF2Khv72XJMUCfDdZj3vxXl20f+aXP8/OrxvDc7Lls1K8Po0ePZtdddy0r2V26dClHHnkkr732GuPGjWu2fkuYIEuSJLWyDh06NNiOCN57770m69fvu/XWW9lwww0btrXg6Qbba3XpvNzz1+qyZkl7iW0/tgXXXXbBcnXXWbvl0+aV226HDg1TzKDh699uqwF8dLP+jLn5dk75xlHceOONDB8+vNnjL126lMMOO4wnnniCiRMnsu6667b4tXwQE2RJkqQaGzhwIJ06deK5555jjz32aLhz7n8rbm+7rT7KH265nZ7r9GDt7l0brTNgs42ZNPUJvjrkgGVlk6Y+scLtluvIAz/P6Jv/zMe33JS33nqLgw466APrL1myhCFDhvDkk08yceLEZcNT2oI36UmSJNVY165dOeWUUzjllFO4+uqrmTFjBo89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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env1_pct_env_grp = [\n",
    "    env1_c_landbird_land/(env1_c_landbird_land+env2_c_landbird_land),\n",
    "    env1_c_landbird_water/(env1_c_landbird_water+env2_c_landbird_water),\n",
    "    env1_c_waterbird_land/(env1_c_waterbird_land+env2_c_waterbird_land),\n",
    "    env1_c_waterbird_water/(env1_c_waterbird_water+env2_c_waterbird_water),\n",
    "]\n",
    "\n",
    "env2_pct_env_grp = [\n",
    "    env2_c_landbird_land/(env1_c_landbird_land+env2_c_landbird_land),\n",
    "    env2_c_landbird_water/(env1_c_landbird_water+env2_c_landbird_water),\n",
    "    env2_c_waterbird_land/(env1_c_waterbird_land+env2_c_waterbird_land),\n",
    "    env2_c_waterbird_water/(env1_c_waterbird_water+env2_c_waterbird_water),\n",
    "]\n",
    "\n",
    "name_labels = ['Landbirds \\n on land','Landbirds \\n on water', 'Waterbirds \\n on land', 'Waterbirds \\n on water']\n",
    "\n",
    "width = 0.35  # the width of the bars\n",
    "fig, ax = plt.subplots(figsize=(10,5))\n",
    "rects1 = ax.bar(np.array([0,1,2,3]) - width/2, env1_pct_env_grp, width, label='Inferred env 1')\n",
    "rects2 = ax.bar(np.array([0,1,2,3]) + width/2, env2_pct_env_grp, width, label='Inferred env 2')\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('p(Env|Group)', fontsize=16)\n",
    "ax.set_xticks(np.array([0,1,2,3]))\n",
    "ax.set_xticklabels(name_labels, fontsize=16)\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.legend(loc='best', fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "invalid-edward",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsgAAAFgCAYAAACmDI9oAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8+yak3AAAACXBIWXMAAAsTAAALEwEAmpwYAAAvsUlEQVR4nO3df5xVVb34/9fbEQQVEEV+CApqpnjRuF6y9Gbijz5Z/rzlD1QyrNS0upZSV0INtVtJfky6cT9iBXgTJbFM/HGVVH6YXzERzRQyUFFBDX9iOv6AWN8/9h7cHAbmnGHmnBl4PR+P85jZa6+z1vvMrHPmPXuvvVeklJAkSZKU2aLWAUiSJEltiQmyJEmSVGCCLEmSJBWYIEuSJEkFJsiSJElSwZa1DqCl9OjRIw0YMKDWYUiSJKmdePjhh19JKe1YWr7JJMgDBgxg3rx5tQ5DkiRJ7UREPNtYuVMsJEmSpAITZEmSJKnABFmSJEkqMEGWJEmSCkyQJUmSpIJN5i4WkiSp/XvzzTdZvnw5K1eurHUoauc6dOhAz5496dq1a8XPNUGWJEltwptvvsnf/vY3+vbtS+fOnYmIWoekdiqlxDvvvMOyZcsAKk6SnWIhSZLahOXLl9O3b1+23nprk2NtlIhg6623pm/fvixfvrzi55sgS5KkNmHlypV07ty51mFoE9K5c+dmTdcxQZYkSW2GR47Vkpo7nkyQJUmSpAITZEmSJKnAu1hIkqQ2bcAFt1e1vyU/OrLV+1i9ejVnn302N910E6+99hozZ85k6NChrd5vU6644gp+9rOfsWTJklqHUlMmyBup2m/aaqvGh4QkSe3ZiBEjeOWVV7jtttvKfs4dd9zBpEmTmDVrFrvtthvbb799K0a4afjtb3/LhAkTmD9/Pq+88kqr/lPhFAtJkqQqW7x4MX369OHAAw+kd+/edOzYsVntNHaHhvfff39jw2uT3n77bQ488ECuvPLKVu/LBFmSJKkFjRgxgqOOOopx48bRt29funfvzumnn059ff2a/d/61rd47rnniAgGDBgAZItbjB07lt13353OnTuzzz77cN11161pd8mSJUQEN9xwA4ceeiidO3dmwoQJa/q7/PLL6devH/369QNg2bJlDBs2jO7du9O9e3eOPPJIFi1atFasY8eOpXfv3my77bacdtppvPXWW02+vqbaHTNmDIMGDWLq1KnsvvvudOnSheOOO45XXnkFgBkzZtCxY0deffXVtdr97ne/y7777rvefr/whS/wve99j8985jNNxrixTJAlSZJa2H333cfjjz/O3Xffza9//Wtuvvlmxo0bB8C4ceO4+OKL6devHy+++CIPPfQQABdeeCG//OUvGT9+PAsWLGDUqFGcddZZ3H772tM5R40axTnnnMOCBQs47rjjAJg9ezaPPfYYd955J/fccw/19fUccsghdOrUidmzZ/PAAw/Qp08fDj/88DWJ+o033siFF17IJZdcwvz589lzzz2bPDpbTruQJfMNr3vGjBk88sgjjB49GoDDDjuMHj16MG3atDX1U0pcf/31DB8+fON+8C3EOciSJEktrGvXrlx99dXU1dUxcOBATjjhBO655x5GjRpFt27d6NKlC3V1dfTu3RvIpg9ceeWVzJgxg4MOOgiAXXfdlT/+8Y+MHz+eI4/84Jqgb3zjGxx//PFr9depUycmTpzIVlttBcDEiRNJKTFp0qQ19wKeMGECPXv25LbbbuPEE0/kqquu4otf/CJnnXUWAKNHj2bmzJksXrx4va9r6tSpTbYLsGrVKiZPnky3bt0AOPPMM5k0aRIAdXV1DBs2jClTpvDVr34VgPvvv5/nn3+eU045ZSN+6i3HBFmSJKmF7b333tTV1a3Z3mmnnXjwwQfXW3/BggW8++67HHHEEWstbrFy5co1UzAaDBkyZJ3nDxo0aE1yDPDwww/zzDPP0KVLl7Xq1dfX89RTTwGwcOFCvvKVr6y1/4ADDthgglxOuwD9+/dfkxxD9vqLSz4PHz6cq666imeffZb+/fszZcoUDj744DXTQ2rNBFmSJKmFdejQYa3tiGD16tXrrd+w79Zbb2WXXXbZYFvbbLPNOs8vLVu9ejWDBw9m6tSp69TdmDtmlNtuU69/v/32Y6+99uL6669n5MiRTJs2jbFjxzY7rpZmgixJklRje++9N1tttRXPPvsshx566Ea3t99++3HDDTfQo0cPtttuu0brDBw4kLlz5/KlL31pTdncuXM3ut1yDR8+nClTpjBo0CDefvvtdaaN1JIX6UmSJNVYly5dGDlyJCNHjmTixIksXryYRx99lKuvvpprrrmm4vZOPfVUevXqxbHHHsvs2bN55plnmDNnDueff/6aO06ce+65XHvttfz85z9n0aJF/PCHP9zgNJBy260kxgULFnDRRRdx9NFH07Vr1w3Wf+2113j00Ud5/PHHAdb8jF566aWK+i2HR5AlSVKbtrksWnXZZZfRq1cvrrjiCs4++2y6du3K4MGD+c53vlNxW1tvvTVz5szhggsu4IQTTmDFihXstNNOHHLIIXTv3h2Ak046iaeffprRo0dTX1/PMcccw3nnncfkyZM3qt1y9e/fn0984hPcd999XHrppU3Wnz59Oqeffvqa7TPOOAOA733ve4wZM6aivpsSKaUWbbBWhgwZkubNm1f1fl1JT5KklrFw4UIGDhxY6zC0idnQuIqIh1NK61z16BQLSZIkqcAEWZIkSSowQZYkSZIKTJAlSZKkAhNkSZIkqcAEWZIkSSowQZYkSZIKTJAlSZKkAhNkSZIkqcClpiVJUts2pluV+1vR6l2sXr2as88+m5tuuonXXnuNmTNnMnTo0FbvtylXXHEFP/vZz1iyZEmtQ6kpjyBLkiRthBEjRnDUUUdV9Jw77riDSZMmceutt/Liiy9y4IEHtlJ0m4aVK1fyH//xH+y7775ss8029OnTh1NOOYXnnnuuVfozQZYkSaqyxYsX06dPHw488EB69+5Nx44dm9XOypUr1yl7//33Nza8Nqe+vp758+czevRo5s+fzy233MLzzz/PEUccwapVq1q8PxNkSZKkFtRwRHncuHH07duX7t27c/rpp1NfX79m/7e+9S2ee+45IoIBAwYAkFJi7Nix7L777nTu3Jl99tmH6667bk27S5YsISK44YYbOPTQQ+ncuTMTJkxY09/ll19Ov3796NevHwDLli1j2LBhdO/ene7du3PkkUeyaNGitWIdO3YsvXv3Ztttt+W0007jrbfeavL1NdXumDFjGDRoEFOnTmX33XenS5cuHHfccbzyyisAzJgxg44dO/Lqq6+u1e53v/td9t1330b77NatG7///e856aST2HPPPdl///2ZMGECCxcuZOHChU3GXCkTZEmSpBZ233338fjjj3P33Xfz61//mptvvplx48YBMG7cOC6++GL69evHiy++yEMPPQTAhRdeyC9/+UvGjx/PggULGDVqFGeddRa33377Wm2PGjWKc845hwULFnDccccBMHv2bB577DHuvPNO7rnnHurr6znkkEPo1KkTs2fP5oEHHqBPnz4cfvjhaxL1G2+8kQsvvJBLLrmE+fPns+eee3LllVdu8HWV0y5kyXzD654xYwaPPPIIo0ePBuCwww6jR48eTJs2bU39lBLXX389w4cPL/tn/OabbwLQvXv3sp9TLi/SkyRJamFdu3bl6quvpq6ujoEDB3LCCSdwzz33MGrUKLp160aXLl2oq6ujd+/eALz99ttceeWVzJgxg4MOOgiAXXfdlT/+8Y+MHz+eI488ck3b3/jGNzj++OPX6q9Tp05MnDiRrbbaCoCJEyeSUmLSpElEBAATJkygZ8+e3HbbbZx44olcddVVfPGLX+Sss84CYPTo0cycOZPFixev93VNnTq1yXYBVq1axeTJk+nWLbvA8swzz2TSpEkA1NXVMWzYMKZMmcJXv/pVAO6//36ef/55TjnllLJ+vu+//z7nn38+Rx999Joj5i3JBFmSJKmF7b333tTV1a3Z3mmnnXjwwQfXW3/BggW8++67HHHEEWsST8jmGDdMwWgwZMiQdZ4/aNCgNckxwMMPP8wzzzxDly5d1qpXX1/PU089BcDChQv5yle+stb+Aw44YIMJcjntAvTv339NcgzZ61++fPma7eHDh3PVVVfx7LPP0r9/f6ZMmcLBBx9cVrK7atUqhg8fzhtvvMH06dObrN8cJsiSJEktrEOHDmttRwSrV69eb/2Gfbfeeiu77LLLBtvaZptt1nl+adnq1asZPHgwU6dOXafu9ttvv+HgN6Dcdpt6/fvttx977bUX119/PSNHjmTatGmMHTu2yf5XrVrFySefzJ///GdmzZrFDjvs0OzXsiEmyJIkSTW29957s9VWW/Hss89y6KGHbnR7++23HzfccAM9evRgu+22a7TOwIEDmTt3Ll/60pfWlM2dO3ej2y3X8OHDmTJlCoMGDeLtt99eZ9pIqZUrVzJs2DAef/xxZs2atWZ6SmvwIj1JkqQa69KlCyNHjmTkyJFMnDiRxYsX8+ijj3L11VdzzTXXVNzeqaeeSq9evTj22GOZPXs2zzzzDHPmzOH8889fc8eJc889l2uvvZaf//znLFq0iB/+8IcbnAZSbruVxLhgwQIuuugijj76aLp27breuqtWreKEE05g7ty53HDDDUQEL730Ei+99BLvvPNORf2WwyPIkiSpbavCynZtwWWXXUavXr244oorOPvss+natSuDBw/mO9/5TsVtbb311syZM4cLLriAE044gRUr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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env1_pct_grp_env = [\n",
    "    env1_c_landbird_land/(env1_c_waterbird_water+env1_c_waterbird_land+env1_c_landbird_water+env1_c_landbird_land),\n",
    "    env1_c_landbird_water/(env1_c_waterbird_water+env1_c_waterbird_land+env1_c_landbird_water+env1_c_landbird_land),\n",
    "    env1_c_waterbird_land/(env1_c_waterbird_water+env1_c_waterbird_land+env1_c_landbird_water+env1_c_landbird_land),\n",
    "    env1_c_waterbird_water/(env1_c_waterbird_water+env1_c_waterbird_land+env1_c_landbird_water+env1_c_landbird_land),\n",
    "]\n",
    "\n",
    "env2_pct_grp_env = [\n",
    "    env2_c_landbird_land/(env2_c_waterbird_water+env2_c_waterbird_land+env2_c_landbird_water+env2_c_landbird_land),\n",
    "    env2_c_landbird_water/(env2_c_waterbird_water+env2_c_waterbird_land+env2_c_landbird_water+env2_c_landbird_land),\n",
    "    env2_c_waterbird_land/(env2_c_waterbird_water+env2_c_waterbird_land+env2_c_landbird_water+env2_c_landbird_land),\n",
    "    env2_c_waterbird_water/(env2_c_waterbird_water+env2_c_waterbird_land+env2_c_landbird_water+env2_c_landbird_land),\n",
    "]\n",
    "\n",
    "name_labels = ['Landbirds \\n on land','Landbirds \\n on water', 'Waterbirds \\n on land', 'Waterbirds \\n on water']\n",
    "\n",
    "width = 0.35  # the width of the bars\n",
    "fig, ax = plt.subplots(figsize=(10,5))\n",
    "rects1 = ax.bar(np.array([0,1,2,3]) - width/2, env1_pct_grp_env, width, label='Inferred env 1')\n",
    "rects2 = ax.bar(np.array([0,1,2,3]) + width/2, env2_pct_grp_env, width, label='Inferred env 2')\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('p(Group|Env)', fontsize=16)\n",
    "ax.set_xticks(np.array([0,1,2,3]))\n",
    "ax.set_xticklabels(name_labels, fontsize=16)\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.legend(loc='best', fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "generic-panic",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pct_grp = [\n",
    "    (env1_c_landbird_land+env2_c_landbird_land)/len(all_background_pred),\n",
    "    (env1_c_landbird_water+env2_c_landbird_water)/len(all_background_pred),\n",
    "    (env1_c_waterbird_land+env2_c_waterbird_land)/len(all_background_pred),\n",
    "    (env1_c_waterbird_water+env2_c_waterbird_water)/len(all_background_pred),\n",
    "]\n",
    "\n",
    "name_labels = ['Landbirds \\n on land','Landbirds \\n on water', 'Waterbirds \\n on land', 'Waterbirds \\n on water']\n",
    "\n",
    "width = 0.35  # the width of the bars\n",
    "fig, ax = plt.subplots(figsize=(10,5))\n",
    "rects1 = ax.bar(np.array([0,1,2,3]), pct_grp, width, color='green')\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('p(Group)', fontsize=16)\n",
    "ax.set_xticks(np.array([0,1,2,3]))\n",
    "ax.set_xticklabels(name_labels, fontsize=16)\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "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": 5
}
