{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "import os\n",
    "\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 = \"cub\"\n",
    "\n",
    "result_folder = \"results\"\n",
    "image_folder = \"images\"\n",
    "cub_folder = \"cub_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(25), *range(25, 325, 25)]"
   ]
  },
  {
   "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",
    "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": 6,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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PTiW5brrriM1NZVXXnmFxk7517VrV9RqNbt37270uQCFhYUhZRbiTEm4CHGGnE4nBQUF9O/fP6RZqX///lgsFrZt2xZ2zl/+8hc+//zzkLEsCQkJ3HTTTezevZu1a9c2qgyBsTSFhYW88cYbdR5TVFQUMp6mpq1bt5Kenk737t0bdV0h6iPhIsQZysvLw+fzhYzMh+oxJRdffDEbNmzA7XYHt7/66qu8/fbbdY5lueGGG0hKSuIf//hH2HUuvPBC+vTpU285Hn30Ubp06cITTzzBjBkzeOWVV3jvvff4xz/+wYwZM7j44ospKSkJO89ms7F582YmTZrU2FsXol4SLkKcoUB/S+1wAZg2bRoVFRV88cUXAKxYsYKnn3663rEsFouFG264gR07dvDtt9+G7LPZbLRr167ecrRv355ly5Zx5513UlJSwksvvcTjjz/OBx98gE6n489//jM33nhj2HmffvopDoeDa6+9tlH3LcSpyHouQkTZjBkzcDgcvP32203+jPz8fH75y1/yxBNPcPXVV0ewdDBlyhQ6derEwoULI/q54uwmNRchomzu3Lls3bo1rCbSGN9++y19+/blqquuimDJqqfc3717N7NmzYro5wohNRchhBARJzUXIYQQESfhIoQQIuIkXIQQQkSchIsQQoiIk3ARQggRcRIuQgghIk7CRQghRMRJuAghhIg4CRchhBAR9/8BkpbDm7NggfcAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAFPCAYAAACBC4NPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABmLklEQVR4nO3dd3hUZf738feZlsnMpFKkJIQaei8KAUVRIKC7AmvBdVldsT26qyKKuPpTrOCiYFtd3bUruorgCgYQUVAQARWlowRSqCmkzSQ5U87zxzBjJpOEJEySSfi+rotLOHPOmfswOJ/cXdE0TUMIIYQIIV1TF0AIIUTLI+EihBAi5CRchBBChJyEixBCiJCTcBFCCBFyEi5CCCFCztDUBRDibJKfn8+kSZPweDx89tlntG7dOuicO++8kzVr1rBkyRIGDhwIgKqqvPvuu6xcuZL09HQURaFTp05MnjyZq666iqioqIB73HfffSxbtizo3hEREbRq1YqRI0cya9asKt9fiFCQcBGiEcXHx/PAAw9w991388gjj/Dcc88FvL58+XLS0tK45ZZb/MFy/PhxZs6cyS+//MLFF1/MlClT0DSNH3/8kUWLFvHBBx/wr3/9i65duwa939y5c4mLi/P/uaSkhG+//ZalS5eyc+dOPvroI0wmU8M+tDg7aUKIRnfLLbdoycnJ2urVq/3HsrOztSFDhmiXX365pqqqpmmaVl5erk2ZMkUbNGiQtmnTpqD7bN++XRsxYoR20UUXaQ6Hw398zpw5WnJyspaVlVXl+z/00ENacnKytnLlyhA/mRBe0uciRBOYN28e0dHRPPLIIxQVFaFpGnPmzEFVVZ566imMRiPgrcns2rWLOXPmMHLkyKD7DBw4kPvvv5/s7Gz+85//1Pr9p0yZAsBPP/0UmgcSohIJFyGaQNu2bZkzZw45OTksXLiQJUuWsHXrVu6880569OjhP2/58uVYLBZ/GFTld7/7HW3atOHTTz+t9ftHRkYCoMnqT6KBSJ+LEE3kD3/4A2lpaXz44YeYzWaGDRvG9ddf73/d7XazY8cOBgwYQERERLX3URSFc889lxUrVpCTk0ObNm1O+95ff/01AH369DnzBxGiClJzEaIJPfzww2iahsPh4IEHHkCn++1/ycLCQlRVrVVYtG3bFoATJ04EHC8qKiI/P9//KzMzk3fffZcXXniBbt26MXny5NA+kBCnSM1FiCa0YsUKf9PUO++8w+OPP+5/zXdcr9ef9j4GgyHgGp+qmtMiIyO56KKLePDBB/19O0KEmoSLEE1k7969vPjii6SkpOB0Ovnoo4+YNGkSKSkpgHfYstFoJC8v77T38tVYfDUYn3/84x+0bt0ap9PJ119/zbvvvktqaioPP/xwjU1tQpwpCRchmoCqqtxzzz0YDAYeeughXC4Xl19+OQ8++CCffvopVqsVRVEYPHgwO3bsoLy8vNow0DSN77//nsTExKBwGTJkCAkJCQBccMEFJCUl8dhjj1FQUMA///lPFEVp8GcVZyfpcxGiCTz33HPs37+fO++8k6SkJLp168att97K4cOHWbhwof+83//+95SUlPDBBx9Ue68vvviCrKwsLrvsstO+75/+9CfGjRvHunXrePPNN0PyLEJURcJFiEb2ww8/8J///IchQ4YwY8YM//Ebb7yRnj17smTJErZs2QLA1KlTGTx4ME8//TTffPNN0L327NnDgw8+SEJCAjNnzqzV+z/yyCPExMSwePFisrKyQvNQQlQi4SJEIyotLeW+++7DaDTyxBNPBIwOMxqNPP744+h0Ov7+979TWlqKTqfjhRdeIDk5mZkzZ/K3v/2Nd999l/fff5+5c+dyxRVXYLPZePnll7FarbUqQ+vWrZk9ezalpaU89NBDDfWo4iwn4SJEI3rqqafIyMjgjjvuoEuXLkGv9+/fnz//+c9kZmayaNEiwBsG7777Lo888ggnTpzgueee4x//+Ad79+7ljjvu4OOPPw6YeFkbV1xxBUOHDmXjxo0sX748FI8mRABFkym6QgghQkxqLkIIIUJOwkUIIUTISbgIIYQIOQkXIYQQISfhUg8ul4vs7GxcLldTF0UIIcKShEs9HDt2jHHjxnHs2LGmLooQQoQlCRchhBAhJ+EihBAi5CRchBBChJyEixBCiJCTcBFCCBFyEi5CCHEW+2rfMexlasjvK+EihBBnqU92HOWf+zQWbAp9wIR9uKxYsYLJkyczYMAAUlNT67Q8+IIFC7juuuuCjrtcLhYvXswFF1zAwIEDueaaa/j5559DV2ghhAhjbreb2Z/u4p2DoOj17Cs1hzxgwjpc0tLSmD17NikpKbz44ouMGDGCOXPmsGrVqtNe+8477/Daa69V+drjjz/OG2+8wY033sii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1aqA42vWrKFz58506NAh6JrRo0dTVFTEpk2b/Mfy8/PZtm0bo0aNavAy10Z9nmv79u088MAD/nZh8E4SW716NUOGDMFoNDZ4uRtCc/i86qu5fGYffvgh8+fPJzU1lX//+9+n/RJtLp9ZXZ+ruXxe1ZE+lzq67bbbmDt3LjExMYwdO5Z169aRlpbGokWLAO8/6szMTLp3747NZmP48OGMGDGCWbNmMXv2bGJjY3n++eeJiopi+vTpTfw0v6nrc02dOpW3336b22+/nTvvvBOr1cp7773H/v37effdd5v4aWqvuX5etdEcP7O8vDwef/xxOnbsyB//+Ed2794d8HqnTp0Amt1nVp/nag6fV42aaoJNc7ZkyRLtkksu0fr166elpqZqy5Yt87+2dOlSLTk5Wdu8ebP/WEFBgXbfffdpw4YN04YMGaLdeOON2oEDB5qg5DWr63NlZ2drd911lzZq1ChtwIAB2jXXXKNt3bq1CUpeO75nqDjRsDl/XhXV9tnC/TNbtmyZlpycXO2v5cuXN8vPrL7PFe6fV00UTathqIUQQghRD9LnIoQQIuQkXIQQQoSchIsQQoiQk3ARQggRchIuQgghQk7CRQghRMhJuAhxlklPT+f555/3b7UgREOQeS5CnEU0TeOaa65h37599OrVi3fffTdoNWwhQkFqLkKcRT766CMOHz7MJ598QnZ2NsuWLWvqIokWSmouQpwl8vPzmTRpEk8//TQpKSl888033HPPPaSlpREbG9vUxRMtjISLEEKIkJNmMSGEECEn4SJEI9u/fz99+vRh48aNTV2UIGvXrqVfv34cOnSoqYsimjkJFyEaSElJCb169eIvf/lLwPH58+czZMgQUlJSAo5/9dVX9OzZk+effz7oXna7nSlTptCvXz+2bt1a57KUlpbyxhtvcO2115KSkkK/fv0477zzmDlzJp988gkejweAiy++mOTkZBYuXFjn9xCiIgkXIRrIrl270DSNPn36+I/9+OOPbNy4keuuuy7o/LFjx9K7d2/efvttSkpK/MfdbjezZs1iz549PPnkkwwfPrxO5fj5559JTU1l/vz5WCwWrrvuOh566CGuvvpqsrOzuffee1myZIn//BkzZvD555/zyy+/1P2hhThFwkWIBuLbbbBv377+Y++99x6xsbFccMEFVV5zyy23UFhYGPBl/+ijj/LVV19x1113cdlll9W5DNdddx1Op5P33nuPV155hRtvvJErrriCO++8k5UrV3LPPffQu3dv/zWXXHIJkZGRvP/++3V6LyEqknARooHs3LkT+C1cXC4Xa9euJSUlpdr9z8ePH0/Xrl154403KC8v59///jdLlizhyiuv5Oabb67T+6uqyt13342qqrz88ssMGTIk6By9Xs/MmTMDXrNarQwdOpRVq1bV6f2EqEjCRYgGsnv3bqKjo0lMTAS8zWQOh4MBAwZUe41Op+Pmm28mNzeXu+66i4ULFzJmzBgeeuihOr//0qVLSU9P549//CP9+/ev07WDBw8mNzeXAwcO1Pl9hQAJFyEahN1u59ChQ/Tu3du/vMqvv/4K4A+b6lx66aV07NiRL774gl69erF48WIMBkOdy/DBBx+gKArTp0+v87W+MvrKLERdSbgI0QD27NmDx+MJ6G/Jz88HICYmpsZrs7OzcTgcAFxxxRXYbLY6v39+fj579+4lOTmZzp071/l634z9vLy8Ol8rBEi4CNEgdu3aBQR25tdmgcj8/HxuvPFGPB4PrVu35o033sDtdtf5/Y8cOYKmaXTp0qXO11Yki1qK+pJwEaIBVDVSLD4+HoCCgoIqryktLeXmm2/m6NGjvPjii8ycOZPMzEw+++yzOr+/b96Ky+Wq87UVy+grsxB1JeEiRAPYtWsXVqs1oEmqR48eAGRkZASd7/F4mDVrFjt27PDPZbn66quJi4vjlVdeoa5LAHbq1AmdTsf+/fvrfC1AZmZmQJmFqCsJFyFCrKysjPT0dPr06RPQrNSnTx9sNhs//fRT0DWPPvoo69atC5jLEhkZyXXXXcf+/fv54osv6lQG31yazMxM3nrrrSrPycrKCphPU9H27dtp3bo1Xbt2rdP7CuEj4SJEiO3Zswe32x0wMx+8c0rGjx/P5s2bUVXVf/zVV1/lvffeq3Iuy7XXXkt0dDQvvfRS0PtcdNFF9OzZs9pyzJs3j8TERJ544gluuOEGXnnlFT766CNeeuklbrjhBsaPH09OTk7QdXa7ne+//56JEyfW9dGF8JNwESLEfP0tlcMFYPr06RQWFvLll18CsHLlSp5++ulq57LYbDauvfZadu7cyTfffBPwmt1up23bttWW45xzzmHZsmXcdttt5OTk8M9//pPHHnuMjz/+GKPRyP/93//xpz/9Kei6NWvWUFpaylVXXVWn5xaiItnPRYhGdsMNN1BaWsp7771X73vs3buX3//+9zzxxBNMmzYthKWDqVOn0qFDB1544YWQ3lecXaTmIkQju++++9i+fXtQTaQuvvnmG3r16sWUKVNCWDLvkvv79+9n9uzZIb2vOPtIzUUIIUTISc1FCCFEyEm4CCGECDkJFyGEECEn4SKEECLkJFyEEEKEnISLEEKIkJNwEUIIEXISLkIIIUJOwkUIIUTI/X9CKlw8+ckc4QAAAABJRU5ErkJggg==\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": "3.6.0",
   "language": "python",
   "name": "py3.6.0"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
