{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%load_ext tensorboard\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import numpy as np\n",
    "import os\n",
    "import random\n",
    "import tensorflow as tf\n",
    "import yaml\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from matplotlib import rc\n",
    "from matplotlib import cm\n",
    "import seaborn as sns\n",
    "from importlib import reload\n",
    "from pathlib import Path\n",
    "import sklearn\n",
    "from tensorflow.keras.models import load_model\n",
    "from joblib import dump, load\n",
    "import pandas as pd\n",
    "import torch\n",
    "import pytorch_lightning as pl\n",
    "import torchvision\n",
    "from torchvision import transforms\n",
    "from pytorch_lightning import seed_everything\n",
    "import celeba_experiments as celeba\n",
    "import models as models\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "################################################################################\n",
    "## Global Variables Defining Experiment Flow\n",
    "################################################################################\n",
    "\n",
    "\n",
    "GPU= 1\n",
    "NUM_WORKERS = 10\n",
    "LATEX_SYMBOL = \"$\"\n",
    "RESULTS_DIR = \"results/\"\n",
    "\n",
    "DATA_ROOT= celeba.CELEBA_ROOT\n",
    "CELEBA_RESULTS_DIR = os.path.join(\n",
    "    RESULTS_DIR,\n",
    "    \"celeba/\",\n",
    ")\n",
    "rc('text', usetex=(LATEX_SYMBOL == \"$\"))\n",
    "plt.style.use('seaborn-whitegrid')\n",
    "seed_everything(42)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load Model Configs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict\n",
    "celeba_configs = defaultdict(dict)\n",
    "\n",
    "for file in os.listdir(CELEBA_RESULTS_DIR):\n",
    "    if '_experiment_config.joblib' in file:\n",
    "        config = load(os.path.join(CELEBA_RESULTS_DIR, file))\n",
    "        fold = int(file[file.find(\"_fold_\") + len(\"_fold_\"):file.find(\"_experiment_config\")]) - 1\n",
    "        if \"Sequential\" in file:\n",
    "            extra = \"Sequential\"\n",
    "        elif \"Independent\" in file:\n",
    "            extra = \"Independent\"\n",
    "        else:\n",
    "            extra = \"\"\n",
    "            \n",
    "        model_name = f\"{extra}{config['architecture']}{config.get('extra_name', '')}\"\n",
    "        celeba_configs[str(fold)][model_name] = config\n",
    "\n",
    "\n",
    "print(\"CelebA Model names:\")\n",
    "for model_name, _ in celeba_configs['0'].items(): \n",
    "    print(\"\\t\", model_name)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_everything(42)\n",
    "og_config = celeba_configs['0']['MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat']\n",
    "if og_config.get(\"use_binary_vector_class\", False):\n",
    "    width = og_config.get('label_binary_width', 5)\n",
    "    def _binarize(concepts, selected, width):\n",
    "        result = []\n",
    "        binary_repr = []\n",
    "        concepts = concepts[selected]\n",
    "        for i in range(0, concepts.shape[-1], width):\n",
    "            binary_repr.append(str(int(np.sum(concepts[i : i + width]) > 0)))\n",
    "        return int(\"\".join(binary_repr), 2)\n",
    "\n",
    "    celeba_train_data = torchvision.datasets.CelebA(\n",
    "        root=DATA_ROOT,\n",
    "        split='all',\n",
    "        download=True,\n",
    "        target_transform=lambda x: x[0].long() - 1,\n",
    "        target_type=['attr'],\n",
    "    )\n",
    "\n",
    "    concept_freq = np.sum(celeba_train_data.attr.cpu().detach().numpy(), axis=0) / celeba_train_data.attr.shape[0]\n",
    "    print(\"Concept frequency is:\", concept_freq)\n",
    "    sorted_concepts = list(map(\n",
    "        lambda x: x[0],\n",
    "        sorted(enumerate(np.abs(concept_freq - 0.5)), key=lambda x: x[1]),\n",
    "    ))\n",
    "    num_concepts = og_config.get('num_concepts', celeba_train_data.attr.shape[-1])\n",
    "    concept_idxs = sorted_concepts[:num_concepts]\n",
    "    concept_idxs = sorted(concept_idxs)\n",
    "    if og_config.get('num_hidden_concepts', 0):\n",
    "        num_hidden = og_config.get('num_hidden_concepts', 0)\n",
    "        hidden_concepts = sorted(\n",
    "            sorted_concepts[num_concepts:min((num_concepts + num_hidden), len(sorted_concepts))]\n",
    "        )\n",
    "    else:\n",
    "        hidden_concepts = []\n",
    "    print(\"Selecting concepts:\", concept_idxs)\n",
    "    print(\"\\tAnd hidden concepts:\", hidden_concepts)\n",
    "    celeba_train_data = torchvision.datasets.CelebA(\n",
    "        root=DATA_ROOT,\n",
    "        split='all',\n",
    "        download=True,\n",
    "        transform=transforms.Compose([\n",
    "            transforms.Resize(og_config['image_size']),\n",
    "            transforms.CenterCrop(og_config['image_size']),\n",
    "            transforms.ToTensor(),\n",
    "            transforms.ConvertImageDtype(torch.float32),\n",
    "            transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5)),\n",
    "        ]),\n",
    "        target_transform=lambda x: [\n",
    "            torch.tensor(\n",
    "                _binarize(x[1].cpu().detach().numpy(), selected=(concept_idxs + hidden_concepts), width=width),\n",
    "                dtype=torch.long,\n",
    "            ),\n",
    "            x[1][concept_idxs].float(),\n",
    "        ],\n",
    "        target_type=['identity', 'attr'],\n",
    "    )\n",
    "    label_remap = {}\n",
    "    vals, counts = np.unique(\n",
    "        list(map(\n",
    "            lambda x: _binarize(x.cpu().detach().numpy(), selected=(concept_idxs + hidden_concepts), width=width),\n",
    "            celeba_train_data.attr\n",
    "        )),\n",
    "        return_counts=True,\n",
    "    )\n",
    "    for i, label in enumerate(vals):\n",
    "        label_remap[label] = i\n",
    "\n",
    "    celeba_train_data = torchvision.datasets.CelebA(\n",
    "        root=DATA_ROOT,\n",
    "        split='all',\n",
    "        download=True,\n",
    "        transform=transforms.Compose([\n",
    "            transforms.Resize(og_config['image_size']),\n",
    "            transforms.CenterCrop(og_config['image_size']),\n",
    "            transforms.ToTensor(),\n",
    "            transforms.ConvertImageDtype(torch.float32),\n",
    "            transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5)),\n",
    "        ]),\n",
    "        target_transform=lambda x: [\n",
    "            torch.tensor(\n",
    "                label_remap[_binarize(x[1].cpu().detach().numpy(), selected=(concept_idxs + hidden_concepts), width=width)],\n",
    "                dtype=torch.long,\n",
    "            ),\n",
    "            x[1][concept_idxs].float(),\n",
    "        ],\n",
    "        target_type=['identity', 'attr'],\n",
    "    )\n",
    "    num_classes = len(label_remap)\n",
    "\n",
    "    # And subsample to reduce its massive size\n",
    "    factor = og_config.get('label_dataset_subsample', 1)\n",
    "    if factor != 1:\n",
    "        train_idxs = np.random.choice(\n",
    "            np.arange(0, len(celeba_train_data)),\n",
    "            replace=False,\n",
    "            size=len(celeba_train_data)//factor,\n",
    "        )\n",
    "        print(\"Subsampling to\", len(train_idxs), \"elements.\")\n",
    "        celeba_train_data = torch.utils.data.Subset(celeba_train_data, train_idxs)\n",
    "else:\n",
    "    concept_selection = list(range(0, len(celeba.CONCEPT_SEMANTICS)))\n",
    "    if og_config.get('selected_concepts', False):\n",
    "        concept_selection = celeba.SELECTED_CONCEPTS\n",
    "    num_classes = og_config['num_classes']\n",
    "    sorted_labels = np.load(\n",
    "        os.path.join(\n",
    "            CELEBA_RESULTS_DIR,\n",
    "            f\"selected_top_{num_classes}_labels.npy\",\n",
    "        ),\n",
    "    )\n",
    "    label_remap = {}\n",
    "    for i, label in enumerate(sorted_labels):\n",
    "        label_remap[label] = i\n",
    "    print(\"len(label_remap) =\", len(label_remap))\n",
    "\n",
    "\n",
    "    # Now reload by transform the labels accordingly\n",
    "    celeba_train_data = torchvision.datasets.CelebA(\n",
    "        root=DATA_ROOT,\n",
    "        split='all',\n",
    "        download=True,\n",
    "        transform=transforms.Compose([\n",
    "            transforms.Resize(64),\n",
    "            transforms.CenterCrop(64),\n",
    "            transforms.ToTensor(),\n",
    "            transforms.ConvertImageDtype(torch.float32),\n",
    "            transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5)),\n",
    "        ]),\n",
    "        target_transform=lambda x: [\n",
    "            torch.tensor(\n",
    "                label_remap.get(x[0].cpu().detach().item() - 1, num_classes),\n",
    "                dtype=torch.long,\n",
    "            ),\n",
    "            x[1][concept_selection].float(),\n",
    "        ],\n",
    "        target_type=['identity', 'attr'],\n",
    "    )\n",
    "\n",
    "    train_idxs = np.where(\n",
    "        list(map(lambda x: x.cpu().detach().item() - 1 in label_remap, celeba_train_data.identity))\n",
    "    )[0]\n",
    "    celeba_train_data = torch.utils.data.Subset(celeba_train_data, train_idxs)\n",
    "total_samples = len(celeba_train_data)\n",
    "train_samples = int(0.7 * total_samples)\n",
    "test_samples = int(0.2 * total_samples)\n",
    "val_samples = total_samples - test_samples - train_samples\n",
    "print(f\"Data split is: {total_samples} = {train_samples} (train) + {test_samples} (test) + {val_samples} (validation)\")\n",
    "celeba_train_data, celeba_test_data, celeba_val_data = torch.utils.data.random_split(\n",
    "    celeba_train_data,\n",
    "    [train_samples, test_samples, val_samples],\n",
    ")\n",
    "train_dl = torch.utils.data.DataLoader(\n",
    "    celeba_train_data,\n",
    "    batch_size=1024,\n",
    "    shuffle=True,\n",
    "    num_workers=NUM_WORKERS,\n",
    ")\n",
    "test_dl = torch.utils.data.DataLoader(\n",
    "    celeba_test_data,\n",
    "    batch_size=1024,\n",
    "    shuffle=False,\n",
    "    num_workers=NUM_WORKERS,\n",
    ")\n",
    "val_dl = torch.utils.data.DataLoader(\n",
    "    celeba_val_data,\n",
    "    batch_size=1024,\n",
    "    shuffle=False,\n",
    "    num_workers=NUM_WORKERS,\n",
    ")\n",
    "\n",
    "label_set = set()\n",
    "sample = next(iter(train_dl))\n",
    "real_sample = []\n",
    "for derp in sample:\n",
    "    if isinstance(derp, list):\n",
    "        real_sample += derp\n",
    "    else:\n",
    "        real_sample.append(derp)\n",
    "sample = real_sample\n",
    "print(\"Sample has\", len(sample), \"elements.\")\n",
    "for i, derp in enumerate(sample):\n",
    "    print(\"Element\", i, \"has shape\", derp.shape, \"and type\", derp.dtype)\n",
    "\n",
    "N_CONCEPTS, N_TASKS = sample[2].shape[-1], num_classes #len(label_set)    \n",
    "\n",
    "print(\"Training sample shape is:\", sample[0].shape)\n",
    "print(\"Training label shape is:\", sample[1].shape)\n",
    "print(\"Training concept shape is:\", sample[2].shape)\n",
    "\n",
    "attribute_count = np.zeros((N_CONCEPTS,))\n",
    "samples_seen = 0\n",
    "for i, (_, (y, c)) in enumerate(train_dl):\n",
    "    print(\"\\rIn batch\", i, \"we have seen\", len(label_set), \"classes\")\n",
    "    c = c.cpu().detach().numpy()\n",
    "    attribute_count += np.sum(c, axis=0)\n",
    "    samples_seen += c.shape[0]\n",
    "    for l in y.reshape(-1).cpu().detach():\n",
    "        label_set.add(l.item())\n",
    "\n",
    "imbalance = samples_seen/attribute_count  - 1\n",
    "print(imbalance)\n",
    "print(\"Found a total of\", len(label_set), \"classes\")\n",
    "\n",
    "\n",
    "print(\"Computing the correlation matrix for concepts:\")\n",
    "total_c = []\n",
    "for (_, (_, c)) in train_dl:\n",
    "    total_c.append(c.cpu().detach())\n",
    "total_c = np.concatenate(total_c, axis=0)\n",
    "concept_corr_matrix = np.corrcoef(total_c.T)\n",
    "print(\"Concept correlation matrix shape:\", concept_corr_matrix.shape)\n",
    "print(\n",
    "    \"Max absolute correlation value:\", np.max(np.abs(concept_corr_matrix - np.eye(N_CONCEPTS))),\n",
    "    \"Max correlation value:\", np.max(concept_corr_matrix - np.eye(N_CONCEPTS)),\n",
    "    \"Min absolute correlation value:\", np.min(np.abs(concept_corr_matrix - np.eye(N_CONCEPTS))),\n",
    "    \"Min correlation value:\", np.min(concept_corr_matrix - np.eye(N_CONCEPTS)),\n",
    "    \"Mean absolute value:\", np.mean(np.abs(concept_corr_matrix - np.eye(N_CONCEPTS))),\n",
    "    \"Mean value:\", np.mean(concept_corr_matrix - np.eye(N_CONCEPTS)),\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load CelebA Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_trained_model(\n",
    "    config,\n",
    "    n_tasks=N_TASKS,\n",
    "    result_dir=CELEBA_RESULTS_DIR,\n",
    "    n_concepts=N_CONCEPTS,\n",
    "    split=0,\n",
    "    imbalance=None,\n",
    "    intervention_idxs=None,\n",
    "    adversarial_intervention=False,\n",
    "    train_dl=None,\n",
    "    sequential=False,\n",
    "    independent=False,\n",
    "):\n",
    "    if split is not None:\n",
    "        full_run_name = f\"{config['architecture']}{config.get('extra_name', '')}_{config['c_extractor_arch']}_fold_{split + 1}\"\n",
    "    else:\n",
    "        full_run_name = f\"{config['architecture']}{config.get('extra_name', '')}_{config['c_extractor_arch']}\"\n",
    "    selected_concepts = np.arange(n_concepts)\n",
    "    if config.get(\"message_passing_layers\"):\n",
    "        edges = []\n",
    "        edge_weights = []\n",
    "        corr_thresh = config.get('corr_thresh')\n",
    "        sorted_selected = sorted(selected_concepts)\n",
    "        for i in range(n_concepts):\n",
    "            i_idx = sorted_selected[i]\n",
    "            for j in range(i + 1, n_concepts):\n",
    "                j_idx = sorted_selected[j]\n",
    "                if np.abs(concept_corr_matrix[i_idx, j_idx]) >= corr_thresh:\n",
    "                    edges.append(np.array([[i, j], [j, i]]))\n",
    "                    if config.get(\"weighted_edges\"):\n",
    "                        weight = np.abs(concept_corr_matrix[i_idx, j_idx])\n",
    "                    else:\n",
    "                        weight = 1\n",
    "                    edge_weights.extend([weight, weight])\n",
    "        concept_edge_list = torch.cuda.LongTensor(np.concatenate(edges, axis=-1))\n",
    "        concept_edge_weights = torch.cuda.FloatTensor(np.array(edge_weights))\n",
    "    else:\n",
    "        concept_edge_list = None\n",
    "        concept_edge_weights = None\n",
    "    if (\n",
    "        (intervention_idxs is not None) and\n",
    "        (train_dl is not None) and\n",
    "        (config['architecture'] == \"ConceptBottleneckModel\") and\n",
    "        (not config.get('sigmoidal_prob', True))\n",
    "    ):\n",
    "        # Then let's look at the empirical distribution of the logits in order to\n",
    "        # be able to intervene\n",
    "        model = models.construct_model(\n",
    "            n_concepts=n_concepts,\n",
    "            n_tasks=n_tasks,\n",
    "            config=config,\n",
    "            imbalance=imbalance,\n",
    "            concept_edge_list=concept_edge_list,\n",
    "            concept_edge_weights=concept_edge_weights,\n",
    "        )\n",
    "        trainer = pl.Trainer(\n",
    "            gpus=GPU,\n",
    "        )\n",
    "        batch_results = trainer.predict(model, train_dl)\n",
    "        out_embs = np.concatenate(\n",
    "            list(map(lambda x: x[1], batch_results)),\n",
    "            axis=0,\n",
    "        )\n",
    "        active_intervention_values = []\n",
    "        inactive_intervention_values = []\n",
    "        for idx in range(n_concepts):\n",
    "            active_intervention_values.append(np.percentile(out_embs[:, idx], 95))\n",
    "            inactive_intervention_values.append(np.percentile(out_embs[:, idx], 5))\n",
    "        print(\"For\", full_run_name, \"we found its intervention values to be:\")\n",
    "        print(\"\\tactive_intervention_values =\", active_intervention_values)\n",
    "        print(\"\\tinactive_intervention_values =\", inactive_intervention_values)\n",
    "        active_intervention_values = torch.cuda.FloatTensor(active_intervention_values)\n",
    "        inactive_intervention_values = torch.cuda.FloatTensor(inactive_intervention_values)\n",
    "    else:\n",
    "        active_intervention_values = inactive_intervention_values = None\n",
    "    \n",
    "    if sequential:\n",
    "        _, c2y_model = models.construct_sequential_models(\n",
    "            n_concepts=n_concepts,\n",
    "            n_tasks=n_tasks,\n",
    "            config=config,\n",
    "            imbalance=imbalance,\n",
    "        )\n",
    "    elif independent:\n",
    "        _, c2y_model = models.construct_sequential_models(\n",
    "            n_concepts=n_concepts,\n",
    "            n_tasks=n_tasks,\n",
    "            config=config,\n",
    "            imbalance=imbalance,\n",
    "        )\n",
    "    else:\n",
    "        c2y_model = None\n",
    "    model = models.construct_model(\n",
    "        n_concepts=n_concepts,\n",
    "        n_tasks=n_tasks,\n",
    "        config=config,\n",
    "        imbalance=imbalance,\n",
    "        concept_edge_list=concept_edge_list,\n",
    "        concept_edge_weights=concept_edge_weights,\n",
    "        intervention_idxs=intervention_idxs,\n",
    "        adversarial_intervention=adversarial_intervention,\n",
    "        active_intervention_values=active_intervention_values,\n",
    "        inactive_intervention_values=inactive_intervention_values,\n",
    "        c2y_model=c2y_model,\n",
    "    )\n",
    "    print(\"sequential =\", sequential)\n",
    "    print(\"independent =\", independent)\n",
    "    if sequential:\n",
    "        extra = \"Sequential\"\n",
    "    elif independent:\n",
    "        extra = \"Independent\"\n",
    "    else:\n",
    "        extra = \"\"\n",
    "    print(\"extra =\", extra)\n",
    "    model_saved_path = os.path.join(\n",
    "        result_dir or \".\",\n",
    "        f'{extra}{full_run_name}.pt'\n",
    "    )\n",
    "    model.load_state_dict(torch.load(model_saved_path))\n",
    "    return model"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test Interventions on CelebA Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "if os.path.exists(\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'total_y_accs.joblib')\n",
    "):\n",
    "    total_y_accs = joblib.load(os.path.join(\"results/celeba_bin_intervention\", f'total_y_accs.joblib'))\n",
    "    total_c_accs = joblib.load(os.path.join(\"results/celeba_bin_intervention\", f'total_c_accs.joblib'))\n",
    "else:\n",
    "    total_y_accs = []\n",
    "    total_c_accs = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import models_cub\n",
    "reload(cub)\n",
    "reload(models_cub)\n",
    "\n",
    "WHITELIST = [\n",
    "    \"ConceptBottleneckModelFuzzy\",\n",
    "    \"ConceptBottleneckModelBool\",\n",
    "    \"ConceptBottleneckModelFuzzyExtraCapacity_Logit\",\n",
    "    'MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat',\n",
    "    'MixtureEmbModelSharedProb_Adaptive_NoProbConcat',\n",
    "    \"IndependentConceptBottleneckModel\",\n",
    "    \"SequentialConceptBottleneckModel\",\n",
    "]\n",
    "\n",
    "concepts_to_intervene = list(range(0, N_CONCEPTS + 1,))\n",
    "for j, num_concepts_intervened in enumerate(concepts_to_intervene):\n",
    "    while len(total_y_accs) <= j:\n",
    "        total_y_accs.append(defaultdict(list))\n",
    "        total_c_accs.append(defaultdict(list))\n",
    "    intervention_y_accs = total_y_accs[j]\n",
    "    c_accs = total_c_accs[j]\n",
    "    print(\"Intervening with\", num_concepts_intervened, \"our of\", N_CONCEPTS, \"concepts\")\n",
    "    for split, runs in celeba_configs.items():\n",
    "        intervention_idxs = sorted(np.random.choice(\n",
    "            list(range(N_CONCEPTS)),\n",
    "            size=num_concepts_intervened,\n",
    "            replace=False,\n",
    "        ))\n",
    "        print(\"\\tFor fold\", split, \"we will intervene on concepts\", intervention_idxs)\n",
    "        for model_name, config in runs.items(): \n",
    "            config[\"shared_prob_gen\"] = config.get(\"shared_prob_gen\", False)\n",
    "            config[\"per_concept_weight\"] = config.get(\"per_concept_weight\", False)\n",
    "            if (model_name not in WHITELIST) or (\"NoConceptSupervision\" in model_name):\n",
    "                continue\n",
    "            if (model_name in intervention_y_accs) and len(intervention_y_accs[model_name]) > (int(split)):\n",
    "                print(\"\\tSkipping\", model_name, \"as it was found in cached results\")\n",
    "                continue\n",
    "            print(\"Loading model\", model_name, \"with\", len(intervention_y_accs[model_name]), \"prev values\")\n",
    "            model = load_trained_model(\n",
    "                config=config,\n",
    "                n_tasks=N_TASKS,\n",
    "                n_concepts=N_CONCEPTS,\n",
    "                result_dir=CELEBA_RESULTS_DIR,\n",
    "                split=int(split),\n",
    "                intervention_idxs=intervention_idxs,\n",
    "                imbalance=imbalance if config.get(\"use_imbalance\", False) else None,\n",
    "                train_dl=train_dl,\n",
    "                sequential=(\"Sequential\" in model_name),\n",
    "                independent=(\"Independent\" in model_name),\n",
    "            )\n",
    "            print(\"imbalance:\", imbalance if config.get(\"use_imbalance\", False) else None)\n",
    "            trainer = pl.Trainer(\n",
    "                gpus=GPU,\n",
    "            )\n",
    "            [test_results] = trainer.test(model, test_dl, verbose=False,)\n",
    "            print(\"\\tFor model:\", model_name, f\"(fold {split}) intervening with\", num_concepts_intervened, \"gives:\")\n",
    "            print(\"\\t\\tTest task accuracy:\", test_results['test_y_accuracy'])\n",
    "            intervention_y_accs[model_name].append(test_results['test_y_accuracy'])\n",
    "            print(\"\\t\\tOriginal concept accuracy:\", test_results['test_c_accuracy'])\n",
    "            c_accs[model_name].append(test_results['test_c_accuracy'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MixtureEmbModelSharedProb_Adaptive_NoProbConcat\n",
      "ConceptBottleneckModelFuzzy\n",
      "ConceptBottleneckModelBool\n",
      "ConceptBottleneckModelFuzzyExtraCapacity_Logit\n",
      "MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat\n",
      "IndependentConceptBottleneckModel\n",
      "SequentialConceptBottleneckModel\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoMAAAFtCAYAAAB8yGDhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAADf7ElEQVR4nOy9d5xcVf3//7xl+vaaZLPp2VQSQoBIhyBIaEYEqQoo8gUFFfx8QEUQ/WHhI2JDRT4fKaI0QVGUKr0GiIKEEBLSs9leZqfPvfec3x93ZnYnW7JJtiU5z8djHjtzbjv3zt2Z17yrJqWUKBQKhUKhUCj2S/TRnoBCoVAoFAqFYvRQYlChUCgUCoViP0aJQYVCoVAoFIr9GCUGFQqFQqFQKPZjlBhUKBQKhUKh2I9RYlChUCgUCoViP0aJQYViDLBt2zZmzZrFN77xjd3a/pe//CWzZs1ixYoVQzwzhWJssXTpUpYuXTra01Ao9imUGFQoBomUkscff5zLLruMI488kvnz53PYYYdxxhlncNttt9HU1DTaU9wtXnjhBWbNmsWsWbP417/+tcvb76vXZXeIxWL88pe/pKura6frrlixglmzZnHDDTfs9vHWrl3L3Xffvdvbj3X++te/9vqB853vfIfvfOc7ozQjhWLfRIlBhWIQhMNhLrzwQq666iqampr43Oc+xw9+8AMuvfRSqqqquO222zj99NN54403Rnuqu8wDDzyArrsfBX/60592adt9+brsDu+99x633XbboMTgUPDkk0/y+9//fkSONRr87Gc/480338wbO+aYYzjmmGNGaUYKxb6JOdoTUCjGOlJKrr76alasWMFVV13F//t//w9N03LLL774Yl5++WWuuOIKvvKVr/DEE09QXl4+ijMePI2Njbz00kscfvjhbNu2jSeffJLrrruOgoKCnW67L1+X3eW9997bp483krS1tbF9+/bRnoZCsV+gLIMKxU544YUXeOWVVzjxxBO57LLL8gRPlqOOOoqrr76aZcuWEY1G85Y9/PDDnHnmmSxcuJBFixbxqU99invvvRchxE6P3d7ezk033cTSpUuZP38+S5Ys4fLLL+fdd9/tc30pJf/3f//HCSecwPz58znmmGO49dZbsSyrz/UffvhhHMfhpJNO4uSTTyYej/PYY48N4qrs2XURQvD73/+e5cuXs3DhQhYuXMjpp5/O7373O2zbzq2XjaW87rrrWLduHZdccgkHH3wwCxYs4Pzzz2fVqlW9jvnqq69y0UUXcfDBB7Nw4UIuuOACXn/99V7rvf3223zxi1/kkEMO4YADDuCEE07g5ptvJhwO5623dOlSDjvsMNrb2/n617/OkiVLWLBgAWeccQYvvvhi3nq33HILAMcffzyzZs0a1HXsyWDPN7veSy+9RH19PbNmzeKzn/1sbj+JRIKf/vSnfOITn2D+/PkccsghXHTRRbz00kt5x/vzn//MrFmz+Otf/8oPfvADDj30UG6++WbOO+88Zs+e3aeLv7GxkdmzZ3P++efnxgZ7n2ZjW99++20efvhhTjnlFA444AAOO+wwbrjhBhKJRG69ww8/HIDbbruNWbNm8ec//zl3nXeMGUylUtx2222cfPLJLFiwgEWLFnHWWWf1snRnXfO//vWvWblyJeeffz6LFi1i0aJFXHLJJWzdunWX3i+FYl9BWQYVip3w6KOPAq6layAuvPDCXmM/+tGPuOuuuzj++OM5++yzsW2b559/nptuuok1a9bw/e9/v9/9hcNhzjnnHNrb2zn77LOZOXMmzc3N3H///Zx//vn87//+L4cddljeNnfeeSft7e2cd955+Hw+nnjiCX77298Sj8f59re/nbeu4zg8/PDD+P1+TjrpJNra2vj1r3/Nn/70J84999xhvS7f/va3eeSRRzjqqKM466yzMAyDF198kf/5n//hgw8+yImqLM3NzVx88cWccsopnHLKKaxdu5bf//73XHbZZTz33HN4vV4AHn/8ca6++moOOuggrr32WhzH4b777uPiiy/mV7/6FccffzwA//znP/nKV75CXV0dV155JQUFBbzzzjvce++9vPLKK/zpT3/C7/fnjp9Kpbj88suZNm0a11xzDZFIhP/93//lS1/6En/4wx9YtGgR3/nOd/i///s/3nzzTb7zne9QVla202vYHzs73/Lycn7+85/z3e9+FyDveOl0mosvvpjVq1dz5plnsmDBAjo7O3n44Ye59NJL+dGPfsTy5cvzjvfEE08QDoe57rrrmDJlChMnTmTlypU888wzXHDBBXnrPvnkk0gpOf3004Hdu08feugh3n33Xc4++2wKCwt57LHHePDBB/H7/XzrW99i2bJlaJrGL3/5S0466SSWLVvGAQcc0Oe1EkJw2WWX8dprr3HKKadw0UUXkU6nefLJJ/n2t7/Ntm3buOqqq/K2+fDDD7n33ns5++yzOfPMM1m5ciV/+tOfuPLKK3P3tUKxXyEVCsWAHHvssXLBggXSsqxd2u6DDz6QdXV18sYbb+y17Morr5R1dXXy/fffl1JKuXXrVllXVyevvfba3Do/+MEP5OzZs+U777yTt21jY6NcvHixPO2003Jjv/jFL2RdXZ088cQTZTKZzI2nUin58Y9/XM6bN092dnbm7ee5556TdXV18utf/3pu7Nxzz5V1dXVy1apVOz2/3b0u77zzjqyrq5Of//znpRAib9mll14q6+rqcuecvS51dXXy8ccfz1v3m9/8pqyrq5OvvfaalFJKy7LkYYcdJk888USZSqVy67W3t8tFixbJE088UUrpXpMjjjhCfupTn8q7VlJKee+998q6ujp511135caOO+44WVdXJ2+44Ya8dVesWCHr6urkl770pdzYtddeK+vq6uTWrVt3eh3eeOMNWVdXJ6+//vrc2K6cb3Zuxx13XN5699xzT5/bR6NRedxxx8klS5bIdDotpZTykUcekXV1dXLJkiUyEonk1m1ra5Nz586VF1xwQa95n3322XL+/Pm5+2l37tMjjjhCdnV15c3toIMOksccc0yv6/OLX/wib787nvM//vGPXtdRSvd+OP300+WcOXNkY2Nj3j5nzZrVa76f+9znZF1dndyyZUuvc1Yo9nWUm1ih2Amtra2Ul5djmrtmSH/iiScAOPnkk+nq6sp7fOITnwDoFRzfk8cff5zp06czderUvG0DgQAHH3wwH374YS+X5vLly/H5fLnXXq+X448/HsuyemUKP/jggwCcccYZubHs84ceemin57e71+WZZ54B4JxzzunlWs4e//nnn88bHzduHMuWLcsby1qKWlpaAHjjjTdoa2tj2bJlOUshQGlpKffeey8/+9nPkFLy1ltv0dLSwoknnkgqlcq7tkuXLkXX9T5L9Jx99tl5rw899FBKSkp4++23d+n8B8Ngzrc/Hn/8cQoKCjjiiCPyzs1xHI499lg6OjpYt25d3jZHHHFEXpxoWVkZhx12GCtXrqStrS033tjYyDvvvMMxxxxDcXFx7ni7ep+eeeaZFBYW5l6HQiGmT5++03Pri573U09M0+STn/wkjuP0co8fdNBBLFy4MG8se32bm5t3eQ4Kxd6OchMrFDtB13WklLu83UcffQTQy83Wk/4C5CORCM3NzTQ3N3PIIYf0u31DQ0PuSxlg5syZvdapra3tdaxs4siECRP42Mc+lhtftmwZ3//+9/n73//ON77xDQKBQL/H3t3rsmHDhn7nOnXqVAA2bdqUNz5p0qRe62ZFbzbGMCtwsufbk3nz5uWeZ9+Xn/70p/z0pz/tc44NDQ29xmbMmNFrrKqqirVr1xKLxQiFQn3ua3cYzPn2x/r164lGowPeN9u3b2fu3Lm51xMnTuy1zqmnnsrLL7/MP//5z5wQ3tFFvLv3aX/nt7Nz64vs/dTX+7Mn95NCsT+hxKBCsROqqqpoaGggnU7nWZx2RiwWA+DWW2+loqKiz3UqKysH3Hb27Nl861vf6vcYNTU1ea/7EiTZL7lkMpkb+9Of/oTjOBx55JG9guaXLFnC888/zxNPPJFnNdyR3b0u8XgcoE+hmY3TyyYSZBnM/rPn5/F4Blwve22/+MUvctRRR/W5Ts94wew++5pD1pqWTqeHVAzuyvXckVgsRkVFBbfeemu/60yfPj3vdV9z//jHP47P5+Ppp5/OE4NFRUUce+yxuWPBrt+nPa3Xe0o8Hu/3/dmT+0mh2J9QYlCh2AmLFi1iy5YtvPnmmxx55JEDrtvR0UFpaSnQ/QVbW1vLggULdumY2W0ty2LJkiWD3q6n4NtxLPvFmE0cAdcd3J9L+KGHHhpQDO7udQkGg0C3KOxJdmx3hFW2bE0kEhlwvey+i4uLB31tLcvCtu1eLvFoNIphGHlWr9EmFAoRjUZ36b7pi4KCAo499liee+45wuEwiUSCd955h7POOisnpnb3Ph1KgsEglmX1+aNkT+4nhWJ/QsUMKhQ74VOf+hQAt99++4Bu0UceeYSlS5fmYpiybqu+unrEYjFSqVS/+yosLKS6uprNmzfnxWxlaW9v73O79evX9xrbvHkz0O0+ffHFF2lsbGTRokX8/Oc/7/MxZcoU/v3vf+dcqn2xp9dl7dq1/c5/2rRp/e6vP7LWpx3j4QBef/11/vznP5NOp3Pu6f66rQz22tq2TUNDA+Xl5bmi3WOBGTNmkEwmWb16da9lHR0du+TaP+2007AsixdeeKGXixh2/z4dSgZzP+1oCVUoFPmMnU8whWKMcthhh/Hxj3+ct956i+9973t91ux78cUX+d73vkcwGOTggw8GyCUA3H///b0sdj/+8Y/52Mc+xpYtW/o97rJly7Btu1eHiXA4zPLly7nkkkt6bfPXv/41b36pVIpnn30Wn8/HQQcdBHQnjlx66aWcdNJJfT6yNesGSiTZ3euSTZ558MEH84SJlDJ3vBNPPLHf4/bHwQcfTElJCU899VSedTAWi/Ff//Vf/PrXv8br9XLwwQdTXl7OSy+91EvgPf744xx55JF91lp85JFH8l6//vrrRCKR3HkBOVE4kNAfSnRd73Ws7H1355135o2n02k+//nPc9pppw2qxiW43T4KCwt56aWXePbZZ6mpqck73+zxdvU+HQyGYQA7v5YnnXQS4HbS6Uk6neYvf/kLPp9PdSxRKHaCchMrFIPgf/7nf7j66qu57777eO211zjttNOYNGkS7e3tvP7667zwwgtMmjSJ22+/PecOnT17NhdeeCH33HMP5557LmeffTamafLiiy/y9NNPc/rpp/cZyJ7l8ssv59lnn+W3v/0tbW1tHHLIIbS1tfHAAw/Q1tbG5z73uV7bVFdX89nPfpZly5bh8Xh47LHHqK+v59JLL6WgoICGhgZefvllJk2alIv76ovly5dz66238te//pX/+q//6jfGaneuy7x58zjvvPO47777uOyyy1i6dCm2bfPcc8/xxhtvcPHFF1NXV7cL746Lz+fjm9/8Jtdeey0XXHAB5513HuCKztbWVn7zm98AbrzYjTfeyNe+9jU+97nPcdFFF1FZWcmqVat48MEHmTp1Kscdd1zevr1eL6tWreKb3/wmixcvpquri//93//F4/HwxS9+MbdeNhHjxz/+MYcccgif/OQn+40XHQomTpzI66+/zg9/+EPGjx/PRRddxDnnnMNjjz3GY489RiqV4vjjjycajfLII4+wevVqbrrppkFbMr1eLyeccALPPfcc0WiUL3zhC70ywHfnPh0MNTU1aJrGY489RmlpKbNmzeozHOHjH/84xx57LH/6059IpVIsWbKEWCzGP/7xDzZs2MB1112Xu/cUCkXfKDGoUAyCUCjEb3/7W5555hkeffRRHnjgATo7O/F6vcycOZMbb7yR5cuX90qK+Na3vsXMmTN58MEH+eEPf4gQgilTpvDf//3fXHTRRQMes6SkhIceeohf/epXPP/88zz66KMEAgEWLlzITTfdxKGHHtprm6uuuopXX32Ve++9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EEKUYZIMCiGEEEKUYZIMCiGEEEKUYZIMXmb27Nl06dKltMO4LRYuXEh4eDh2u73I+VFRUUyePPk2R3Xneeihh5g4ceIt38/mzZtp1aoVFy5cuOX7upzNZuOhhx7igw8+uO37FjBx4kQeeuiha1pnx44dhIeHExcXV+wybdu2JTo6+kbDE8LNrFmz6NixY2mHcVXjx48nKiqqtMO4K/zrk8GoqCjCwsJYu3btFedv27YNgGeffZZVq1aVePsOh4NffvmFIUOG0KhRIyIiIujWrRszZ84kKyvLtdzEiROpXbs24eHhRf4cOXLEtVxYWBjfffddkfvLn79gwYISx1icPn36sH//fjQaDQA7d+5ky5YtN7zda5Gdnc1XX311xWXCwsKoW7eu2/lq2bIlTzzxBPv27btNkbrH8+uvv5Z4+WPHjrFy5corLnPx4kXGjh3LW2+9RcWKFW80xGum1Wp5//33+f7779m0adNt3//dLCoqivHjxxc571Y+SDRt2pT9+/dTpUqVG9rO9V7DIiIiuP/++5k2bRoWi8Vtudt1DRPX53oePoTTnDlzcDgcV11uy5YtPP300zRv3pz69evTvn17Jk6cyMmTJ13LLFiwgLCwMNd3qkGDBrRp04YXX3yRc+fOFVru+eefL3Jf+fNv5Frzr08GAcqXL89vv/1WaHpcXBynTp267u0qisLYsWP5+OOPeeKJJ9iyZQvbtm3j7bffZtOmTfTv39/tYhoREcH+/fuL/Kldu/ZV483OzmbNmjX4+vped8xX8s0337B169Zbsu3ibNu27arJIMCUKVPczteSJUuoXr06jz32GGfPnr0NkV6/BQsWXDUZ/Pjjj7nnnnvo1KnTbYqqsODgYB5++GH++9//luhiJ+5+N3IN27lzJ++99x6///47M2bMcNtuaV3DhLiVjh49ygcffHDV6+N3333HyJEjadmyJcuXL2fPnj188cUXWK1W+vfvz4EDB9yW3717N/v372fv3r38+OOPXLhwgWeffdZtGV9fX/78809SUlIK7W/BggUEBgbe0LHd8mRQURTMOetQFKVE02+Ftm3bsmHDBpKTk92mx8TE0L59e7dp0dHRtG3bFnBWGbdp04bMzEzX/EcffZSnn34agCVLlrBixQo++ugjOnfujMFgQK/X06RJE7788ksaNGhAfHz8NcfbtGlTYmNjOXTo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19Ro+max2WyMHTuWoUOH0qZNm9u+/3+71157jQceeID77ruPUaNGlXY4Qgjh5pZXEwshhBBCiDuXlAwKIYQQQpRhkgwKIYQQQpRhkgwKIYQQQpRhkgwKIYQQQpRhkgwKIYQQQpRhkgwKIYQQQpRhkgwKIYQQQpRhkgwKIcRtNHv2bLp06VLaYdywixcvEhkZyYYNG0pl/zNmzCAqKgq73V4q+xd3pq5du/LRRx+VaNlt27YRFhZGbGzsLY7qzvevH3Q6KiqKnTt3otVqC8175JFHmDBhQilEdWWxsbF8+umnbN68mZSUFDw9Palbty7Dhw8nMjISgLNnz9KpUyd0Oh0qlQqVSoWHhwd16tTh6aefpnnz5m7LBQYGsmHDhkLnIS4uji5dulCpUiXWrl17249ViLtdVFQU27dvZ86cOXTs2LHY+d9++63re3ktHA4H8+fPZ8GCBRw7dgxFUQgKCqJLly6MHDkST09PACZOnMjChQvR6XRFbufXX3+ldu3aTJw4kZiYGF599VWioqIKLZc/f+rUqfTr16/IbSmKwkMPPUSDBg2YNGnSNR/TzWCz2RgyZAiRkZGMGTOmVGK4W9ntdr744guWLFnC2bNnMZvNBAUF0bVrV0aPHo3RaCztEEts3bp1VKhQgbp1617zutu2bWPYsGGsXLmSatWqFbtcQkICc+fOZf369SQkJGA0GqlVqxZDhgyhR48eruXCwsLQarWu13l6eHhQvXp1RowYwf333++2nE6nY+PGjfj5+bntKzs7m8jISHJycjh69Og1H9P1KhMlgz169GD//v2Ffu7ERHD37t306dMHrVbLd999x969e1m4cCERERGMHDmSH3/80W35zz77jP3797Nv3z5WrFhBjRo1ePLJJ0lMTHRbTqVSsX79+kL7i4mJISAg4FYekhC3lKIobL9g5vLn2uKm3wrly5fnt99+KzQ9Li6OU6dOXfd2FUVh7NixfPzxxzzxxBNs2bKFbdu28fbbb7Np0yb69+9PVlaWa/mIiIgir3X79++ndu3aV403OzubNWvW4Ovre8W4li5dyrFjx3jmmWeu+9hulFarZezYsXzxxRecP3++1OK4G02fPp3vv/+eV199lS1btrBnzx7ee+89li9fXmrJ/fWKjo7m0KFDt2z7Z86coW/fvsTHxzNnzhz27NnDihUr6N69O6+88goz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JYQQQoiy67Ylg+svnCDXbgUg125l/YUTt2vXbvJL9l5++WVWrFjBkSNHAFAUxW25giV++UlWQfm/X94beceOHa4SvfDwcBYuXEhoaChqtZr9+/dfV8xGo5E2bdrwyCOP8MknnxSaX79+fSpWrMjKlSvZtm0bOp2OJk2aXNe+hBBCCFG23LZksH3Fmpg0zpIxk0ZH+4o1r7LG7dG+fXuAQsOvnDhxgurVqwMQGhpaaP6xY8fw9vYmMDDQbXrTpk1dJXr79++nT58+eHt7065dOz777DMsFkuhGNatW0evXr3Iycm5ary5ublFTh84cCCLFy9m0aJF9OvX76rbEUIIIYSA25gMvtO4O8/UbkWjgMo8U7sV7zTufrt2XUhcXBwffvgh9evX57777qN+/fpMnz6dhIQEzGYzX331FbGxsQwYMACAhx56iN9//53Nmzdjt9s5cOAA3333HQMHDizxOIWvvvoqZrOZoUOHsm/fPhwOB+np6cybN49x48bRp0+fYtv42e129uzZw48//sigQYOKXKZ3797s3buXP/74gz59+lzXeRFCCCFE2XPbBp3Wa7TMaNbrdu3OzZIlS1ixYgXgrNb19/enQ4cOPP/886jVambPns0777xD//79ycvL49577+Wbb76hdu3agDMZzMnJ4e233+b8+fNUqFCBRx55hMcff7zEMYSEhBATE8Mnn3zCuHHjSEhIwNPTkzp16hAdHU1kZKTb8lOmTOHNN98EQKPREBwczLBhw3jiiSeK3L6vry+RkZFkZmYSFBR0PadJCCGEEGWQSrm8MZwQQgghhCgzytw4g0IIIYQQ4h+SDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGGSDAohhBBClGH/D/G134wxAHFaAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "y_acc_means = [\n",
    "    {\n",
    "        method: np.mean(vals)\n",
    "        for method, vals in results.items()\n",
    "    } for results in total_y_accs\n",
    "]\n",
    "y_acc_stds = [\n",
    "    {\n",
    "        method: np.std(vals)\n",
    "        for method, vals in results.items()\n",
    "    } for results in total_y_accs\n",
    "]\n",
    "method_names = list(y_acc_means[-1].keys())\n",
    "\n",
    "x_vals = concepts_to_intervene\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "clrs = sns.color_palette(\"colorblind\", 30)\n",
    "\n",
    "color_map = {\n",
    "    'No Concepts': clrs[7],\n",
    "    'Sequential-CBM': clrs[1],\n",
    "    'Bool-CBM': clrs[2],\n",
    "    'Independent-CBM': clrs[3],\n",
    "    'Fuzzy-CBM': clrs[5],\n",
    "    'Hybrid-CBM': clrs[6],\n",
    "    \"MixCEM (ours)\": clrs[9],\n",
    "    \"MixCEM + RandInt (ours)\": clrs[10],\n",
    "}\n",
    "method_to_actual_name = {\n",
    "    'SequentialConceptBottleneckModel': 'Sequential-CBM',\n",
    "    'IndependentConceptBottleneckModel': 'Independent-CBM',\n",
    "    'ConceptBottleneckModelBool': 'Bool-CBM',\n",
    "    'ConceptBottleneckModelFuzzy': 'Fuzzy-CBM',\n",
    "    'ConceptBottleneckModelFuzzyExtraCapacity_Logit': 'Hybrid-CBM',\n",
    "    'MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat': \"MixCEM (ours)\",\n",
    "    'MixtureEmbModelSharedProb_Adaptive_NoProbConcat': \"MixCEM without RandInt (ours)\",\n",
    "}\n",
    "\n",
    "\n",
    "for method_name in method_names:\n",
    "    print(method_name)\n",
    "    if method_name not in method_to_actual_name:\n",
    "        continue\n",
    "    means = np.array([item[method_name] * 100 for item in y_acc_means])\n",
    "    stds = np.array([item[method_name] * 100 for item in y_acc_stds])\n",
    "    method_name = method_to_actual_name.get(method_name, method_name)\n",
    "    if method_name not in color_map:\n",
    "        color_map[method_name] = clrs[len(color_map)]\n",
    "    color = color_map[method_name]\n",
    "    ax.plot(\n",
    "        x_vals,\n",
    "        means,\n",
    "        c=color,\n",
    "        zorder=1,\n",
    "    )\n",
    "    ax.scatter(\n",
    "        x_vals,\n",
    "        means,\n",
    "        s=50,\n",
    "        label=method_name,\n",
    "        color=color,\n",
    "        zorder=2,\n",
    "        marker=\"x\" if \"(ours)\" in method_name else \".\",\n",
    "    )\n",
    "    ax.fill_between(\n",
    "        x_vals,\n",
    "        means - stds,\n",
    "        means + stds,\n",
    "        alpha=0.3,\n",
    "        facecolor=color,\n",
    "    )\n",
    "\n",
    "ax.set_xlabel(\"Concepts Intervened\", fontsize=15)\n",
    "ax.set_ylabel(\"Task Accuracy (%)\", fontsize=15)\n",
    "\n",
    "ax.grid(False)\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "plt.title('CelebA Concept Intervention', fontsize=20)\n",
    "lgd = fig.legend(handles, labels, fontsize=15, loc='upper center', bbox_to_anchor=(0.5,-0.001), ncol=3)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "joblib.dump(total_y_accs, os.path.join(\"results/celeba_bin_intervention\", f'total_y_accs.joblib'))\n",
    "joblib.dump(total_c_accs, os.path.join(\"results/celeba_bin_intervention\", f'total_c_accs.joblib'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test incorrect interventions in CUB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "if os.path.exists(\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'incorrect_total_y_accs.joblib')\n",
    "):\n",
    "    adversarial_total_y_accs = joblib.load(os.path.join(\"results/celeba_bin_intervention\", f'incorrect_total_y_accs.joblib'))\n",
    "else:\n",
    "    adversarial_total_y_accs = []\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import models_cub\n",
    "reload(cub)\n",
    "reload(models_cub)\n",
    "\n",
    "concepts_to_intervene = list(range(0, N_CONCEPTS + 1))\n",
    "for j, num_concepts_intervened in enumerate(concepts_to_intervene):\n",
    "    while len(adversarial_total_y_accs) <= j:\n",
    "        adversarial_total_y_accs.append(defaultdict(list))\n",
    "    intervention_y_accs = adversarial_total_y_accs[j]\n",
    "    print(\"Intervening with\", num_concepts_intervened, \"our of\", N_CONCEPTS, \"concepts\")\n",
    "    for split, runs in celeba_configs.items():\n",
    "        intervention_idxs = sorted(np.random.choice(\n",
    "            list(range(N_CONCEPTS)),\n",
    "            size=num_concepts_intervened,\n",
    "            replace=False,\n",
    "        ))\n",
    "        print(\"\\tFor fold\", split, \"we will intervene on concepts\", intervention_idxs)\n",
    "        for model_name, config in runs.items(): \n",
    "            config[\"shared_prob_gen\"] = config.get(\"shared_prob_gen\", False)\n",
    "            config[\"per_concept_weight\"] = config.get(\"per_concept_weight\", False)\n",
    "            if (model_name not in WHITELIST) or (\"NoConceptSupervision\" in model_name):\n",
    "                continue\n",
    "            if (model_name in intervention_y_accs) and len(intervention_y_accs[model_name]) >= (int(split) + 1):\n",
    "                print(\"\\tSkipping\", model_name, \"as it was found in cached results\")\n",
    "                continue\n",
    "            model = load_trained_model(\n",
    "                config=config,\n",
    "                n_tasks=N_TASKS,\n",
    "                n_concepts=N_CONCEPTS,\n",
    "                result_dir=CELEBA_RESULTS_DIR,\n",
    "                split=int(split),\n",
    "                intervention_idxs=intervention_idxs,\n",
    "                imbalance=imbalance if config.get(\"use_imbalance\", False) else None,\\\n",
    "                adversarial_intervention=True,\n",
    "                sequential=(\"Sequential\" in model_name),\n",
    "                independent=(\"Independent\" in model_name),\n",
    "            )\n",
    "            print(\"imbalance:\", imbalance if config.get(\"use_imbalance\", False) else None)\n",
    "            trainer = pl.Trainer(\n",
    "                gpus=GPU,\n",
    "            )\n",
    "            [test_results] = trainer.test(model, test_dl, verbose=False,)\n",
    "            print(\"\\tFor model:\", model_name, f\"(fold {split}) intervening with\", num_concepts_intervened, \"gives:\")\n",
    "            print(\"\\t\\tTest task accuracy:\", test_results['test_y_accuracy'])\n",
    "            intervention_y_accs[model_name].append(test_results['test_y_accuracy'])\n",
    "            print(\"\\t\\tOriginal concept accuracy:\", test_results['test_c_accuracy'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "joblib.dump(\n",
    "    adversarial_total_y_accs,\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'adversarial_total_y_accs.joblib'),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MixtureEmbModelSharedProb_Adaptive_NoProbConcat\n",
      "ConceptBottleneckModelFuzzy\n",
      "ConceptBottleneckModelBool\n",
      "ConceptBottleneckModelFuzzyExtraCapacity_Logit\n",
      "MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat\n",
      "IndependentConceptBottleneckModel\n",
      "SequentialConceptBottleneckModel\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoMAAAFtCAYAAAB8yGDhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAD1qElEQVR4nOydd5xcVd3/37fMnT4729N7NoUUkhAgoSYgEGpoggEUbA+oPCoqtkf08QGx/cCCCKIIBJFeDL0HAiFAaOm9Z3ubnX7L+f0xsy3bN7vZlPN+vfLKzp1zzj1zd/bOZ75VEUIIJBKJRCKRSCRHJOpAb0AikUgkEolEMnBIMSiRSCQSiURyBCPFoEQikUgkEskRjBSDEolEIpFIJEcwUgxKJBKJRCKRHMFIMSiRSCQSiURyBCPFoERyELB7924mTJjAj370o17N//Of/8yECRNYsWJFH+9MIjm4mD9/PvPnzx/obUgkhxVSDEok3UQIwfPPP8+1117LiSeeyJQpU5gzZw4XXXQRd9xxB+Xl5QO9xV7x5ptvMmHCBCZMmMBHH33U4/mH63XpDbFYjD//+c9EIpEux65YsYIJEyZw00039fp8Gzdu5L777uv1/IOdZ555ps0XnJ///Of8/Oc/H6AdSSSHJ1IMSiTdoL6+ni996Ut897vfpby8nC9+8Yv86le/4utf/zpFRUXccccdnH/++bz33nsDvdUe8/DDD6OqmVvBY4891qO5h/N16Q2rVq3ijjvu6JYY7AtefPFFHnjggQNyroHgD3/4A++//36rY6eccgqnnHLKAO1IIjk80Qd6AxLJwY4QghtuuIEVK1bw3e9+l//6r/9CUZSm56+55hrefvttvvWtb/Hf//3fvPDCC+Tn5w/gjrtPWVkZb731FnPnzmX37t28+OKL/PSnPyUQCHQ593C+Lr1l1apVh/X5DiTV1dXs3bt3oLchkRwRSMugRNIFb775JsuWLeOMM87g2muvbSV4GjnppJO44YYbWLBgAdFotNVzjz/+OJdccgnTp09nxowZXHjhhSxevBjHcbo8d01NDTfffDPz589nypQpHHfccVx33XV8+umn7Y4XQvD3v/+dz33uc0yZMoVTTjmF2267DdM02x3/+OOPY9s2Z511FmeffTbxeJwlS5Z046rs33VxHIcHHniAhQsXMn36dKZPn87555/PP/7xDyzLahrXGEv505/+lE2bNvHVr36VY445hmnTpnHFFVewevXqNud85513uPrqqznmmGOYPn06V155JcuXL28z7sMPP+RrX/sas2fPZurUqXzuc5/jN7/5DfX19a3GzZ8/nzlz5lBTU8P3vvc9jjvuOKZNm8ZFF13E0qVLW437/e9/D8Bpp53GhAkTunUdW9Ld19s47q233mLPnj1MmDCBq666qmmdRCLB7bffzplnnsmUKVOYPXs2V199NW+99Var8z355JNMmDCBZ555hl/96lcce+yx/OY3v2HRokVMnDixXRd/WVkZEydO5Iorrmg61t33aWNs64cffsjjjz/OOeecw9SpU5kzZw433XQTiUSiadzcuXMBuOOOO5gwYQJPPvlk03XeN2YwlUpxxx13cPbZZzNt2jRmzJjBpZde2sbS3eiav/POO1m5ciVXXHEFM2bMYMaMGXz1q19l165dPfp9SSSHC9IyKJF0wdNPPw1kLF2d8aUvfanNsV//+tf885//5LTTTuOyyy7DsizeeOMNbr75ZtavX88tt9zS4Xr19fVcfvnl1NTUcNlllzF+/HgqKir497//zRVXXME999zDnDlzWs259957qampYdGiRbjdbl544QXuvvtu4vE4//M//9NqrG3bPP7443g8Hs466yyqq6u58847eeyxx/jCF77Qr9flf/7nf3jiiSc46aSTuPTSS9E0jaVLl/Lb3/6WdevWNYmqRioqKrjmmms455xzOOecc9i4cSMPPPAA1157La+//jqGYQDw/PPPc8MNNzBz5kx++MMfYts2Dz30ENdccw1/+ctfOO200wB49dVX+e///m9KSkq4/vrrCQQCfPLJJyxevJhly5bx2GOP4fF4ms6fSqW47rrrGDNmDDfeeCMNDQ3cc889fOMb3+DBBx9kxowZ/PznP+fvf/8777//Pj//+c/Jy8vr8hp2RFevNz8/nz/+8Y/87//+L0Cr86XTaa655hrWrl3LJZdcwrRp06irq+Pxxx/n61//Or/+9a9ZuHBhq/O98MIL1NfX89Of/pRRo0YxbNgwVq5cySuvvMKVV17ZauyLL76IEILzzz8f6N379NFHH+XTTz/lsssuIxgMsmTJEh555BE8Hg8/+clPWLBgAYqi8Oc//5mzzjqLBQsWMHXq1HavleM4XHvttbz77rucc845XH311aTTaV588UX+53/+h927d/Pd73631ZwNGzawePFiLrvsMi655BJWrlzJY489xvXXX9/0vpZIjiiERCLplFNPPVVMmzZNmKbZo3nr1q0TJSUl4he/+EWb566//npRUlIi1qxZI4QQYteuXaKkpET88Ic/bBrzq1/9SkycOFF88sknreaWlZWJWbNmifPOO6/p2J/+9CdRUlIizjjjDJFMJpuOp1Ipcfrpp4ujjjpK1NXVtVrn9ddfFyUlJeJ73/te07EvfOELoqSkRKxevbrL19fb6/LJJ5+IkpIS8eUvf1k4jtPqua9//euipKSk6TU3XpeSkhLx/PPPtxr74x//WJSUlIh3331XCCGEaZpizpw54owzzhCpVKppXE1NjZgxY4Y444wzhBCZa3LCCSeICy+8sNW1EkKIxYsXi5KSEvHPf/6z6di8efNESUmJuOmmm1qNXbFihSgpKRHf+MY3mo798Ic/FCUlJWLXrl1dXof33ntPlJSUiJ/97GdNx3ryehv3Nm/evFbj7r///nbnR6NRMW/ePHHccceJdDothBDiiSeeECUlJeK4444TDQ0NTWOrq6vF5MmTxZVXXtlm35dddpmYMmVK0/upN+/TE044QUQikVZ7mzlzpjjllFPaXJ8//elPrdbd9zU/99xzba6jEJn3w/nnny8mTZokysrKWq05YcKENvv94he/KEpKSsTOnTvbvGaJ5HBHuoklki6oqqoiPz8fXe+ZIf2FF14A4OyzzyYSibT6d+aZZwK0CY5vyfPPP8/YsWMZPXp0q7ler5djjjmGDRs2tHFpLly4ELfb3fTYMAxOO+00TNNskyn8yCOPAHDRRRc1HWv8+dFHH+3y9fX2urzyyisAXH755W1cy43nf+ONN1odHzRoEAsWLGh1rNFSVFlZCcB7771HdXU1CxYsaLIUAuTm5rJ48WL+8Ic/IITggw8+oLKykjPOOINUKtXq2s6fPx9VVdst0XPZZZe1enzssccSDof58MMPe/T6u0N3Xm9HPP/88wQCAU444YRWr822bU499VRqa2vZtGlTqzknnHBCqzjRvLw85syZw8qVK6murm46XlZWxieffMIpp5xCTk5O0/l6+j695JJLCAaDTY/9fj9jx47t8rW1R8v3U0t0XeeCCy7Atu027vGZM2cyffr0Vscar29FRUWP9yCRHOpIN7FE0gWqqiKE6PG8zZs3A7Rxs7WkowD5hoYGKioqqKioYPbs2R3OLy0tbfpQBhg/fnybMcOHD29zrsbEkSFDhnD88cc3HV+wYAG33HILzz77LD/60Y/wer0dnru312Xr1q0d7nX06NEAbN++vdXxESNGtBnbKHobYwwbBU7j623JUUcd1fRz4+/l9ttv5/bbb293j6WlpW2OjRs3rs2xoqIiNm7cSCwWw+/3t7tWb+jO6+2ILVu2EI1GO33f7N27l8mTJzc9HjZsWJsx5557Lm+//TavvvpqkxDe10Xc2/dpR6+vq9fWHo3vp/Z+P/vzfpJIjiSkGJRIuqCoqIjS0lLS6XQri1NXxGIxAG677TYKCgraHVNYWNjp3IkTJ/KTn/ykw3MMHTq01eP2BEnjh1wymWw69thjj2HbNieeeGKboPnjjjuON954gxdeeKGV1XBfentd4vE4QLtCszFOrzGRoJHurN/4+lwuV6fjGq/t1772NU466aR2x7SMF2xcs709NFrT0ul0n4rBnlzPfYnFYhQUFHDbbbd1OGbs2LGtHre399NPPx23283LL7/cSgyGQiFOPfXUpnNBz9+nLa3X+0s8Hu/w97M/7yeJ5EhCikGJpAtmzJjBzp07ef/99znxxBM7HVtbW0tubi7Q/AE7fPhwpk2b1qNzNs41TZPjjjuu2/NaCr59jzV+MDYmjkDGHdyRS/jRRx/tVAz29rr4fD6gWRS2pPFYb4RVY9mahoaGTsc1rp2Tk9Pta2uaJpZltXGJR6NRNE1rZfUaaPx+P9FotEfvm/YIBAKceuqpvP7669TX15NIJPjkk0+49NJLm8RUb9+nfYnP58M0zXa/lOzP+0kiOZKQMYMSSRdceOGFANx1112dukWfeOIJ5s+f3xTD1Oi2aq+rRywWI5VKdbhWMBikuLiYHTt2tIrZaqSmpqbdeVu2bGlzbMeOHUCz+3Tp0qWUlZUxY8YM/vjHP7b7b9SoUXz88cdNLtX22N/rsnHjxg73P2bMmA7X64hG69O+8XAAy5cv58knnySdTje5pzvqttLda2tZFqWlpeTn5zcV7T4YGDduHMlkkrVr17Z5rra2tkeu/fPOOw/TNHnzzTfbuIih9+/TvqQ776d9LaESiaQ1B88dTCI5SJkzZw6nn346H3zwAb/85S/brdm3dOlSfvnLX+Lz+TjmmGMAmhIA/v3vf7ex2P3ud7/j+OOPZ+fOnR2ed8GCBViW1abDRH19PQsXLuSrX/1qmznPPPNMq/2lUilee+013G43M2fOBJoTR77+9a9z1llntfuvsWZdZ4kkvb0ujckzjzzySCthIoRoOt8ZZ5zR4Xk74phjjiEcDvPSSy+1sg7GYjG+//3vc+edd2IYBscccwz5+fm89dZbbQTe888/z4knnthurcUnnnii1ePly5fT0NDQ9LqAJlHYmdDvS1RVbXOuxvfdvffe2+p4Op3my1/+Muedd163alxCpttHMBjkrbfe4rXXXmPo0KGtXm/j+Xr6Pu0OmqYBXV/Ls846C8h00mlJOp3mqaeewu12y44lEkkXSDexRNINfvvb33LDDTfw0EMP8e6773LeeecxYsQIampqWL58OW+++SYjRozgrrvuanKHTpw4kS996Uvcf//9fOELX+Cyyy5D13WWLl3Kyy+/zPnnn99uIHsj1113Ha+99hp333031dXVzJ49m+rqah5++GGqq6v54he/2GZOcXExV111FQsWLMDlcrFkyRL27NnD17/+dQKBAKWlpbz99tuMGDGiKe6rPRYuXMhtt93GM888w/e///0OY6x6c12OOuooFi1axEMPPcS1117L/PnzsSyL119/nffee49rrrmGkpKSHvx2Mrjdbn784x/zwx/+kCuvvJJFixYBGdFZVVXFX//6VyATL/aLX/yC73znO3zxi1/k6quvprCwkNWrV/PII48wevRo5s2b12ptwzBYvXo1P/7xj5k1axaRSIR77rkHl8vF1772taZxjYkYv/vd75g9ezYXXHBBh/GifcGwYcNYvnw5t956K4MHD+bqq6/m8ssvZ8mSJSxZsoRUKsVpp51GNBrliSeeYO3atdx8883dtmQahsHnPvc5Xn/9daLRKF/5ylfaZID35n3aHYYOHYqiKCxZsoTc3FwmTJjQbjjC6aefzqmnnspjjz1GKpXiuOOOIxaL8dxzz7F161Z++tOfNr33JBJJ+0gxKJF0A7/fz913380rr7zC008/zcMPP0xdXR2GYTB+/Hh+8YtfsHDhwjZJET/5yU8YP348jzzyCLfeeiuO4zBq1Ch+8IMfcPXVV3d6znA4zKOPPspf/vIX3njjDZ5++mm8Xi/Tp0/n5ptv5thjj20z57vf/S7vvPMOixcvpqysjIKCAq6//nquu+46oDlx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vLzw8vJi0qRJpKen8+effzq3a9OmDT179kSr1dK5c2f8/f05evQoAAsWLKBr16507twZrVZLXFwc//73v/Hz8+PIkSPs2rWLiRMnEhgYiF6v58EHHyQiIsKliVCj0fD8889jMBgICwtj1KhRrFmzxqX2sUBubi4OhwN3d3ckScLPz4/Zs2eX2PRtt9v58ccfGTp0KADdu3fH29ubRYsWObdZuXIl3t7ePProo+j1epo2berSt7BTp074+fmxatUq57Lly5fTs2dPvLy8+Omnn2jatCkjRoxAp9MRFBTEK6+8wvbt211qGDt37uysqS3tOnr27MmmTZto0aIFAC1atKBx48bs27fP5foGDRqEr68vkiQVufZZs2YxZ84cvLy80Ol09O/fH6PRyIkTJ4p9rQq0bduWRo0aufTpW758Ob169cLHx+ea+14dW2RkJBqNhvvuuw+r1crp06eL3Xb+/Pn06tWLnj17otFoqFu3Lv/85z9ZtmwZZrPZuV3fvn2pWbMmkiQxYMAATpw4wfHjxwGw2WysWrWKQYMGAfDdd98xfPhw2rZtiyzLREZGMnbsWGdtboExY8YQFhaGXq+nb9++pKenk5ycTGZmJsuWLeO5554jLCwMrVZLr169iIuL46effgLyn4vdtWtXOnbsiE6no3fv3rRt27bMr5EgCKCt6gAE4U5TkBTodLpSt01ISKBu3bro9XrnMn9/f/z9/V366NWrV89lP3d3d0wmk/MYXbp0cVnfs2dPIP+LEmDAgAEu61VVpVGjRs7f69ati1Z7pTgICwvDbDaTkZFRJOaGDRsyZswYHnnkEZo0aUKHDh3o27cvLVu2LPYa165dS3p6ujNB0Gg0DBkyhAULFvDII48gSRIXL16kVq1aaDQa536F49NqtfTr148VK1bw4IMPkp2dzaZNm5g7dy4Ap06dYt++fURFRbmcW6PRcO7cOerWreu8rrJeh9VqZfbs2fzxxx+kp6cD+clO4bgKXruSHDt2jFmzZnHw4EGMRqNzeVmaMYcNG8a8efN44YUXsFqtrFu3znm9ZVX4fePm5gbgktgVdurUKRISEli9erXLckVRSEpKcv5tCl9vREQEkZGRrFixgsaNG7NlyxZMJhN9+/Z1HvP48eP85z//ce5TcINhtVqdywofs3Ccly5dQlEUnn76aZdkW1VV59/p4sWL3HXXXS4xN2rUyJmgCoJQOpEMCkIFCw8PR5Zl4uPjiYyMvOa2Foul2No3RVFcvvyKq3UqIMsyiqIUu85gMADw119/UaNGjRKPcfX+BTHJcvGNB5MnT+bxxx/nr7/+4s8//+TBBx/kscceY8KECUW2nT9/Pg6Hg3vuuce5zOFwkJeXx19//UWXLl2wWq1FrvHq12XAgAF89913JCcn8+eff+Ln5+dMAtzc3OjevXupyVLhpLu063jnnXf466+/+PTTT2nevDkajYbhw4cXOWZJSX9OTg6PPfYYXbt25bfffiMoKIhTp045E6XSDBw4kBkzZrBx40bMZjMBAQF06NChTPsWKOnvVxw3NzdGjRrF66+/Xuz6gil+rr7eAQMG8MsvvzB+/HiWL1/O3Xff7ay9dHNz49lnn3X20bzeOAvevz/99BPNmjUrdhur1Vpk/5I+D4IgFE80EwtCBfPx8aFbt2588cUXLrUfBdavX0///v3Jy8ujfv36JCQkuNQUpaSkkJGRQf369ct0vvDwcE6dOuWybMmSJezcuZPw8HAADh065LK+oCm7wPnz552d+gvWe3h44OvrW+R8iqKQmZlJSEgIQ4YM4d///jdvvfUW//vf/4pse/z4cXbs2MFHH33EkiVLnD/Lli2jY8eOfP/99wDUrFmTS5cuucR07Ngxl2NFRUURHh7O2rVr+f333xkwYICztio8PJyjR4+6JAEWi+Wag1pKu449e/bQu3dvoqOj0Wg0ZWreLezkyZNkZ2czduxYgoKCAJwDNcrC19eXe+65h+XLl7Ns2TIGDx58zZuCGxUeHs7hw4ddlmVnZ5OZmXnN/e677z5Onz7NoUOH+OOPPxg4cKDLMa9+76WlpbnUkl5LWFgYGo2myDEuXLjgfL/WrFmT8+fPu6y/+r0jCMK1iWRQECrB66+/jsViYdSoUezfvx9FUcjKymL+/Pm88MILDBw4EA8PD+677z4UReHDDz/EZDKRmZnJ+++/T61atejatWuZzjVy5Ei2bt3K6tWrsdlsbN68mTfeeAPIbwrt3Lkz06ZNIyEhAYfDwZo1a+jXrx+7d+92HsNmszF79mzMZjOJiYksWLCAPn36AODh4QHkN/nl5OTw22+/cd9997F//35UVcVoNHLgwAEaNGhQJLbvvvuO8PBw+vTpQ506dVx+HnzwQTZs2MCFCxeIi4sjLS2N//73v1itVg4cOOAyYrTAgAEDWL58Odu3b3c2OwOMGDGClJQUZs2aRW5uLllZWbz99ts8/PDDJdYSlXYddevW5dChQ+Tl5XH+/Hlef/11atWqxcWLF4utzb1aQbP333//jc1mY8uWLc4+jxcvXix1f4Dhw4ezbt06/vrrLwYPHlymfcrK3d2dpKQkMjMzMZvNjBkzht27dzN//nzMZjMpKSm89NJLxdb2FhYSEkKHDh2YNm0a7u7udO7c2bnu4Ycf5vfff2fFihXYbDYSExN58skn+eCDD8oUo6enJ0OHDuXTTz/l0KFDOBwOdu7cyaBBg5xdIOLi4vjzzz/ZtWsXVquV33///bqSbkEQRDIoCJWiTp06LF68mJiYGF544QVatWpF3759WbduHbNnz+axxx4DICgoiK+++oqjR4/SrVs3+vXrh8PhYP78+c4mstJ07NiR6dOn8+GHH9KmTRumTp3K1KlTiY2NBeDDDz+kUaNGDBs2jLZt2/Lpp58ybdo0l072kZGRuLu707NnT/r160fDhg2ZPHkykN+HsX///vzf//0fjz/+OP379+fBBx/k+eefp2XLltx9992kpqby0UcfucSVm5vL0qVLGTlyZLE1Wj169CAoKIgffviBpk2bMn36dL7//ntiY2OZOnUqzzzzTJF9BgwYwO7du4mMjHTpu1enTh0+//xztm7dyl133UXv3r3Jyspi3rx5JTZBlnYdr7zyChaLhY4dO/Lkk08yaNAgxo0bR3x8PE888USpf5fg4GAmT57M559/Trt27fjuu++YOnUqffv25c033+TXX38t9Rjt2rVzJluhoaGlbn897r//fqxWK926deOvv/4iJiaGGTNm8MMPPxAbG8vAgQPx8/Mr05yY999/P9u2baN///4u/T779evHK6+8wsyZM2ndujUPPfQQMTExJTZFF+fVV1+lR48ePP7447Ru3Zo333yT8ePHO/vBPvTQQ4wcOZLnn3+eDh068McffzBmzJjrf0EEoRqT1LLc4gqCcMeaNGkSCQkJLFiwoKpDEa5iMpmIi4vjgw8+oHv37lUdjiAIdyhRMygIgnALMplMvP3229SrV49u3bpVdTiCINzBRDIoCIJwi1m2bBnt27fn/PnzzJw5s1IHjgiCIIhmYkEQBEEQhGpM1AwKgiAIgiBUYyIZFARBEARBqMZEMigIgiAIglCNiWRQEARBEAShGhPJoCAIgiAIQjUmkkFBEARBEIRqTCSDgiAIgiAI1ZhIBgVBEARBEKoxkQwKgiAIgiBUYyIZFARBEARBqMZEMigIgiAIglCNiWRQEARBEAShGhPJoCAIgiAIQjUmkkFBEARBEIRqTCSDgiAIgiAI1ZhIBgVBEARBEKoxkQwKgiAIgiBUYyIZvMqcOXPo1atXVYdxUyxZsoSoqCgcDkex60ePHs3kyZNvclS3npEjRzJp0qRKP8+WLVu46667uHTpUqWf62p2u52RI0cya9asm35uASZNmsTIkSOva5+dO3cSFRVFYmJiidt07dqV2bNn32h4guBi5syZxMXFVXUYpXrppZcYPXp0VYdxW7jjk8HRo0cTERHBunXrrrl++/btADz77LOsWbOmzMdXFIWffvqJESNG0Lp1a2JiYujTpw8zZswgNzfXud2kSZOIjIwkKiqq2J8jR444t4uIiOB///tfsecrWL9o0aIyx1iSgQMHEh8fj0ajAWDXrl1s3br1ho97PYxGI//5z3+uuU1ERATNmzd3eb06duzI448/zv79+29SpK7x/Pzzz2Xe/tixY6xevfqa2yQlJTFhwgTeffddataseaMhXjetVstHH33Ed999x+bNm2/6+W9no0eP5qWXXip2XWXeSMTGxhIfH09YWNgNHae8ZVhMTAz33HMP06ZNw2q1umx3s8owoXzKc/Mh5Js7dy6KopS63datW3n66adp37490dHRdO/enUmTJnHq1CnnNosWLSIiIsL5mWrZsiVdunThxRdf5Pz580W2++c//1nsuQrW30hZc8cngwBBQUH88ssvRZYnJiZy+vTpch9XVVUmTJjAp59+yuOPP87WrVvZvn077733Hps3b2bIkCEuhWlMTAzx8fHF/kRGRpYar9Fo5I8//sDX17fcMV/Lt99+y7Zt2yrl2CXZvn17qckgwJQpU1xer+XLl1O/fn0effRRzp07dxMiLb9FixaVmgx++umnNGjQgLvvvvsmRVVUaGgoDz74IP/3f/9XpsJOuP3dSBm2a9cu/vWvf/Hrr7/y4Ycfuhy3qsowQahMR48eZdasWaWWj//73/946qmn6NixIytXrmTv3r189dVX2Gw2hgwZwoEDB1y237NnD/Hx8ezbt48FCxZw6dIlnn32WZdtfH19+euvv0hPTy9yvkWL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zSUrK4u3336bhx9+uMzlb1xcHEuXLuXYsWNYLBa++eYbl9HI/fv3x93dnXfffZeMjAxMJhP//ve/GTp0qEuCeC0Fn6cTJ06UuE9ISAivv/46X3zxBdOmTSMlJQVFUTh16hQvvPACO3bsuObn2mg08uWXX5KcnFxkYFaBoUOH8vHHHxMTE1Nh89LelNHEV/cRLNyH8GaMJi5s2LBhGI1Gl75/Jfnggw8IDAzk4YcfBqBt27Y88MADvPzyy84h8R9++CGvvvoqCxcupFOnTnTo0IG3336bPn368L///c+lMC5pAElUVJRzVFVx8V66dImBAweW+Rq7dOnC8ePHXQbHxMbGcuzYsWs2EY8aNYoNGzZw9913lzoKEfKT6zlz5rBmzRo6duzIAw88QFhYmMvo3ddff53U1FQ6dOjA6NGjeeCBB1yaxu655x6CgoK4++67r3sS2nfeeYfk5GRmzJgBwNNPP03NmjXp0aMHw4cPJyYmhsmTJ5OVleXsbFyad999l/r16zNgwAB69+5NjRo1inxpX68HHniAEydO0K1btyI1qQAdOnRAo9G4NLN169aNDz74gC+//JLY2Fgef/xxunTpwv/93/8B+YnFu+++y99//01sbCz//Oc/ix1hWlitWrWYOXMmX331Fe3ataNDhw78+OOPzJ0711kTmJaWxuHDh+nWrdsNXXNVkGQJTZQv2h7BaKJ8keSb1w2lrIYMGUJeXl6xN6OtW7d21toOGjTouieRnT17NrIsc/fddzNw4EA6dOjg0oG+JDdShg0ePBitVss333zj8rkurDxlWHUgafXUHPkvGry9m5oj/4WkvbVqsgs89NBDjBw5kueff54OHTrwxx9/MGbMGOd6jUbDZ599hsFgoG/fvnTs2JFff/2VL774wqXPco8ePThx4gRdunRh1KhR3H333Tz55JNAfl/Xzz//nK1bt3LXXXfRu3dvsrKymDdvXpm74EyYMIGuXbsyevRounbtyrlz51xGrnt5efHll19y8eJFevToQdeuXdm3bx//+c9/SnzvXu2uu+6iadOmDB06tMTvbIDhw4fzzTffcPr0ae677z5iYmJ48skn8fPzY9GiRUX6gxceQBIXF8dff/3Fl19+Wewof4ABAwaQlpZWod0uJLWSq+ZUVcVq2oDevbtLu3ZJywWhOnrjjTc4deoU8+fPr9I4Zs2axdq1a1m6dGmF94MU8qc/euihh1i/fn2pgzsE4U4xevRoQkJCnNO0CbeemzKa2ODRo0jCV9JyQaiOxo0bx/Hjx1m/vuo6kSclJTF//nwmTpwoEsFKcOnSJd58800efvhhkQgKgnBLESW+INwCQkJC+Oijj3j99devq9N0RbHb7UyYMIFRo0bRpUuXm37+O92bb77JvffeS7NmzRg3blxVhyMIguCi0puJBUEQBEEQhFuXqBkUBEEQBEGoxkQyKAiCIAiCUI2JZFAQBEEQBKEaE8mgIAiCIAhCNSaSQUEQBEEQhGpMJIOCIAiCIAjVmEgGBUEQBEEQqjGRDAqCINxEc+bMoVevXlUdxg1LSkqic+fObNy4sUrO/+GHHzJ69GgcDkeVnF+4NfXu3ZtPPvmkTNtu376diIgIEhISKjmqW98dP+n06NGj2bVrF1qttsi6hx56iIkTJ1ZBVNeWkJDA559/zpYtW0hPT8fLy4vmzZvz8MMP07lzZwDOnTvH3XffjU6nQ5IkJEnCw8ODpk2b8vTTT9O+fXuX7QIDA9m4cWOR1yExMZFevXpRq1Yt1q1bd9OvVRBud6NHj2bHjh3MnTuXuLi4Etf/97//dX4ur4eiKCxcuJBFixZx7NgxVFUlJCSEXr168dRTT+Hl5QXApEmTWLJkCTqdrtjj/Pzzz0RGRjJp0iQWL17M66+/zujRo4tsV7D+gw8+YPDgwcUeS1VVRo4cScuWLXn11Vev+5oqgt1uZ8SIEXTu3Jnnn3++SmK4XTkcDr766iuWL1/OuXPnsFgshISE0Lt3b8aPH4+bm1tVh1hm69evJzg4mObNm1/3vtu3b2fMmDGsXr2aevXqlbhdcnIy8+bNY8OGDSQnJ+Pm5kaTJk0YMWIE/fr1c24XERGBVqt1Ps7Tw8OD+vXrM3bsWO655x6X7XQ6HZs2bcLPz8/lXEajkc6dO5OXl8fRo0ev+5rKq1rUDPbr14/4+PgiP7diIrhnzx4GDhyIVqvlf//7H/v27WPJkiXExMTw1FNPsWDBApftv/jiC+Lj49m/fz+rVq2iYcOGPPHEE6SkpLhsJ0kSGzZsKHK+xYsXExAQUJmXJAiVSlVVdlyycPV9bUnLK0NQUBC//PJLkeWJiYmcPn263MdVVZUJEybw6aef8vjjj7N161a2b9/Oe++9x+bNmxkyZAi5ubnO7WNiYoot6+Lj44mMjCw1XqPRyB9//IGvr+814/r99985duwYzzzzTLmv7UZptVomTJjAV199xcWLF6ssjtvR9OnT+e6773j99dfZunUre/fu5V//+hcrV66ssuS+vGbPns2hQ4cq7fhnz55l0KBBXLhwgblz57J3715WrVpF3759ee2115gxY4bL9lOmTHF+5tavX09cXBzPPfccBw8edNnO19eXpUuXFjnfypUr8fDwqLTrKUm1SAavJS4ujpkzZ7os69q1K7Nnzwbyq5yjoqKcPy1atCAiIoLz58+zZMkSl3VRUVFERkby6quvsm3bNiIiIjhz5ozLsd9++22GDh1abCyKojB58mTat2/PO++8Q1hYGJIkERwczLPPPsvkyZNdCv6r1ahRg8GDB2OxWIo837Z79+5FCn9VVVmyZAk9evQo68slCLecnUlWZuzO4ttDuc7ET1VVvj2Uy4zdWexMslZ6DF27dmXjxo2kpaW5LF+8eDHdu3d3WTZ79my6du0K5DcZd+nShZycHOf6Rx55hKeffhqA5cuXs2rVKj755BN69uyJwWBAr9fTtm1bvv76a1q2bMmFCxeuO97Y2FgSEhKKfImuXLmSFi1a4Onpec39v/76awYMGOCSNB49epSxY8fSvn17YmJiePTRRzly5IhzfWll7ezZsxk8eDAzZsygdevWbN++nYyMDF588UXuuusuWrVqRZ8+ffjpp5+c+3fq1Im6devy3//+97pfg+rszz//pFevXsTGxqLX69FqtcTExDB79mwGDBgAQEZGBhMnTqRbt260bNmSQYMGuXQJMJlMvPTSS8TExNChQwemTZvmUttcXBPsli1biIiI4Ny5cwCYzWbee+894uLiiI6Opm/fvixZssS5/ezZsxk2bBi///47vXv3plWrVowcOdL5vdq1a1cOHjzIlClTnHFf/T776quv6N27NzExMXTr1o2ZM2de1w3i22+/TWBgILNnz6ZRo0ZIkoSvry+jRo1i2rRpKIpSYlcFDw8Phg8fjqIozmsu0L17dxYtWlRkn8WLF1fJd/JNSwYVh52zm37k4IK3ObvpRxSH/Wad+oasWrXKmeXv2bOHli1b0rNnT2rVqsXAgQNd7rw//fRT9Ho9I0aMoH379oSHh7skYHa7nZUrV5aYDB4+fJiTJ0/y2GOPFbt+1KhRPPHEEyXGmpKSwrff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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "y_acc_means = [\n",
    "    {\n",
    "        method: np.mean(vals)\n",
    "        for method, vals in results.items()\n",
    "    } for results in adversarial_total_y_accs\n",
    "]\n",
    "y_acc_stds = [\n",
    "    {\n",
    "        method: np.std(vals)\n",
    "        for method, vals in results.items()\n",
    "    } for results in adversarial_total_y_accs\n",
    "]\n",
    "method_names = list(y_acc_means[-1].keys())\n",
    "\n",
    "x_vals = concepts_to_intervene\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "color_map = {\n",
    "    'No Concepts': clrs[7],\n",
    "    'Sequential-CBM': clrs[1],\n",
    "    'Bool-CBM': clrs[2],\n",
    "    'Independent-CBM': clrs[3],\n",
    "    'Fuzzy-CBM': clrs[5],\n",
    "    'Hybrid-CBM': clrs[6],\n",
    "    \"MixCEM (ours)\": clrs[9],\n",
    "    \"MixCEM + RandInt (ours)\": clrs[10],\n",
    "}\n",
    "method_to_actual_name = {\n",
    "    'SequentialConceptBottleneckModel': 'Sequential-CBM',\n",
    "    'IndependentConceptBottleneckModel': 'Independent-CBM',\n",
    "    'ConceptBottleneckModelBool': 'Bool-CBM',\n",
    "    'ConceptBottleneckModelFuzzy': 'Fuzzy-CBM',\n",
    "    'ConceptBottleneckModelFuzzyExtraCapacity_Logit': 'Hybrid-CBM',\n",
    "    'MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat': \"MixCEM (ours)\",\n",
    "    'MixtureEmbModelSharedProb_Adaptive_NoProbConcat': \"MixCEM without RandInt (ours)\",\n",
    "}\n",
    "\n",
    "\n",
    "for method_name in method_names:\n",
    "    print(method_name)\n",
    "    if method_name not in method_to_actual_name:\n",
    "        continue\n",
    "    means = np.array([item[method_name] * 100 for item in y_acc_means])\n",
    "    stds = np.array([item[method_name] * 100 for item in y_acc_stds])\n",
    "    method_name = method_to_actual_name.get(method_name, method_name)\n",
    "    if method_name not in color_map:\n",
    "        color_map[method_name] = clrs[len(color_map)]\n",
    "    color = color_map[method_name]\n",
    "    ax.plot(\n",
    "        x_vals,\n",
    "        means,\n",
    "        c=color,\n",
    "        zorder=1,\n",
    "    )\n",
    "    ax.scatter(\n",
    "        x_vals,\n",
    "        means,\n",
    "        s=50,\n",
    "        label=method_name,\n",
    "        color=color,\n",
    "        zorder=2,\n",
    "        marker=\"x\" if \"(ours)\" in method_name else \".\",\n",
    "    )\n",
    "    ax.fill_between(\n",
    "        x_vals,\n",
    "        means - stds,\n",
    "        means + stds,\n",
    "        alpha=0.3,\n",
    "        facecolor=color,\n",
    "    )\n",
    "\n",
    "ax.set_xlabel(\"Concepts Adversarially Intervened\", fontsize=15)\n",
    "ax.set_ylabel(\"Task Accuracy (%)\", fontsize=15)\n",
    "\n",
    "ax.grid(False)\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "plt.title('CelebA Concept Intervention', fontsize=20)\n",
    "lgd = fig.legend(handles, labels, fontsize=15, loc='upper center', bbox_to_anchor=(0.5,-0.001), ncol=3)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Finally, let's see how the embedding size affects interventions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "if False and os.path.exists(\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'emb_ablation_total_y_accs.joblib')\n",
    "):\n",
    "    emb_seen = joblib.load(os.path.join(\"results/celeba_bin_intervention\", f'emb_ablation_seen.joblib'))\n",
    "    emb_ablation_total_y_accs = joblib.load(os.path.join(\"results/celeba_bin_intervention\", f'emb_ablation_total_y_accs.joblib'))\n",
    "else:\n",
    "    emb_ablation_total_y_accs = defaultdict(lambda: defaultdict(list))\n",
    "    emb_seen = set()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import models_cub\n",
    "reload(cub)\n",
    "reload(models_cub)\n",
    "max_emb_size = 32\n",
    "CELEBA_ABLATION_RESULTS_DIR = \"results/celeba_emb_size_ablation\"\n",
    "emb_ablation_configs = defaultdict(dict)\n",
    "for file in os.listdir(CELEBA_ABLATION_RESULTS_DIR):\n",
    "    if '_experiment_config.joblib' in file:\n",
    "        config = load(os.path.join(CELEBA_ABLATION_RESULTS_DIR, file))\n",
    "        fold = int(file[file.find(\"_fold_\") + len(\"_fold_\"):file.find(\"_experiment_config\")]) - 1\n",
    "        model_name = f\"{config['architecture']}{config.get('extra_name', '')}\"\n",
    "        emb_ablation_configs[str(fold)][model_name] = config\n",
    "print(\"CUB Emb Ablation Model names:\")\n",
    "for model_name, _ in emb_ablation_configs['0'].items(): \n",
    "    print(\"\\t\", model_name)\n",
    "\n",
    "\n",
    "WHITELIST = [\n",
    "    \"ConceptBottleneckModelFuzzy\",\n",
    "    \"ConceptBottleneckModelFuzzyExtraCapacity_Logit\",\n",
    "    'MixtureEmbModelSharedProb_AdaptiveDropout_NoProbConcat',\n",
    "    'MixtureEmbModelSharedProb_Adaptive_NoProbConcat',\n",
    "]\n",
    "\n",
    "\n",
    "splits = sorted(emb_ablation_configs.keys())\n",
    "\n",
    "for split in splits:\n",
    "    runs = emb_ablation_configs[split]\n",
    "    model_names = sorted(runs.keys())\n",
    "    for num_concepts_intervened in [\n",
    "        0,\n",
    "        int(N_CONCEPTS * 0.25),\n",
    "        int(N_CONCEPTS * 0.5),\n",
    "        int(N_CONCEPTS * 0.75),\n",
    "        N_CONCEPTS,\n",
    "    ]:\n",
    "        intervention_idxs = sorted(np.random.choice(\n",
    "            list(range(N_CONCEPTS)),\n",
    "            size=num_concepts_intervened,\n",
    "            replace=False,\n",
    "        ))\n",
    "        for model_name in model_names: \n",
    "            config = runs[model_name]\n",
    "            config[\"shared_prob_gen\"] = config.get(\"shared_prob_gen\", False)\n",
    "            config[\"per_concept_weight\"] = config.get(\"per_concept_weight\", False)\n",
    "            if config[\"emb_size\"] > max_emb_size:\n",
    "                print(\"Skipping model\", model_name, \"as it has embedding size\", config[\"emb_size\"])\n",
    "                continue\n",
    "            if \"NoConceptSupervision\" in model_name:\n",
    "                continue\n",
    "            key = (model_name, split, num_concepts_intervened, config[\"emb_size\"])\n",
    "            if key in emb_seen:\n",
    "                print(\"Skipping this as we have already seen it for\", model_name)\n",
    "                continue\n",
    "            print(\"Running\", model_name, \"with\", num_concepts_intervened, \"intervened concepts for fold\", int(fold))\n",
    "            model = load_trained_model(\n",
    "                config=config,\n",
    "                n_tasks=N_TASKS,\n",
    "                n_concepts=N_CONCEPTS,\n",
    "                result_dir=CELEBA_ABLATION_RESULTS_DIR,\n",
    "                split=int(split),\n",
    "                imbalance=imbalance,\n",
    "                intervention_idxs=intervention_idxs,\n",
    "                train_dl=train_dl,\n",
    "            )\n",
    "            trainer = pl.Trainer(\n",
    "                gpus=GPU,\n",
    "            )\n",
    "            [test_results] = trainer.test(model, test_dl, verbose=False,)\n",
    "            print(\n",
    "                \"\\tFor model:\", model_name, f\"(fold {int(split) + 1} trained with emb {config['emb_size']})\",\n",
    "                \"intervening with\", num_concepts_intervened, \"gives:\"\n",
    "            )\n",
    "            print(\"\\t\\tTest task accuracy:\", test_results['test_y_accuracy'])\n",
    "            emb_ablation_total_y_accs[model_name][config['emb_size']].append(\n",
    "                test_results['test_y_accuracy']\n",
    "            )\n",
    "            emb_seen.add(key)\n",
    "            print(\"\\t\\tOriginal concept accuracy:\", test_results['test_c_accuracy'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import joblib\n",
    "joblib.dump(\n",
    "    emb_ablation_total_y_accs,\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'emb_ablation_total_y_accs.joblib'),\n",
    ")\n",
    "joblib.dump(\n",
    "    emb_seen,\n",
    "    os.path.join(\"results/celeba_bin_intervention\", f'emb_ablation_seen.joblib'),\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": 5
}
