{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt\n",
    "from tqdm import tqdm\n",
    "\n",
    "from mutual_information import mutual_information_T_Y, mutual_information_X_T, mutual_information_T_C\n",
    "from utils_cv import NO_CBM, CBM_bool, CBM_fuzzy, HYBRID, CEM, name_mappings, color_mappings, \\\n",
    "    marker_mappings, NO_CBM_plus"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "dataset = \"celeba\"\n",
    "\n",
    "result_folder = \"results\"\n",
    "image_folder = \"images\"\n",
    "cub_folder = \"celeba_results\"\n",
    "data_folder = os.path.join(result_folder, cub_folder)\n",
    "\n",
    "output_file = \"test_embedding_vectors_on_epoch\"\n",
    "\n",
    "methods = [NO_CBM_plus, CBM_bool, CBM_fuzzy, HYBRID, CEM]\n",
    "methods_low_variance = methods[:4]\n",
    "methods_high_variance = methods[-1:]\n",
    "\n",
    "seeds = [*range(1, 3)]\n",
    "epochs = [*range(100), *range(100, 200, 20), 200]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "labels_c = np.load(os.path.join(data_folder, \"c_val.npy\"), allow_pickle=True)\n",
    "labels_y = np.load(os.path.join(data_folder, \"y_val.npy\"), allow_pickle=True)\n",
    "\n",
    "debug = True\n",
    "metrics = []\n",
    "for seed in seeds:\n",
    "    for method in methods:\n",
    "        folder_name = os.path.join(data_folder, f\"{method}_resnet34_fold_{seed}\")\n",
    "\n",
    "        file = os.path.join(folder_name, f\"{output_file}_{epochs[0]}.npy\")\n",
    "        output = np.load(file, allow_pickle=True)\n",
    "        N = output.shape[1]\n",
    "        noise_variance = N/10 if method != SplitEmbedding and method != CBM_fuzzy_plus else N\n",
    "\n",
    "        for epoch in tqdm(epochs, desc=folder_name):\n",
    "\n",
    "            file = os.path.join(folder_name, f\"{output_file}_{epoch}.npy\")\n",
    "            output = np.load(file, allow_pickle=True)\n",
    "\n",
    "            MI_X_T, H_T, H_X_T = mutual_information_X_T(output,\n",
    "                                                        return_H=True, noise_variance=noise_variance)\n",
    "            MI_T_C, _, H_T_C  = mutual_information_T_C(output, labels_c, entropy_T=H_T,\n",
    "                                                       return_H=True, noise_variance=noise_variance)\n",
    "            MI_T_Y, _, H_T_Y = mutual_information_T_Y(output, labels_y, entropy_T=H_T,\n",
    "                                                      return_H=True, noise_variance=noise_variance)\n",
    "\n",
    "            epoch_metric = {\n",
    "                \"dataset\": dataset,\n",
    "                \"method\": method,\n",
    "                \"seed\": seed,\n",
    "                \"epoch\": epoch,\n",
    "                \"H(T)\": H_T,\n",
    "                \"H(X|T)\": H_X_T,\n",
    "                \"H(T|C)\": H_T_C,\n",
    "                \"H(T|Y)\": H_T_Y,\n",
    "                \"I(X,T)\": MI_X_T,\n",
    "                \"I(T,C)\": MI_T_C,\n",
    "                \"I(T,Y)\": MI_T_Y,\n",
    "            }\n",
    "            metrics.append(epoch_metric)\n",
    "            if debug == 2:\n",
    "                print(f\"\\nH(T): {H_T:.2f}, H(X|T): {H_X_T:.2f}, H(T|C): {H_T_C:.2f}, H(T|Y): {H_T_Y:.2f}, \"\n",
    "                      f\"I(X,T): {MI_X_T:.2f}, I(T,C): {MI_T_C:.2f}, I(T,Y): {MI_T_Y:.2f}\")\n",
    "\n",
    "        if seed == 1 and debug:\n",
    "            df = pd.DataFrame(metrics)\n",
    "            ax = sns.scatterplot(data=df, x=\"I(X,T)\", y=\"I(T,Y)\", size=\"epoch\", hue=\"method\")\n",
    "            ax.legend().set_visible(False)\n",
    "            plt.show()\n",
    "            ax = sns.scatterplot(data=df, x=\"I(X,T)\", y=\"I(T,C)\", size=\"epoch\", hue=\"method\")\n",
    "            ax.legend().set_visible(False)\n",
    "            plt.show()\n",
    "\n",
    "df = pd.DataFrame(metrics)\n",
    "df.to_pickle(f\"{dataset}_results.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "df = pd.read_pickle(f\"{dataset}_results.pkl\")\n",
    "\n",
    "if not os.path.isdir(image_folder):\n",
    "    os.makedirs(image_folder)\n",
    "\n",
    "df_mean = df.groupby([\"dataset\", \"method\", \"epoch\"]).mean().reset_index()\n",
    "\n",
    "\n",
    "methods = []\n",
    "for i, row in df_mean.iterrows():\n",
    "    methods.append(name_mappings[row['method']])\n",
    "df_mean['Methods'] = methods\n",
    "methods = np.unique(np.asarray(methods)).tolist()\n",
    "methods_before_mappings = np.unique(np.asarray(df_mean['method'])).tolist()\n",
    "print(methods)\n",
    "print(methods_before_mappings)\n",
    "df_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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aLG2o2Ms69evj51pH12TYrVaUVWVYz39GLazK+r+qcTWxUX439lSPWMMOCo3gztHpOG1aHHve2bHEFeO6i7jKkKINiml/9m8ePFibrvtNi677DJOOukkli5dyvTp03E6nZx55pnN0qZpmmzatIlVK75ky7adADidToLBIE6nE5fLhWEYBAIBRo8ezaDCjkd8z+qAgRkrK6mMqBIsQog2L6XD5a9//Svjx4/nrrvuAuCkk06ivLycv/3tb80WLjt37mDBv/9FpHptJBaLBavVWj3FOBDA6XRimibHHXcco0ePxhhpxJ1bHxnfsc5z64/KzeCu4yx8ua2ci4dLsAgh2raUvS22bds2CgsLOf300+Oun3HGGWzatIlt27Y1S7s//bQJp91NOBzGaq3+zxOJRLDb7bEeTEZGBmPGjMFqtTZoGnHfTulMGSHBIoRo+1K257Jp0yYAevfuHXe9Z8+eAGzevJnu3bsnvN3oF79pmpimicvlIhAIxB6vrKxk5MiRca+Rc+uFECJeyvZcKisrAfB6vXHXPR4PUL23V3Po1asnuhaIbUIZCARigRMMBunQoQP9+vWLe03NhZDSKxFCiBQOl+juwgd/WUevR29ZJVpubmc+CG7ADBezJVhOUAtiGAa6rpObm8uZZ55J165dm6VtIYRoK1L2tlhaWhpQu4fi8/niHk80VVX5962zYutZotvp17WjsRBCiLqlbM8lOtZSWFgYd33r1q1xjyda9BaX2+2ODeIffGyxEEKIw0vZcOnZsyd5eXl88MEHcdc//PBDevXqJbemhBAihaXsbTGA66+/njvvvDM29ffjjz9m8eLFPP7448kuTQghxGGkdLice+65aJrGiy++yFtvvUX37t159NFHmTBhQrJLE0IIcRgpHS4AF154IRdeeGGyyxBCCNEAKTvmIoQQovWScBFCCJFwKX9brCnC4TAAu3fvTnIlQgjRNnXu3BmljnOp2nS4FBVV71Q8ZcqUJFcihBBt07Jly8jLy6t13WJG91Npg4LBIKtXr6Zjx47YbLZklyOEEG3OoXoubTpchBBCJIcM6AshhEg4CRchhBAJJ+EihBAi4SRchBBCJJyEixBCiISTcBFCCJFwEi5CCCESrt2Gy/vvv8/EiRMZMmQI48ePZ8GCBckuqcVEIhHmzZvHpEmTGDZsGOPGjWPGjBm1jpRuD2644QZOO+20ZJfRYlasWMFFF13E0KFDOfHEE/nTn/4UOzq8PZg3bx7jx4/n2GOPZdKkSfz73/9OdknNbt26dQwaNKjWNlifffYZ5513HkOHDuXUU0/lxRdfTGi77TJcFi9ezG233UZBQQGzZs1i1KhRTJ8+vdapl23V888/z5/+9CfGjBnDrFmzuPLKK1mwYAG/+93vkl1ai3r33Xf56KOPkl1Gi/n222+58sor6dixI88++yzXX389//73v7n77ruTXVqLePPNN7nvvvsYM2YMzzzzDCeccAK33347ixcvTnZpzWbTpk1cc801GIYRd33VqlVce+219OnTh6eeeopJkybx2GOP8cILLySucbMdGjdunHnTTTfFXfvd735nnnnmmUmqqOVEIhFz5MiR5n333Rd3feHChWZ+fr65du3aJFXWsnbv3m2OHDnSPPnkk81x48Ylu5wWMWXKFHPKlClmJBKJXXvttdfMsWPHmn6/P4mVtYwLLrjAvPTSS+OuXXzxxeYll1ySpIqaj67r5muvvWYOGzbMHDVqlJmfn2/u2rUr9vjll19unn/++XGveeyxx8zjjjvODIVCCamh3fVctm3bRmFhIaeffnrc9TPOOINNmzaxbdu2JFXWMnw+H2eddRa/+MUv4q736dMHgMLCwmSU1eLuvvtuCgoKGD16dLJLaRElJSV8/fXXXHTRRVgsltj1KVOmsHTpUlwuVxKraxmhUAiPxxN3LTMzk7KysuQU1IxWrlzJzJkzueqqq7jtttviHguFQnz99dd1fgdWVFSwatWqhNTQ7sJl06ZNAPTu3Tvues+ePQHYvHlzi9fUkrxeL3fffTcjRoyIu7506VIAjjrqqGSU1aLeeust1qxZwz333JPsUlrMxo0bMU2TjIwMbrrpJo499lhGjBjBvffeSzAYTHZ5LeKyyy7j008/ZfHixVRVVfHBBx/wySefcPbZZye7tITr27cvS5cu5YYbbqi1ae+2bdvQdb3ZvwPb9Jb7damsrASqv2Rriv6Lpj0Oan/33XfMnj2bcePG0bdv32SX06x27NjBjBkzmDFjBtnZ2ckup8WUlJQAcMcdd3Daaafx7LPPsmHDBp544glCoRCPPPJIkitsfhMnTuTLL7/kpptuil2bPHky06ZNS15RzSQnJ+eQj7XUd2C7Cxdz/ybQNW8N1LxutbavztzKlSu59tprycvL48EHH0x2Oc3KNE3uuusuTjnlFM4444xkl9OidF0HYPjw4dx7770AjB49GtM0efTRR7n++uvp3r17Mktsdtdddx3ffPMNd955JwMHDuS7777jmWeeifXm24tDfQdGJeo7sH19kwJpaWlA7XSOTseMPt4eLFq0iCuvvJIuXbowZ84csrKykl1Ss5o7dy4bNmzgrrvuwjAMDMOI/UWr+fu2KPqv0pNPPjnu+oknnohpmmzYsCEZZbWYVatW8dlnn3H33XdzxRVXMGrUKK6++mruuOMOXn311Tb/+Ws61Hdg9OdEfQe2u3CJ3mc8eOB669atcY+3dS+99BK33HILxx57LHPnzqVTp07JLqnZLVmyhNLSUk488UQGDRrEoEGDWLBgAYWFhQwaNIj58+cnu8Rm06tXLwA0TYu7Hu3RHOpfsW3Fzp07geqeW03HHXccAD/99FOL15QsPXr0wGaz1foOjP6cqO/AdhcuPXv2JC8vr9aalg8//JBevXrRtWvXJFXWct566y0eeeQRxo8fz/PPP99uemv3338/b7/9dtyvn//853Tu3Dn2+7aqb9++dOvWjUWLFsVd/89//oOiKAwbNixJlbWM6BfmihUr4q5/++23AHTr1q2lS0oah8PBcccdx4cffhjXW1+yZAlpaWkcc8wxCWmn3Y25AFx//fXceeedZGRkMGbMGD7++GMWL17M448/nuzSml1xcTEPPfQQ3bp1Y8qUKaxduzbu8R49erTZge7odOuaMjMzsdvtDB48OAkVtRyLxcJtt93GLbfcwm233ca5557L6tWrefbZZ7n00kvb7P/zqEGDBjFu3DgefvhhfD4fAwYMYPXq1cyaNYuTTz6ZoUOHJrvEFnXddddx5ZVXcvPNNzN58mS++eYbXnjhBW699daETUtvl+Fy7rnnomkaL774Im+99Rbdu3fn0UcfZcKECckurdl9+umnBAIBduzYwZQpU2o9/thjj7XJqZkCJkyYgN1uZ9asWVxzzTV06NCB66+/nmuuuSbZpbWIxx9/nKeffpo5c+ZQXFxMt27duOqqq/j1r3+d7NJa3OjRo3nqqad48sknuf7668nNzeX3v/89V111VcLasJhteRRTCCFEUrS7MRchhBDNT8JFCCFEwkm4CCGESDgJFyGEEAkn4SKEECLhJFyEEEIknISLEG3Apk2beOqp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\n",
      "text/plain": [
       "<Figure size 432x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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v51Ro0YxcuTIRJfSosrKyvj222+ZNm0aiqJEj1988cV88sknOByOBFbXcgKBAC6XK+ZYhw4dqKioSExBLeC7777j4Ycf5ve//z0zZsyIeS0QCPDtt982+H1WVVXFypUrj/j+Ei6NVFhYCEBeXl7M8dzcXAC2bt3a6jW1JLfbze23387QoUNjjn/yyScA9O7dOxFltYrXX3+d9evXc8cddyS6lBa3efNmDMMgLS2NG2+8kcGDBzN06FDuvPNOampqEl1ei7nsssv4/PPPKSgowOPxsHjxYpYuXcq5556b6NLiplevXnzyySdcd9119RbhLS4uRtf1Fv0+kyX3G6m6uhqo/dKtK/LTz9HQyb1mzRqeffZZxo8fT69evRJdTovYuXMn999/P/fffz8dO3ZMdDktrqysDIDbbruNM888k6effppNmzbx2GOPEQgEeOCBBxJcYcuYPHkyK1as4MYbb4wemzJlCldddVXiioqzjIyMg77WGt9nEi6NZOxfPLruo4O6x02m9t0I/O6777jmmmvIzs7m3nvvTXQ5LcIwDGbPns2YMWOYMGFCostpFbquA3DiiSdy5513AjBy5EgMw2DOnDlMnz6dnJycRJbYIq699lpWrVrFrFmz6N+/P2vWrOGpp56Kttjbu4N9n0XE4/usfX8jxlFKSgpQP9EjwzUjr7dHH3zwAVdccQVdunTh+eefJz09PdEltYiXX36ZTZs2MXv2bILBIMFgMPp/wrq/b08iP6medtppMcdPPfVUDMNg06ZNiSirRa1cuZIvvviC22+/ncsvv5zhw4fzhz/8gdtuu41///vf7fIzH+hg32eRP8fj+0zCpZEizyYP7Mjevn17zOvtzb/+9S9uvvlmBg8ezMsvv0xWVlaiS2oxH374IeXl5Zx66qkMGDCAAQMGsHDhQoqKihgwYABvv/12okuMux49egCgaVrM8UiL5mA/2bZlu3btAmpba3WddNJJAPz000+tXlNr6969O2azud73WeTP8fg+k3BppNzcXLKzs+vNafnoo4/o0aMHXbt2TVBlLef111/ngQceID8/n3/+85/tunUG8Je//IU33ngj5tfpp5/OMcccE/19e9OrVy+6devGBx98EHP8P//5DxaLhSFDhiSospYT+eL85ptvYo6vXr0agG7durV2Sa3OZrNx0kkn8dFHH8W0yD/88ENS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\n",
      "text/plain": [
       "<Figure size 432x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"white\", rc={'figure.figsize': (6, 5)}, font_scale=1.5)\n",
    "palette = [color_mappings[method] for method in methods_before_mappings]\n",
    "markers = [marker_mappings[method] for method in methods_before_mappings]\n",
    "\n",
    "ax = sns.scatterplot(data=df_mean, x=\"I(X,T)\", y=\"I(T,Y)\",\n",
    "                     sizes=(30, 150),linewidth=0.05, edgecolor=\"black\",\n",
    "                     hue=\"Methods\", style=\"Methods\", palette=palette,\n",
    "                     markers=markers, size=\"epoch\")\n",
    "ax.legend().set_visible(False)\n",
    "sns.despine()\n",
    "plt.ylabel(\"$I(\\hat{C}, Y)$\")\n",
    "plt.xlabel(\"$I(X, \\hat{C})$\")\n",
    "plt.title(\"XOR\")\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "ax = sns.scatterplot(data=df_mean, x=\"I(X,T)\", y=\"I(T,C)\",\n",
    "                     sizes=(30, 150),linewidth=0.05, edgecolor=\"black\",\n",
    "                     hue=\"Methods\", style=\"Methods\", palette=palette,\n",
    "                     markers=markers, size=\"epoch\")\n",
    "ax.legend().set_visible(False)\n",
    "sns.despine()\n",
    "plt.ylabel(\"$I(\\hat{C}, C)$\")\n",
    "plt.xlabel(\"$I(X, \\hat{C})$\")\n",
    "plt.title(\"XOR\")\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  }
 ],
 "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
