{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "import joblib\n",
    "import os\n",
    "import glob\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import patches\n",
    "import seaborn as sns\n",
    "from sklearn.model_selection import cross_val_score\n",
    "from sklearn.tree import DecisionTreeClassifier\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import accuracy_score, roc_curve, f1_score\n",
    "from sklearn.manifold import TSNE\n",
    "from torch.nn import BCELoss, BCEWithLogitsLoss, Sequential, LeakyReLU, Linear\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from sklearn.cluster import KMeans\n",
    "from sklearn_extra.cluster import KMedoids\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics.cluster import homogeneity_score, v_measure_score\n",
    "from matplotlib import rc\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "\n",
    "cv = 3\n",
    "emb_sizes = [2, 10, 50]\n",
    "sns.set(font_scale=1.3)\n",
    "sns.set_style('whitegrid')\n",
    "figsize = [9, 4]\n",
    "palette = [sns.color_palette(\"Paired\")[i] for i in [7, 6, 3, 2, 5]]\n",
    "step = 500\n",
    "LATEX_SYMBOL = \"$\"\n",
    "rc('text', usetex=(LATEX_SYMBOL == \"$\"))\n",
    "plt.style.use('seaborn-whitegrid')\n",
    "\n",
    "experiments = {\n",
    "    'XOR': 'results/xor/test_embedding_acts/',\n",
    "    'Trigonometry': 'results/trig/test_embedding_acts/',\n",
    "    'Dot': 'results/dot/test_embedding_acts/',\n",
    "    'CUB': 'results/cub/test_embedding_acts/',\n",
    "    'CelebA': 'results/celeba/test_embedding_acts/',\n",
    "}\n",
    "methods = {\n",
    "    'ConceptBottleneckModelNoConceptSupervisionReLU_ExtraCapacity': 'VanillaModel',\n",
    "    'ConceptBottleneckModelBool': 'Bool',\n",
    "    'ConceptBottleneckModelFuzzy': 'Fuzzy', \n",
    "    'ConceptBottleneckModelFuzzyExtraCapacity': 'Fuzzy+',\n",
    "    'MixtureEmbModelSharedProb_Adaptive_NoProbConcat': 'CEM without RandInt (ours)',\n",
    "    'MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat': 'CEM (ours)',\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def embedding_homogeneity(c_vec: np.array, c_test: np.array, y_test: np.array, nc: int, c_pred=None) -> [float, float]:\n",
    "    \"\"\"\n",
    "    Computes the alignment between learnt concepts and labels.\n",
    "\n",
    "    :param c_vec: predicted concept representations (can be concept embeddings)\n",
    "    :param c_test: concept ground truth labels\n",
    "    :param y_test: task ground truth labels\n",
    "    :param step: integration step\n",
    "    :return: concept alignment AUC, task alignment AUC\n",
    "    \"\"\"\n",
    "    # compute the maximum value for the AUC\n",
    "    n_clusters = np.linspace(2, c_vec.shape[0], step).astype(int)\n",
    "    max_auc = np.trapz(np.ones(nc))\n",
    "    \n",
    "\n",
    "    # for each concept:\n",
    "    #   1. find clusters\n",
    "    #   2. compare cluster assignments with ground truth concept/task labels\n",
    "    concept_auc, task_auc = [], []\n",
    "    for concept_id in range(c_test.shape[1]):\n",
    "        concept_homogeneity, task_homogeneity = [], []\n",
    "        for nc in n_clusters:\n",
    "            kmedoids = KMedoids(n_clusters=nc, random_state=0)\n",
    "            if c_vec.shape[1] != c_test.shape[1]:\n",
    "                c_cluster_labels = kmedoids.fit_predict(np.hstack([c_vec[:, concept_id][:, np.newaxis], c_vec[:, c_test.shape[1]:]]))\n",
    "            elif c_vec.shape[1] == c_test.shape[1] and len(c_vec.shape) == 2:\n",
    "                c_cluster_labels = kmedoids.fit_predict(c_vec[:, concept_id].reshape(-1, 1))\n",
    "            else:\n",
    "                c_cluster_labels = kmedoids.fit_predict(c_vec[:, concept_id])\n",
    "\n",
    "            # compute alignment with ground truth labels\n",
    "            concept_homogeneity.append(homogeneity_score(c_test[:, concept_id], c_cluster_labels))\n",
    "            task_homogeneity.append(homogeneity_score(y_test, c_cluster_labels))\n",
    "\n",
    "        # compute the area under the curve\n",
    "        concept_auc.append(np.trapz(np.array(concept_homogeneity)) / max_auc)\n",
    "        task_auc.append(np.trapz(np.array(task_homogeneity)) / max_auc)\n",
    "\n",
    "    # return the average alignment across all concepts\n",
    "    concept_auc = np.mean(concept_auc)\n",
    "    task_auc = np.mean(task_auc)\n",
    "    return concept_auc, task_auc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "auc_file = os.path.join('./results', 'homogeneity_summary.csv')\n",
    "if os.path.exists(auc_file):\n",
    "    auc_scores = pd.read_csv(auc_file)\n",
    "\n",
    "else:\n",
    "    columns = ['experiment', 'concept AUC (%)', 'task AUC (%)', 'method_id', 'method', 'fold']\n",
    "    auc_scores = pd.DataFrame(columns=columns)\n",
    "    \n",
    "for experiment_name, result_dir in experiments.items():\n",
    "    c_test = np.load(os.path.join(result_dir, 'c_val.npy'))\n",
    "    y_test = np.load(os.path.join(result_dir, 'y_val.npy'))\n",
    "    resnet = '_lambda'\n",
    "    cv = 5\n",
    "    epochs = 500\n",
    "    step = 20\n",
    "    if experiment_name == 'CUB':\n",
    "        resnet = '_resnet34'\n",
    "        epochs = 300\n",
    "        step = 10\n",
    "    elif experiment_name == 'CUB*':\n",
    "        resnet = '_subsample_0.05_resnet34'\n",
    "        epochs = 250\n",
    "        cv = 3\n",
    "    elif experiment_name == 'CelebA':\n",
    "        resnet = '_resnet34'\n",
    "        epochs = 200\n",
    "        step = 10\n",
    "\n",
    "    for method_id, (method, method_name) in enumerate(methods.items()):\n",
    "        for fold in range(cv):\n",
    "            if method_name == 'Fuzzy+' and experiment_name in ['CelebA', 'CUB']:\n",
    "                resnet = '_Logit_resnet34'\n",
    "            elif method_name == 'Fuzzy+' and experiment_name not in ['CelebA', 'CUB']:\n",
    "                resnet = '_LogitOnlyProb_lambda'\n",
    "            elif method_name != 'Fuzzy+' and experiment_name in ['CelebA', 'CUB']:\n",
    "                resnet = '_resnet34'\n",
    "            else:\n",
    "                resnet = '_lambda'\n",
    "\n",
    "            c_pred = np.load(os.path.join(result_dir, f'{method}{resnet}_fold_{fold+1}', f'test_embedding_semantics_on_epoch_{epochs}.npy'))\n",
    "            c_vec = np.load(os.path.join(result_dir, f'{method}{resnet}_fold_{fold+1}', f'test_embedding_vectors_on_epoch_{epochs}.npy'))\n",
    "            y_pred = np.load(os.path.join(result_dir, f'{method}{resnet}_fold_{fold+1}', f'test_model_output_on_epoch_{epochs}.npy'))\n",
    "\n",
    "            if experiment_name == 'CUB*':\n",
    "                c_test = np.load(os.path.join(result_dir, 'c_test.npy'))\n",
    "                selected_concepts = np.load(os.path.join(result_dir, f'selected_concepts_fold_{fold+1}.npy'))\n",
    "                c_test = c_test[:, selected_concepts]\n",
    "\n",
    "            if 'CEM' in method_name:\n",
    "                c_vec = c_vec.reshape(c_test.shape[0], c_test.shape[1], -1)\n",
    "\n",
    "            is_done = len(auc_scores[(auc_scores['experiment']==experiment_name) & \n",
    "                            (auc_scores['method_id']==method_id) & \n",
    "                            (auc_scores['method']==method_name) & \n",
    "                            (auc_scores['fold']==fold)])\n",
    "            if is_done < 1:\n",
    "                concept_auc, task_auc = embedding_homogeneity(c_vec, c_test, y_test, step)\n",
    "                auc_scores = auc_scores.append(pd.DataFrame([[experiment_name, concept_auc*100, task_auc*100, method_id, method_name, fold]], columns=columns))\n",
    "                auc_scores.to_csv(os.path.join('./results', 'homogeneity_summary.csv'), index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdgAAAF6CAYAAAAK1Dr+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAA9hAAAPYQGoP6dpAADffElEQVR4nOzdd1QU19sH8O+CVFEBKYKCWEAMNkzRKGqixt5r7EaNGjUaNTHGEqOxJmoS28+S2HslscaSaGxRjBqJ3SgCosAKosjS9/3Dlw3DLjA725fv5xzP2Zm9M/MsuA8zz9y5V6ZUKpUgIiIiIiIiIiIiIiKt2Jg6ACIiIiIiIiIiIiIiS8QCOxERERERERERERGRBCywExERERERERERERFJwAI7EREREREREREREZEELLATEREREREREREREUnAAjsRERERERERERERkQQssBMRERERERERERERScACOxERERERERERERGRBCywExERERERERERERFJwAI7ERHp1d69e1GjRg3VvwsXLpg6JCIiIiIiIiph8l+XTp482ejHHzBggOr4zZs3N/rxyXhYYCciIiIiIiIiIiIikqCUqQOgkic9PR3dunXDv//+q1o3Y8YM9O3bV9L+vv76a2zevFm1/M4772DVqlWit7916xZOnTqFq1ev4uHDh0hISIBCoYBMJoOzszO8vb1RpUoV1K9fH82bN4e/v7/WMS5duhTLli3Tejt7e3uULVsWnp6eCAkJQYMGDdCqVSs4OjpqvS+yLrGxsWjRooXB9j9v3jx069bNYPsnIiLxJk+ejH379hXbztnZGWXLlkXZsmVRuXJl1KlTB/Xq1UNoaCjs7OyMECkRWbr4+HicOHECf/31F+7du4cnT57g5cuXAIDSpUvD1dUVVapUwWuvvYZmzZqhTp06kMlkxe63YB7bsWMH6tWrJznONm3a4MGDB6rl27dva2y3d+9efPHFF6L2aWdnB2dnZ7i6uiIgIAA1a9ZEs2bNEBoaKuozElk7Q+UHMpwuXbrg5s2bquXSpUvjzJkzcHZ2NmFU1okFdjI6R0dHLF68GD179kRmZiYA4JtvvsHbb7+NKlWqaLWv8+fPY8uWLaplDw8PzJ07V9S2v//+O5YtW4Z//vmn0DYpKSlISUnBnTt38Ouvv2LevHkICwvD2LFjUbduXa1ilSIzMxNyuRxy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xBxERKZkqBzEArsO8h4HcnJygrOzs4mjISIpLPWxPuYfIuvAHGS57t+/D8C8fgbmGBOZL+YfIjIl5iAiMiV95yDLzGhERERERERERERERCbGAjsRERERERERERERkQQssBMRERERERERERERScACOxERERERERERERGRBCywExERERERERERERFJwAI7EREREREREREREZEEpfS5s9TUVKSlpQEAnJ2d4eLios/dExERERERERERERGZDckF9rS0NJw8eRJnzpzBP//8g5iYGKSnpwvaODo6ws/PD7Vq1UJYWBjeeecdODs76xw0EREREREREREREZGpaV1gj4+Px6pVqxAeHg6FQgGlUlloW4VCgTt37uDOnTvYt28fnJyc0LVrVwwfPhze3t46BU5EREREREREREREZEqiC+y5ublYuXIlVq9ejYyMDCiVSnh6euLtt99G7dq14e/vD29vbzg5OQF4VVyPj49HdHQ0IiMjcf78eSQmJmLLli3Ys2cPRowYgREjRsDGhsPAExEREREREREREZHlEVVgT0xMxMcff4y///4btra26NixI/r06YPQ0NAitwsODhYsX7lyBVu3bsXhw4exZMkSnDp1CkuXLoWnp6f0T0BEREREREREREREZAKiCuw9evRAfHw83nnnHUyePBkBAQGSDhYaGorQ0FCMHj0a8+bNw6lTp9CrVy/8/vvvkvZHRERERERERERERGQqosZnef78ORYsWICVK1dKLq7nFxAQgFWrVmHevHl49uyZVtvu3bsXr7/+OmrUqIHY2FiNbWJiYjB58mQ0adJENcHq5MmTC20fERGBYcOG4a233kKtWrXQunVrfPfdd0hLS9P2oxGRlWMOIiJTYf4hIlNiDiIiU2IOIiJzJqoH+7Zt29SGe9GHrl27ombNmqLaPn36FF9++SVOnDihGuddk5iYGPTq1QsZGRkYNGgQqlatiocPH2LdunU4ffo0du7ciYoVK6raHz9+HGPHjkXFihUxatQouLu749KlS1i9ejUiIiKwceNGlCql9VywRGRlmIOIyFSYf4jIlJiDiMiUmIOIyBKIyhZii+uZmZm4ffs2njx5gvT0dDg5OaFy5cqoXr06ZDKZTvvu0aMHsrKysGbNGqxevRoXL17U2G7evHlISkrC2rVr0bhxY9X60NBQDBkyBAsWLMCSJUtU8c6Y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3yFZbt68+eqFDsNUcYgqIiIiIusgusD++uuv4+eff8b69esRERGBW7duISMjA46OjqhcuTLefvttDB48GN7e3oaMl4iIiEgSDvVCZJmio6MRXLMmFGnSh2MB9D8kCxERERERoEWBHQAqV66MGTNmGCoWIiIiIiIiAblcDkVaGhpMXI6yfkGS95ObmYGb3w8HADRfsB829tJ7jD++dBz/bF4geXsiIiIish6iCuw//PADxo0bp/eDK5VK/PDDD/jkk0/0vm8iIiIiIrIeZf2C4Fa9juTtczIUqteu1WrB1sFJ8r6ex9yVvC0RERERWRcbMY3+97//YdiwYYiPj9fbgePj4zF06FCsWrVKb/skIiIiIiIiIiIiIjIWUT3Yu3btin379qF9+/YYOnQoBg4ciNKlS0s64MuXL7FhwwasXbsWqamp6Natm6T9EBERERERWQIbRQpsFCmCdbKcTNXrUskxUNraq23HuSOIiIiIzJ+oAvu8efPw2muvYeHChViyZAl+/PFHdOjQAa1atcKbb74Je3v1k8H8MjMzERERgV9//RUHDx5EWloa7O3tMX36dPTr108vH4SIiIiIiMgcOd/7A2X+OVjo+x7HF2pc/6JWe6TW7miosIiIiIhID0RPcjpgwACEhYVh7ty5OH36NHbu3ImdO3eiVKlSCAoKQuXKleHl5QUnp1djGSoUCiQkJODhw4e4c+cOsrOzoVQqAQBNmzbFF198gSpVqhjmUxEREREREZmJtOpNkV6xrtbbsfc6ERERkfkTXWAHgCpVqmDNmjW4evUqNm3ahN9//x1paWm4fv06rl+/DplMJmifV1AHACcnJzRv3hwDBw5E3bran1yWNPHx8UhISNB6Oy8vL3h7exsgIiIiIiIikoJDvRARERFZL60K7Hnq1auHevXqITMzE5cvX0ZkZCRiYmIgl8uRnp4OAHB0dISHhwf8/PxQp04dhIaGFjuUDP1n8+bNWLx4sdbbTZgwARMnTjRARERERERERERERESUn6QCex57e3s0bNgQDRs21Fc89P/69++PVq1aCdalp6ejS5cuAIDw8HA4Ojqqbefl5WWM8IiIiIiIiIiIiIhKPJ0K7GQ43t7eakO9pKWlqV6HhITA2dnZ2GERERERWbzo6GjI5XLJ2+c9sQkAV69e1djpQVseHh7w9/fXeT9ERERERGRcLLAT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REREREREREREpImYYCciIiIiIiIiIiIiUgIT7ERERERERERERERESmCCnYiIiIiIiIiIiIhICUywExEREREREREREREpgQl2IiIiIiIiIiIiIiIlMMFORERERERERERERKQEJtiJiIiIiIiIiIiIiJTABDsRERERERERERERkRKYYCciIiIiIiIiIiIiUgIT7EREREREREREREREStBW5c5fvHiBxMREVVZBYSYmJqhTp46qq0FUojStbbJdkjph+yEqfZrW7gC2PSq72B6JiL4umhb3GfOpRAhV5Pnz50J9fX0hAI36T19fX/j8+XNV/WxEJe758+dCPQ1rm3pfSbuMjY0VNmnSRNi1a1dVV4Xy8fz5c6GBhrUfg6+k/VDZ9fz5c6GBgYHK25LCbc/AQOPa3tWrV4VNmjQRfv/998Xyee7u7sImTZoI3d3d5SrP86D6e/78uVBfA9ujvga2R031/fffC5s0aSK8evVqoWVFMWLXrl2lUDPKz8KFC4VNmjQR+vj4qLoqUsLCwoTNmzcXzpkzR9VVUch///0n7NChg7Bfv37C9+/fq7o6RfIpf6BZcV9PnzFfGT4+PsImTZoI165dq+qqKOTevXvCVq1aCV1dXYXZ2dklth+VjWBPTExEeno6xowZg+rVq5f4/q5cuYKQkBB06tQJHTt2VOozXr16hb179yIxMbHId7tevnyJ7t27AwBGjRoFNze3fMt6eHhg8+bN2LdvH2xtbYu0X1JcbGws/Pz8MGbMGFSuXFnV1SlxiYmJyEhPh2BiH8DcWNXVKVxcEjJ2BhRLuxT5vH1+TiAQQF9fHzVr1kT79u0xduxY1K5du1j2WRoeP36Mw4cPIyIiAvHx8cjIyICJiQlq1aqFXr16oX///jA0NJR4j6+vL/73v/9JfZaWlhYqVaqEunXrokuXLhg9ejQqVqwoUUYUuwBg1apVGDRoUIH127BhA7Zv3w4A+P333zFkyJAifFvVSExMxMf0dCwb5YB6ZoaFv0HFniWkYun+4FJpP7K0b98e+/fvL5b9qrPbt2/Dx8cHUVFRSEhIQG5uLqpVq4a6deuib9++6N27N/T19SXe83n7+Zy2tjYqV66Mhg0bokePHnBxcUH58uUlyixatAjHjx8HAHh5ecHGxqbA+s2bNw/+/v4AoJHXGomJifj48SP2znJH01qNVV0duTx4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u2WuuaYpEhMT4e/vDzMzs3wXFtcEjPtll5aWFsaPH49ly5Zh7969Gj1Q9cGDB7hy5QosLS2LPbkOaPAip0REREQlISAgAH///Te6du2Khg0bqro6RKWCxz0REWmKLl26wM7ODufOncPt27dVXR2lbdq0CRkZGZg/f754AV0idTNixAg0atQIXl5eMhcU1RSrV6+GQCAQLypd3JhgJyIioq/eu3fv8Oeff2LhwoWYO3cujIyMsGTJElVXi6hE8bgnIiJNtWLFClSqVAn/+9//kJGRoerqKCw8PBze3t7o1auXRo9ep7JPW1sbq1atQl5eHhYvXgwVzjSutGPHjiEsLAxjx44tdJ0HZTHBTkRERF+9Dx8+wN3dHQEBAbC1tYWXl5fcCxYSaSoe90REpKlq1KiBjRs34vnz5xp3czg+Ph5z585F48aNsXLlSlVXh6hQlpaWWLZsGa5evYoNGzaoujoKuX//PpYvX46OHTti7ty5JbYflS5ySkRERERERERERESkqTiCnYiIiIiIiIiIiIhICUywExEREREREREREREpgQl2IiIiIiIiIiIiIiIlMMFORERERERERERERKQEJtiJiIiIiIiIiIiIiJTABDsRERERERERERERkRKYYCciIiIiIiIiIiIiUgIT7ERERERERERERERESmCCnYiIiIiIiIiIiIhICUywExEREREREREREREpgQl2IiIiIiIiIiIiIiIlMMFORERERERERERERKQEJtiJiIiIiIiIiIiIiJTABDsRERERERERERERkRKYYCciIiIiIiIiIiIiUgIT7ERERERERERERERESmCCnYiIiIiIiIiIiIhICf8PXE+/ixSrZFcAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1800x350 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def bold_text(x):\n",
    "    if LATEX_SYMBOL == \"$\":\n",
    "        return r\"$\\textbf{\" + x + \"}$\"\n",
    "    return x\n",
    "\n",
    "clrs = sns.color_palette(\"colorblind\", 30)\n",
    "color_map = {\n",
    "    'VanillaModel': clrs[7],\n",
    "    'Bool': clrs[2],\n",
    "    'Fuzzy': clrs[5], \n",
    "    'Fuzzy+': clrs[6],\n",
    "    'CEM without RandInt (ours)': clrs[9],\n",
    "    'CEM (ours)': clrs[10],\n",
    "}\n",
    "fig_width = 18\n",
    "fig_height = 3.5\n",
    "scale = 1\n",
    "trials = 5\n",
    "num_models = len(methods)\n",
    "\n",
    "fig, axs = plt.subplots(1, 5, figsize=(fig_width, fig_height))\n",
    "for j, (experiment_name, _) in enumerate(experiments.items()):\n",
    "    ax = axs[j]\n",
    "    mean = auc_scores.groupby(['experiment', 'method']).mean().reset_index()\n",
    "    std = auc_scores.groupby(['experiment', 'method']).std().reset_index()\n",
    "    i = 0\n",
    "    for _, method_name in methods.items():\n",
    "        if method_name == 'VanillaModel+':\n",
    "            continue\n",
    "        alpha = 1\n",
    "        hatch = ''\n",
    "        if method_name == 'VanillaModel':\n",
    "            alpha = 1\n",
    "            hatch=\"/\"\n",
    "        color = color_map[method_name]\n",
    "        ax.bar(\n",
    "            i,\n",
    "            mean[(mean['experiment']==experiment_name) & (mean['method']==method_name)]['concept AUC (%)'],\n",
    "            width=1,\n",
    "            color=color,\n",
    "            align='center',\n",
    "            label=method_name,\n",
    "            yerr=2*std[(std['experiment']==experiment_name) & (std['method']==method_name)]['concept AUC (%)'],\n",
    "            capsize=5,\n",
    "            edgecolor=\"black\",\n",
    "            alpha=alpha,\n",
    "            hatch=hatch,\n",
    "        )\n",
    "        i += 1\n",
    "        \n",
    "    if j == 0:\n",
    "        ax.set_ylabel(\"Concept Alignment (%)\", fontsize=18)\n",
    "    ax.set_title(bold_text(experiment_name), fontsize=30)\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks(np.arange(0, 105, 10))\n",
    "    ax.set_yticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 105, 10))), fontsize=15)\n",
    "    ax.set_ylim((40, 105))\n",
    "    ax.grid(axis='y')\n",
    "    ax.grid(True)\n",
    "\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "labels = ['No concepts',\n",
    " 'Bool-CBM',\n",
    " 'Fuzzy-CBM',\n",
    " 'Hybrid-CBM',\n",
    " 'CEM without RandInt (ours)',\n",
    " 'CEM (ours)']\n",
    "\n",
    "lgd = fig.legend(handles, labels, fontsize=16, loc='upper center', bbox_to_anchor=(0.5,0.11), ncol=num_models)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "acc_scores = pd.DataFrame()\n",
    "columns = ['experiment', 'Task Accuracy (%)', 'method_id', 'method', 'fold']\n",
    "for experiment_name, result_dir in experiments.items():\n",
    "    result_dir = '/'.join(result_dir.split('/')[:-2])\n",
    "    resnet = ''\n",
    "    cv = 5\n",
    "    epochs = 3100\n",
    "    step = 500\n",
    "    if experiment_name == 'CUB':\n",
    "        resnet = '_resnet34'\n",
    "        epochs = 250\n",
    "        cv = 5\n",
    "    elif experiment_name == 'CUB*':\n",
    "        resnet = '_subsample_0.05_resnet34'\n",
    "        epochs = 250\n",
    "        cv = 3\n",
    "    elif experiment_name == 'CelebA':\n",
    "        resnet = '_resnet34'\n",
    "        epochs = 200\n",
    "        cv = 5\n",
    "    elif experiment_name == 'XOR':\n",
    "        epochs = 1035\n",
    "        step = 50\n",
    "    \n",
    "    for method_id, (method, method_name) in enumerate(methods.items()):\n",
    "        acc_results = joblib.load(os.path.join(result_dir, 'results.joblib'))\n",
    "        if method_name == 'Fuzzy+' and experiment_name in ['CelebA', 'CUB']:\n",
    "            resnet = '_Logit'\n",
    "        elif method_name == 'Fuzzy+' and experiment_name not in ['CelebA', 'CUB']:\n",
    "            resnet = '_LogitOnlyProb'\n",
    "        else:\n",
    "            resnet = ''\n",
    "                \n",
    "        for fold in range(cv):\n",
    "            y_acc = acc_results[str(fold)][f'test_acc_y_{method}{resnet}']\n",
    "            acc_scores = acc_scores.append(pd.DataFrame([[experiment_name, y_acc*100, method_id, method_name, fold]], columns=columns))\n",
    "\n",
    "acc_scores.reset_index(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "auc_file = os.path.join('results', 'homogeneity_summary.csv')\n",
    "if os.path.exists(auc_file):\n",
    "    auc_scores = pd.read_csv(auc_file)\n",
    "\n",
    "auc_scores['method'] = auc_scores['method'].astype(str)\n",
    "acc_scores['method'] = acc_scores['method'].astype(str)\n",
    "acc_scores = pd.merge(auc_scores, acc_scores, on=['method', 'fold', 'experiment'], how='left', suffixes=('', '_r'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "acc_scores[acc_scores['experiment']=='CUB']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats\n",
    "from scipy.special import inv_boxcox\n",
    "\n",
    "def ci_interv(r, ci=0.95):\n",
    "    m = np.mean(r)\n",
    "    try:\n",
    "        xt, lmbda = stats.boxcox(r)\n",
    "        lo_xt, hi_xt = stats.t.interval(ci, len(xt) - 1, loc=np.mean(xt), scale=stats.sem(xt))\n",
    "        lo_x, hi_x = inv_boxcox(lo_xt, lmbda), inv_boxcox(hi_xt, lmbda)\n",
    "    except ValueError:\n",
    "        lo_x = hi_x = m\n",
    "    if np.isnan(lo_x):\n",
    "        lo_x = np.mean(r)\n",
    "    if np.isnan(hi_x):\n",
    "        hi_x = np.mean(r)\n",
    "    return np.array([[m-lo_x], [hi_x-m]])\n",
    "#     return np.array([[lo_x], [hi_x]])\n",
    "\n",
    "def ci_interv_boot(r, ci=0.95):\n",
    "    n = 100\n",
    "    m = np.mean(r)\n",
    "    xt = [np.mean(np.random.choice(r, len(r))) for _ in range(n)]\n",
    "    lo_x, hi_x = stats.t.interval(ci, len(xt) - 1, loc=np.mean(xt), scale=stats.sem(xt))\n",
    "    if np.isnan(lo_x):\n",
    "        lo_x = hi_x = np.mean(r)\n",
    "    return np.array([[m-lo_x], [hi_x-m]])\n",
    "\n",
    "a2 = acc_scores[(acc_scores['experiment']==experiment_name) & (acc_scores['method']==method_name)]['concept AUC (%)'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "std = acc_scores.groupby(['experiment', 'method']).std().reset_index()\n",
    "std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "def bold_text(x):\n",
    "    if LATEX_SYMBOL == \"$\":\n",
    "        return r\"$\\textbf{\" + x + \"}$\"\n",
    "    return x\n",
    "\n",
    "# sns.set_style(\"whitegrid\", {\"grid.alpha\": \".6\", \"grid.linewidth\": \".3\"})\n",
    "plt.style.use('seaborn-whitegrid')#, {\"grid.alpha\": \".6\", \"grid.linewidth\": \".3\"})\n",
    "mpl.rc('grid', alpha=.7, linewidth=.5)\n",
    "# mpl.rc('grid', alpha=1, linewidth=2)\n",
    "clrs = sns.color_palette(\"colorblind\", 30)\n",
    "color_map = {\n",
    "    'VanillaModel': clrs[7],\n",
    "    'Bool': clrs[2],\n",
    "    'Fuzzy': clrs[5], \n",
    "    'Fuzzy+': clrs[6],\n",
    "    'CEM without RandInt (ours)': clrs[9],\n",
    "    'CEM (ours)': clrs[10],\n",
    "}\n",
    "markers = {\n",
    "    'VanillaModel': 'o',\n",
    "    'Bool': 's',\n",
    "    'Fuzzy': 'X', \n",
    "    'Fuzzy+': 'P',\n",
    "    'CEM without RandInt (ours)': 'D',\n",
    "    'CEM (ours)': 'D',\n",
    "}\n",
    "fig_width = 18\n",
    "fig_height = 3\n",
    "scale = 1\n",
    "trials = 5\n",
    "num_models = len(methods)\n",
    "\n",
    "fig, axs = plt.subplots(1, 5, figsize=(fig_width, fig_height))\n",
    "for j, (experiment_name, _) in enumerate(experiments.items()):\n",
    "    ax = axs[j]\n",
    "    labelcolor = []\n",
    "    for i, (_, method_name) in enumerate(methods.items()):\n",
    "        \n",
    "        if method_name == 'CEM (ours)':\n",
    "            continue\n",
    "\n",
    "        color = color_map[method_name]\n",
    "        \n",
    "        task_vals = acc_scores[(acc_scores['experiment']==experiment_name) & (acc_scores['method']==method_name)]['Task Accuracy (%)'].values\n",
    "        concept_vals = acc_scores[(acc_scores['experiment']==experiment_name) & (acc_scores['method']==method_name)]['concept AUC (%)'].values\n",
    "        ci_tasks = ci_interv(task_vals)\n",
    "        ci_concepts = ci_interv(concept_vals)\n",
    "        median_tasks = np.mean(task_vals)\n",
    "        median_concepts = np.mean(concept_vals)\n",
    "\n",
    "        ax.add_patch(patches.Rectangle((0, 100.2), 110, 110, **{'color': 'white', 'alpha': 1, 'zorder': 0.8}))\n",
    "        ax.add_patch(patches.Rectangle((100.2, 0), 110, 110, **{'color': 'white', 'alpha': 1, 'zorder': 0.8}))\n",
    "        ax.errorbar(\n",
    "            y=median_tasks,\n",
    "            x=median_concepts,\n",
    "            elinewidth=2,\n",
    "            color=color,\n",
    "            yerr=ci_tasks,\n",
    "            xerr=ci_concepts,\n",
    "            capsize=3,\n",
    "        )\n",
    "        ax.scatter(\n",
    "            y=median_tasks,\n",
    "            x=median_concepts,\n",
    "            marker=markers[method_name],\n",
    "            s=80,\n",
    "            color=color,\n",
    "            label=method_name,\n",
    "        )\n",
    "        labelcolor.append(color)\n",
    "        \n",
    "    if j == 0:\n",
    "        ax.set_ylabel(\"Task Accuracy (%)\", fontsize=18)\n",
    "        \n",
    "    ax.set_xlabel(\"Concept Alignment (%)\", fontsize=18)\n",
    "    ax.set_title(bold_text(experiment_name), fontsize=30)\n",
    "    if experiment_name == 'CelebA':\n",
    "        ax.set_xticks(np.arange(0, 101, 5))\n",
    "        ax.set_yticks(np.arange(0, 101, 5))\n",
    "        ax.set_xticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 5))), fontsize=15)\n",
    "        ax.set_yticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 5))), fontsize=15)\n",
    "        ax.set_xlim((66, 85))\n",
    "        ax.set_ylim((21, 35))\n",
    "    elif experiment_name == 'CUB':\n",
    "        ax.set_xticks(np.arange(0, 101, 5))\n",
    "        ax.set_yticks(np.arange(0, 101, 5))\n",
    "        ax.set_xticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 5))), fontsize=15)\n",
    "        ax.set_yticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 5))), fontsize=15)\n",
    "        ax.set_xlim((76, 90))\n",
    "        ax.set_ylim((61, 85))\n",
    "    else:\n",
    "        ax.set_xticks(np.arange(0, 101, 10))\n",
    "        ax.set_yticks(np.arange(0, 101, 10))\n",
    "        ax.set_xticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 10))), fontsize=15)\n",
    "        ax.set_yticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 10))), fontsize=15)\n",
    "        ax.set_xlim((41, 103))\n",
    "        ax.set_ylim((41, 103))\n",
    "    ax.grid(axis='y')\n",
    "    ax.grid(True)\n",
    "    \n",
    "    if experiment_name == 'XOR':\n",
    "        ann_alpha = 0.6\n",
    "        ax.annotate('CEM', xy=(98, 98), xytext=(85, 80), fontsize=12, alpha=ann_alpha, \n",
    "                    arrowprops=dict(arrowstyle=\"<-\", color='black', lw=1, alpha=ann_alpha))\n",
    "        ax.annotate('Hybrid-CBM', xy=(98, 98), xytext=(50, 80), fontsize=12, alpha=ann_alpha, \n",
    "                    arrowprops=dict(arrowstyle=\"<-\", color='black', lw=1, alpha=ann_alpha))\n",
    "        ax.annotate('Fuzzy-CBM', xy=(99, 52), xytext=(80, 60), fontsize=12, alpha=ann_alpha, \n",
    "                    arrowprops=dict(arrowstyle=\"<-\", color='black', lw=1, alpha=ann_alpha))\n",
    "        ax.annotate('Boolean-CBM', xy=(99, 52), xytext=(47, 60), fontsize=12, alpha=ann_alpha, \n",
    "                    arrowprops=dict(arrowstyle=\"<-\", color='black', lw=1, alpha=ann_alpha))\n",
    "\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "labels = ['No concepts',\n",
    " 'Boolean-CBM',\n",
    " 'Fuzzy-CBM',\n",
    " 'Hybrid-CBM',\n",
    " 'CEM withput RandInt (ours)',\n",
    " 'CEM (ours)']\n",
    "\n",
    "lgd = fig.legend(handles, labels, fontsize=18, loc='upper center', bbox_to_anchor=(0.5,-0.05), ncol=num_models)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HXh4eNCyZUu++uorefutW7cYOHAgDRo0oHHjxkyYMCHD5Fvv2r17N7a2tqxevTrDvjp16jB37lyCg4MZP368xmmpC5uYUuA9+eWXX/j5559JSEhAX18fW1tbypcvT0xMDPfv35cn6W/dujXLli2TFxgQNDty5AjTpk1j+/btNGvWLNfHp6am0q5dO/kP3NLSkvPnz6Orq6uxfGBgoDwTpbe3N1WqVNE+eEGjWbNmceDAAR49epTrY//55x/c3NzQ09PjxIkT8nqiz549w9XVFWdnZ6ZMmUJsbCxff/018fHxHDp0CAMDgwznCgkJwcXFhfLly3P06FGNZQBGjRrFH3/8wfjx49VWCHsfxBX7ezBv3jxWrFhBamoq48eP5+rVqxw8eJANGzawc+dOLl++zPTp0zEyMuLChQuMGDEi07m1hTR//fVXno6/ePEir169onr16lhbWxMSEsL58+fzKTpBG3n5nS5evJiEhAQ+/fRTtUWit23bRmJiIu7u7lhaWmJjY8PYsWPx8/PD29tb47m+++47IiMjmTt3bqZJHWD69Ono6emxYcMGgoKCtI49P4jEXshOnDjBrl270NHRYfXq1YwbNy7DklelS5fm008/Zd26dejp6XH//n3WrVv3niIuHu7cuZOn4/fv3w9Ax44d5SvxgwcP5jUsQUvR0dHygjG5dfv2bS5cuEDp0qUZPny42r4bN25QrVo1tYXI69WrJ+9714ULF/D09MTNzU1e5CMzNWrUwMXFhYSEBNavX69V7PlFJPZClJqaysqVKwHo378/7dq1y7J8ixYtGDp0KF27dpXXLk3v+fPnzJkzh44dO9KgQQMcHBxwcXHhu+++09iJ4+Hhga2tLX379gXg999/Z9CgQTRt2pQGDRrQrVs3fvvtt0zjefjwITNmzKBdu3bUr1+fFi1aMHHiRP7++2+N5VNSUti/fz9DhgyhSZMm1K9fn9atWzNp0iRu376doXz6Dsno6GguXbokH9ugQQO6dOnCr7/+SkpKinzM6tWrsbW1lVdlGjp0aK47L0NDQzl37hyQtkh4165dgbQVk0JDQ3N8Hsi68/TmzZt89tlnNGvWjEaNGtGjRw8OHDgAwIQJEzK04aZ/PxISErh//z7jx4/HycmJ+vXr0759exYtWpRhbc30x0Facho0aBCNGzemadOmfPrpp9y9exeAhIQEVq5cSadOnbC3t8fJyYm5c+dmuv5mcHAwS5YswcXFRf7Mde3alR9//JHw8PAM5bX5zA0ZMoTGjRuTmpoKIL8WDw+PnPwK5PN17do1w0IbL1++VEvqgDwv+rtX2fHx8cybNw8zMzOmT5+eo7pVC2IcOXJEXubxfRCJvRDduHEDf39/FAoFI0aMyNEx06dPZ/ny5RmWY7t48SLdunVjz549REZG8uGHH9KwYUOCg4PZtm0b3bt317gEncrWrVsZP348MTEx2NvbY2FhwePHj1mwYAEbNmzIUP7w4cP07t0bDw8PjI2NadasGaVLl8bLy4t+/fpx7NgxtfIJCQl89tlnzJ49mz///JOqVavy4YcfAmnzsQ8YMIBt27ZlGt/Jkyf54osvCAgIwN7enho1auDn58fSpUuZPHmyXK5mzZryFTaAo6NjrjsvDx06RFJSEkqlkjp16tCwYUOqV69OUlIShw8fzvF5suLt7c2QIUO4dOkSCoWCxo0bk5KSwqxZs1i6dGm2HW5//vknAwcO5N69e9SpU4caNWrw4sULtm/fzvjx4zM97uzZs4waNYq4uDjq16+PQqHg8uXLjBgxgpcvXzJq1Ci2bt2KtbU1SqWS0NBQdu/erXHe8b/++ovu3buzefNmQkNDadSoER988AEvXrxg/fr1dO3alX///TfTWHL6mXN0dMTR0VH+d4cOHejQoYNak0pmEhISOHv2LJC2cLem/To66mlP9W/VkoEqa9asITAwkKlTp+Z4wQ4HBwcsLS2JjY2VLxbeC0koNKtXr5aUSqXk7Oycp/OEhoZKTZs2lZRKpTRz5kwpPj5e3hcVFSV9+eWXklKplD755BMpMTFR3nfw4EFJqVRKLVq0kJo2bSpduXJF3peamirNnDlTUiqVUrNmzaSUlBR539OnT6V69epJtra20rFjx9SOWbVqlaRUKqWGDRtKb968kfctWLBAUiqVkpubmxQYGKh2zK5du6Q6depIderUkXx9feV9AQEBklKplJRKpeTo6Cjt2LFD7XUfO3ZM3n/u3Dm1fart165dy/X72alTJ0mpVEq//vqrvG3dunWSUqmUXFxcNB6TPtaAgAB5+/Tp0yWlUilNnz5d3hYfHy+1bNlSUiqV0pdffinFxcXJ+06fPi3Z29tL7dq1k5RKpbRq1SqNdbRt21basGGDlJqaKu8/dOiQvP/Bgwcaj2vXrp3k7e0t74uIiJDrcnFxkXr06CGFhoaqxaNUKiVbW1spODhY3h4dHS21atVKUiqV0tKlS9U+V6GhofJnzs3NTe2zo+1n7tq1a/JryI0rV65ISqVSqlevntrfhYqDg4PUrVs3tW1hYWGSUqmURo0aJW97+PChVLduXWnQoEHye56cnCy9efNG7bVrMmXKFEmpVEru7u65ij0/iSv2QvTPP/8AyLfI2jpw4ADh4eFUqlSJOXPmqK2EY2JiwnfffYeBgQHPnj3jwoULGY5/8+YNX3zxBR999JG8TaFQyO2Rb9++xd/fX963fft2kpKS6Nixo9xMoTpm3LhxWFtbExcXh5eXFwBhYWHs3bsXHR0dVq5cibW1tdoxAwYMoGfPnqSmprJ9+3aNr7FBgwYMHjxYbVvXrl3lO5ejR4/m9O3K0s2bN/n333/R1dWlW7du8nY3Nzd0dHTw8/PLc/v9xYsXCQkJQU9Pj3nz5mFkZCTv+/jjj/n888/lleszU7t2bb744gu1FaZcXV3lK8nMOhqdnJxo3769/O+yZcvSpUsXAPz8/Jg3b57a1ejHH3+MpaUlkiSprafr4eFBcHAwTZo0YerUqWor+pibm/PDDz9QtmxZ7t+/r3Gd1dx+5rSlWrpOqVRqXPy5atWqPH/+nKSkJHnb48ePAahevToAkiQxZ84cFAoF8+bNA9KGwjZt2pQWLVrQuHFj5s6dq3aO9FSLVGfWRFkYRGIvRBEREQB5Hrp48eJFIO2PUFMvvbm5ubzy+dWrVzWeI30SU6lWrZr889u3b+WfVV8Obdq0yXCMQqFg9+7dXLt2jYEDBwJw+fJlEhMTUSqVaudMr2PHjkDa2q2adO7cWeP2li1bAnnvLFVRtXE7OTlhaWkpb69YsaLcWZbXTtQ///wTADs7O6ysrDLs79evX7bn0PT7UigUVK1aFVD/faWnep/TU33RWlpayklI037V5xXgjz/+ANI+c5qYmJjISTs/PnPaCggIyHDe9Fq0aEFcXJxae/3OnTvlfQB79uzh9u3bfP7559SqVYvffvuNn3/+mRYtWrBs2TJ69erF7t27+emnnzTWYWNjoxbL+6D33mr+D1K15ak6hbSlGi2gVCozLVOzZk2uXr2qsc3T0NBQY4JJf4WjuhqJi4uTryZVSeRd755LdQUUHBzMmDFjNB6j6lgKCQkhJiYGY2Njtf2ZvTbVH2xQUBCSJOVqgV9NMajuMtzc3DLs79GjB1euXOHEiRPMnDmTUqVKaVWP6slU1RXhu6ysrLC2ts7yqj2zRKX6nWV29ahpfL3qYiCzsfeq/enb/VW/06NHj2ocPQLw5MkTIG2suKY4c/qZy4s3b94AUKFCBY37hw0bxr59+5g7dy6HDh0iMjKSp0+f4ujoiJOTEyEhIfz444/Y2NgwevRoALkP4qeffkJXV5fu3bvz6NEj9uzZw4QJEzLcGaheZ1xcHJGRkZQtWzbPryu3RGIvRKrFeHM70uJdkZGRABmGSaan2qcqm15WY3EzqwvIkHwzo7rSe/v2baZjg9OLjo7OcO7M/hhUryslJYW4uDhKly6do5g0OXbsGHFxcZQtW1atA1alY8eOmJiYyF8APXr00Koe1ZdYVn/gFhYWWSb23PzO0stqEeTcLJCsGvFy7969LDvlAaKiojJs0zb+3FJ1gGb2JVyxYkW2b9/O999/z927dzEwMMDV1ZUZM2agUCjkMesrV67E0NCQ169fExgYSM+ePdUeVmvWrBm3bt3i0aNHNGjQQK2O9E1tqs9XYROJvRDVrl0byHvbW06uUqX/f6D43REAeakrMTExV8d+9NFHbN26Vat6M3viM/3dTl5fm2rsemRkZIY/zncdPHhQ68Su+l1k9XvLy51HYVDFt3TpUlxdXd9zNHlTr149duzYkWG7asx6t27d5GaZ9E8ip6e6Kg8KCsr2s/M+iDb2QqQa7vfq1ascP1WXlJTEzZs31baprvw1XY2rqK6a83q1YGpqKv9Rp29zzYpqnLDqtlgbmq760m/X19dXuzLKrYcPH8pXnhUqVMDKykrjf6o/6Js3b/L8+XOt6lLdVWQ2NhzyfhdX0FT9Qnn5nRYG1WciLi4uV8epxqybmpqqDfVUXcy8e6Ghp6cnH/eu9HVr23yXVyKxF6LGjRtTq1YtAH7++eccHbN582YGDRqkNomR6spf1e6piaq9U1VWW4aGhnJnWmajFh48eMCZM2fkOxFV+3hAQIDGD35O+Pn5adyuSq55nZtFdbWuVCq5ePEiFy5c0PjfxYsXsbGxQZIkrTtRVeOv088Cmd6bN2/ea0dbTqh+p6rPVVFlYWEBwOvXr3N1nGrM+pQpUyhfvry8XZWY330ITNW8pqkpUFV3qVKl3kszDIjEXui+/vprAM6dO8fmzZuzLHvp0iXWrFkDoDZMTDU65fTp0xqbR4KCguRRI61atcpzzKr6VB2N75o1axZjx46VR+u0aNECAwMD4uPjMx2W6OHhwdChQzl16pTG/b///rvG7ao6HBwcNO7PScd0QkKC/EBVr169siyrUCjkMocOHVJ76jWn6tevD8Ddu3c13mXt2bMn1+csbKqnpH///fdMR6+MGTOGGTNm5MuXVPqmqdy856oO/tzcXT169IgtW7bg6OhInz591PapLmpUQ5VVVBcemjq1VRdAmQ02KAwisReyjz/+mGHDhgGwZMkSZs2alWHK0NjYWNavX8+YMWNITEykU6dO8iPZAD179sTCwoLg4GAWLFigNpogIiKC6dOnk5KSQoMGDbKd3yInhg0bhr6+Prdv3+aXX36Rt0uSxObNm7l37x5GRkZyG3S5cuXkIXxLlizJMIri0qVLLFq0iOvXr2c6EsLHx0ceiqji4eEhn+vdhKxqKsiuYw/g1KlTREREoK+vT/fu3bMt7+bmhq6uLsHBwVy6dCnb8u9q27YtpUuXJiEhgcWLF6uNNjlz5gybN29WG+tfFLm5uWFlZUVMTAwTJ05Umz4gPj6exYsX4+3tzdmzZzM8sq8NVXMj5Ox3qqJq7378+HGOJs5LP2Z9/vz5Gfo6zMzMsLOz49q1a/IXVlhYGKdPn6ZChQp88MEHGc6pGkuv+kJ/H0Tn6Xswc+ZMKlSowJo1azhw4AAHDx5EqVRiZWVFfHw89+/fJzo6Gl1dXYYPH86UKVPUPnBly5ZlxYoVfPnll+zbt4/Tp09Tu3Zt4uLi8PPzIy4ujipVqvDjjz/mS6ecjY0NCxcuZObMmaxYsYKDBw9iY2ODv78/z58/R09Pj4ULF1KxYkX5mMmTJ+Pn58fVq1cZMmQIdnZ2WFhYEBgYKA/B7Nmzp9oDT+l99dVXfPvtt2zcuBEbGxuCgoLkpqe+ffvK/RUqjo6OnD17luXLl3PgwAFMTEwyfDGoqJph2rdvn6NHxa2srGjVqhXnzp3j4MGDGsfzZ8XMzIxJkyaxaNEiPDw8uHz5Mra2toSEhPDgwQNmzpzJmTNnsn1I6X0yMTFh1apVjBw5kuvXr9O2bVsaNGiAJEk8fvyY8PBwjIyMWLZsWYb5WbRRvXp1ypcvT2hoKEOGDMHa2pqPPvqIb775JsvjHBwcKF26NLGxsdy4cSPbO1bVmPWRI0dm2mw5atQoJk6cSM+ePalbty6PHj0iPDycOXPmZGh7lyRJHsfv5OSUi1ecv8QV+3vy+eefc+rUKSZMmECjRo0IDQ3l6tWr3Lt3jypVqjB8+HCOHTvGjBkzNA5La9q0KUePHqVfv36YmJhw584dnj59SvXq1Rk/fjyHDx/O11tBNzc39u7dS+fOnYmLi+PatWtER0fTqVMn9u7dm+Hhk1KlSrFp0yYWLFhAkyZNePHiBVevXiU8PJxWrVqxZs0aFi9enGl9bdq0YcuWLVSpUoW//voLf39/ateuzaxZs5g/f36G8rNmzaJZs2YYGBgQEhIit7W+6/nz5/j4+ADZN8Ok17t3byBt7pWwsLAcH6cydOhQfvjhB+zt7YmKiuLu3buUKVOGDRs2MGzYMLkJSdUpVxQ1atSIY8eOMXz4cCpVqsRff/3FnTt3KFu2LP369ePo0aO0bt06X+oyNDTkhx9+oFatWqSkpPD27dtMf6fvHqd60jaz5jwV1Zj1KlWqMHbs2EzLOTs78/3331O+fHlu3bqFiYkJ33zzjfxAXnq3b98mJCSE0qVL5/oCID+JhTaEIuO/vHiFi4sLT58+Zd68efTv3/99h1Os3blzh379+lG6dGkuXryYL3cQOTV16lSOHj3KgAEDmDt3bqHV+y5xxS4IBSwhIYEzZ87w66+/ahzWGBwcLDdPqeYGF7SnWn80NjZW6+cotPHvv//i6emJoaEhX375ZaHVq4lI7IJQwPT19Vm8eDFLly5l4cKFap16MTExzJ49m9TUVJRKpca5W4TcmzFjBoaGhmzevLnQVjP6/vvvSU5OZuTIkTmaYrggicQuCAVMR0eHhQsXYmRkhKenJ61bt2b48OEMGDCA1q1bc+HCBUxNTVmyZMn7DrXEqFmzJtOmTSMmJoaZM2fmeX6m7Bw6dIhz587RsGFDRo0aVaB15YRI7IJQCD766CO5k7lUqVLcvHmT+/fvY2FhweDBgzl8+HCuFgcRsjd48GB69uzJlStX5JXLCsLDhw+ZN28eVlZWrF69ukh0gIvOU0EQhBJGXLELgiCUMCKxC4IglDAisQuCIJQwIrELgiCUMCKxC4IglDAisQuCIJQwIrELgiCUMCKxC4IglDAisQuCIJQw/we3eRq7/k2zFAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "clrs = sns.color_palette(\"colorblind\", 30)\n",
    "color_map = {\n",
    "    'VanillaModel': clrs[7],\n",
    "    'Bool': clrs[2],\n",
    "    'Fuzzy': clrs[5], \n",
    "    'Fuzzy+': clrs[6],\n",
    "    'CEM without RandInt (ours)': clrs[9],\n",
    "    'CEM (ours)': clrs[10],\n",
    "}\n",
    "markers = {\n",
    "    'VanillaModel': 'o',\n",
    "    'Bool': 's',\n",
    "    'Fuzzy': 'X', \n",
    "    'Fuzzy+': 'P',\n",
    "    'CEM without RandInt (ours)': 'D',\n",
    "    'CEM (ours)': 'D',\n",
    "}\n",
    "fig_width = 4\n",
    "fig_height = 4\n",
    "scale = 1\n",
    "trials = 5\n",
    "num_models = len(methods)\n",
    "\n",
    "fig, axs = plt.subplots(1, 1, figsize=(fig_width, fig_height))\n",
    "for j, (experiment_name, _) in enumerate(experiments.items()):\n",
    "    ax = axs\n",
    "    mean = acc_scores.groupby(['experiment', 'method']).mean().reset_index()\n",
    "    std = acc_scores.groupby(['experiment', 'method']).std().reset_index()\n",
    "    labelcolor = []\n",
    "    if experiment_name != 'Dot':\n",
    "        continue\n",
    "        \n",
    "    for i, (_, method_name) in enumerate(methods.items()):\n",
    "        if method_name == 'CEM (ours)' or method_name == 'Bool':\n",
    "            continue\n",
    "\n",
    "        color = color_map[method_name]\n",
    "        ax.add_patch(patches.Rectangle((0, 100.2), 110, 110, **{'color': 'white', 'alpha': 1, 'zorder': 0.8}))\n",
    "        ax.add_patch(patches.Rectangle((100.2, 0), 110, 110, **{'color': 'white', 'alpha': 1, 'zorder': 0.8}))\n",
    "        ax.errorbar(\n",
    "            y=mean[(mean['experiment']==experiment_name) & (mean['method']==method_name)]['Task Accuracy (%)'],\n",
    "            x=mean[(mean['experiment']==experiment_name) & (mean['method']==method_name)]['concept AUC (%)'],\n",
    "            elinewidth=2,\n",
    "            color=color,\n",
    "            yerr=2*std[(std['experiment']==experiment_name) & (std['method']==method_name)]['Task Accuracy (%)'],\n",
    "            xerr=2*std[(std['experiment']==experiment_name) & (std['method']==method_name)]['concept AUC (%)'],\n",
    "            capsize=3,\n",
    "        )\n",
    "        ax.scatter(\n",
    "            y=mean[(mean['experiment']==experiment_name) & (mean['method']==method_name)]['Task Accuracy (%)'],\n",
    "            x=mean[(mean['experiment']==experiment_name) & (mean['method']==method_name)]['concept AUC (%)'],\n",
    "            marker=markers[method_name],\n",
    "            s=80,\n",
    "            color=color,\n",
    "            label=method_name,\n",
    "        )\n",
    "        labelcolor.append(color)\n",
    "        \n",
    "    ax.set_title(bold_text(\"Trade-Offs (Dot)\"), fontsize=22) #, pad=20\n",
    "    ax.set_ylabel(\"Task Accuracy (%)\", fontsize=18)    \n",
    "    ax.set_xlabel(\"Concept Alignment (%)\", fontsize=18)\n",
    "    ax.set_xticks(np.arange(0, 101, 10))\n",
    "    ax.set_xticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 10))), fontsize=15)\n",
    "    ax.set_yticks(np.arange(0, 101, 10))\n",
    "    ax.set_yticklabels(list(map(lambda x: f\"{x}\", np.arange(0, 101, 10))), fontsize=15)\n",
    "    ax.set_xlim((41, 102))\n",
    "    ax.set_ylim((41, 102))\n",
    "    ax.grid(axis='y')\n",
    "    ax.grid(True)\n",
    "\n",
    "    \n",
    "    ax.annotate('OURS', xy=(91, 90), fontsize=11)\n",
    "    ax.annotate('No concepts', xy=(49, 99), fontsize=9)\n",
    "    ax.annotate('CBM Fuzzy\\n (Koh et al.)', xy=(81, 50), fontsize=9)\n",
    "    ax.annotate('   CBM Hybrid\\n(Manhipei et al.)', xy=(62, 89), fontsize=9)\n",
    "\n",
    "ax.scatter(\n",
    "    y=100,\n",
    "    x=100,\n",
    "    marker='*',\n",
    "    s=110,\n",
    "    color=clrs[3],\n",
    ")\n",
    "\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": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
