{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import wandb\n",
    "import yaml\n",
    "import torch\n",
    "from torch.nn.functional import one_hot\n",
    "from torch.utils.data import TensorDataset\n",
    "from pytorch_lightning.utilities.seed import seed_everything\n",
    "from pytorch_lightning.loggers import WandbLogger\n",
    "from ccbm.utils import randomize_class, load_data, RandomSamplerClassBatch, save_set_c_and_cf, FEATURE_NAMES, DATASET, CLASS_TO_VISUALISE, print_concept_importance\n",
    "from ccbm.models import (StandardE2E, StandardCBM, Oracle, \n",
    "                         CounterfactualCBM_V3, CounterfactualCBM_V3_1,\n",
    "                         VAE_CF, CCHVAE, ConceptVCNet)\n",
    "import math\n",
    "import numpy as np\n",
    "import pytorch_lightning as pl\n",
    "from sklearn.metrics import roc_auc_score\n",
    "from ccbm.metrics import (variability, \n",
    "                          difference_over_union, \n",
    "                          intersection_over_union, \n",
    "                          cf_in_distribution, distance_train)\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression\n",
    "\n",
    "\n",
    "from train import train_model, train_oracle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Failed to detect the name of this notebook, you can set it manually with the WANDB_NOTEBOOK_NAME environment variable to enable code saving.\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33mgdominici\u001b[0m (\u001b[33macbm\u001b[0m). Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: \u001b[33mWARNING\u001b[0m Path ./wandb/wandb/ wasn't writable, using system temp directory.\n",
      "wandb: WARNING Path ./wandb/wandb/ wasn't writable, using system temp directory\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "wandb version 0.16.2 is available!  To upgrade, please run:\n",
       " $ pip install wandb --upgrade"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Tracking run with wandb version 0.16.0"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Run data is saved locally in <code>/var/folders/zy/8kppgl856s54352ptnhsp3zh0000gn/T/wandb/run-20240118_161008-boglad0j</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Syncing run <strong><a href='https://wandb.ai/acbm/uncategorized/runs/boglad0j' target=\"_blank\">exalted-leaf-34</a></strong> to <a href='https://wandb.ai/acbm/uncategorized' target=\"_blank\">Weights & Biases</a> (<a href='https://wandb.me/run' target=\"_blank\">docs</a>)<br/>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View project at <a href='https://wandb.ai/acbm/uncategorized' target=\"_blank\">https://wandb.ai/acbm/uncategorized</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run at <a href='https://wandb.ai/acbm/uncategorized/runs/boglad0j' target=\"_blank\">https://wandb.ai/acbm/uncategorized/runs/boglad0j</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "There is a wandb run already in progress and newly created instances of `WandbLogger` will reuse this run. If this is not desired, call `wandb.finish()` before instantiating `WandbLogger`.\n"
     ]
    }
   ],
   "source": [
    "# Initialize wandb\n",
    "wandb.login()\n",
    "\n",
    "run = wandb.init(dir='./wandb')\n",
    "wandb_logger = WandbLogger()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`pytorch_lightning.utilities.seed.seed_everything` has been deprecated in v1.8.0 and will be removed in v1.10.0. Please use `lightning_lite.utilities.seed.seed_everything` instead.\n",
      "Global seed set to 0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Get config variables\n",
    "seed = 0\n",
    "batch_size = 1024\n",
    "dataset_name = 'dsprites'\n",
    "model = 'CFCBM'\n",
    "emb_size = 128\n",
    "device = accelerator = 'cpu'\n",
    "learning_rate = 0.005\n",
    "epochs = 75\n",
    "fold = 0\n",
    "\n",
    "# Set seed\n",
    "seed_everything(seed, workers=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# dSprites"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Saving image embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !python3 experiments/dsprites/save_embeddings.py"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Creating directories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# creates directory for results\n",
    "results_root_dir = f\"./results/\"\n",
    "os.makedirs(results_root_dir, exist_ok=True)\n",
    "results_dir = f\"./results/{dataset_name}/\"\n",
    "os.makedirs(results_dir, exist_ok=True)\n",
    "figures_dir = f\"./results/{dataset_name}/figures/\"\n",
    "os.makedirs(figures_dir, exist_ok=True)\n",
    "log_dir = f\"./results/{dataset_name}/logs/\"\n",
    "os.makedirs(log_dir, exist_ok=True) "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Loading data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load train data\n",
    "X, c, y = load_data(dataset_name)\n",
    "if len(y.shape) == 1:\n",
    "    y = y.unsqueeze(1)\n",
    "    # Unique [concepts, labels]\n",
    "    c_cf_set = torch.unique(torch.cat((c, y), dim=-1), dim=0)\n",
    "    concept_labels = c_cf_set[:, -1]\n",
    "    c_cf_set = c_cf_set[:, :-1]\n",
    "else:\n",
    "    c_cf_set = torch.unique(torch.cat((c, torch.argmax(y, dim=-1).unsqueeze(-1)), dim=-1), dim=0)\n",
    "    concept_labels = c_cf_set[:, -1]\n",
    "    c_cf_set = c_cf_set[:, :-1]\n",
    "    concept_labels = one_hot(concept_labels.long(), num_classes=y.shape[1]).float()\n",
    "\n",
    "# Load test data\n",
    "X_test, c_test, y_test = load_data(dataset_name, split='test')\n",
    "if len(y_test.shape) == 1:\n",
    "    y_test = y_test.unsqueeze(1)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Selecting model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define models\n",
    "models = {\n",
    "            'Oracle': Oracle(),\n",
    "            'DeepNN': StandardE2E(X.shape[1], y.shape[1], emb_size, learning_rate),\n",
    "            'StandardCBM': StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=False),\n",
    "            'CFCBM': CounterfactualCBM_V3(X.shape[1], c.shape[1], y.shape[1], emb_size, c_cf_set, concept_labels, learning_rate=learning_rate, resample=0, bernulli=False, deep=False, reconstruction=False),\n",
    "            'VAECF': (StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True), \n",
    "                      VAE_CF(c.shape[1], y.shape[1], emb_size, None, learning_rate)),\n",
    "            'CCHVAE': (StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "                       CCHVAE(c.shape[1], y.shape[1], emb_size, None, learning_rate)),\n",
    "            'VCNET': ConceptVCNet(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "            'BayCon': StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "        }\n",
    "net = models[model]"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Setting up dataloader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create DataLoader\n",
    "train_data = TensorDataset(X, c, y)\n",
    "train_dl = torch.utils.data.DataLoader(train_data, batch_sampler=torch.utils.data.BatchSampler(RandomSamplerClassBatch(y, batch_size=batch_size, replacement=False), batch_size=batch_size, drop_last=True), pin_memory=True)\n",
    "test_data = TensorDataset(X_test, c_test, y_test)\n",
    "test_dl = torch.utils.data.DataLoader(test_data, batch_sampler=torch.utils.data.BatchSampler(RandomSamplerClassBatch(y_test, batch_size=batch_size, replacement=False), batch_size=batch_size,  drop_last=True), pin_memory=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Traing the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: True (mps), used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "MPS available but not used. Set `accelerator` and `devices` using `Trainer(accelerator='mps', devices=1)`.\n",
      "`Trainer(limit_train_batches=1.0)` was configured so 100% of the batches per epoch will be used..\n",
      "`Trainer(limit_val_batches=1.0)` was configured so 100% of the batches will be used..\n",
      "Global seed set to 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running CounterfactualCBM_V3(\n",
      "  (cross_entropy): CrossEntropyLoss()\n",
      "  (bce): BCELoss()\n",
      "  (bce_log): BCEWithLogitsLoss()\n",
      "  (model): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "    (4): Linear(in_features=128, out_features=2, bias=True)\n",
      "  )\n",
      "  (encoder): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "  )\n",
      "  (relation_classifiers): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=7, bias=True)\n",
      "  )\n",
      "  (reasoner): Sequential(\n",
      "    (0): Linear(in_features=7, out_features=2, bias=True)\n",
      "  )\n",
      "  (classification_loss): BCELoss()\n",
      "  (concept_mean_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_mean_z3_predictor): Sequential(\n",
      "    (0): Linear(in_features=137, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_z3_predictor): Sequential(\n",
      "    (0): Linear(in_features=137, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_mean_qz3_predictor): Sequential(\n",
      "    (0): Linear(in_features=139, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_qz3_predictor): Sequential(\n",
      "    (0): Linear(in_features=139, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=7, bias=True)\n",
      "  )\n",
      "), epochs=75, learning_rate=0.005\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "   | Name                       | Type              | Params\n",
      "------------------------------------------------------------------\n",
      "0  | cross_entropy              | CrossEntropyLoss  | 0     \n",
      "1  | bce                        | BCELoss           | 0     \n",
      "2  | bce_log                    | BCEWithLogitsLoss | 0     \n",
      "3  | model                      | Sequential        | 82.4 K\n",
      "4  | encoder                    | Sequential        | 82.2 K\n",
      "5  | relation_classifiers       | Sequential        | 903   \n",
      "6  | reasoner                   | Sequential        | 16    \n",
      "7  | concept_mean_predictor     | Sequential        | 33.0 K\n",
      "8  | concept_var_predictor      | Sequential        | 33.0 K\n",
      "9  | concept_mean_z3_predictor  | Sequential        | 34.2 K\n",
      "10 | concept_var_z3_predictor   | Sequential        | 34.2 K\n",
      "11 | concept_mean_qz3_predictor | Sequential        | 34.4 K\n",
      "12 | concept_var_qz3_predictor  | Sequential        | 34.4 K\n",
      "13 | concept_predictor          | Sequential        | 17.4 K\n",
      "------------------------------------------------------------------\n",
      "386 K     Trainable params\n",
      "0         Non-trainable params\n",
      "386 K     Total params\n",
      "1.545     Total estimated model params size (MB)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f4311930fe04b3d8b748997abe159f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Sanity Checking: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The dataloader, val_dataloader 0, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The dataloader, train_dataloader, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The number of training batches (7) is smaller than the logging interval Trainer(log_every_n_steps=50). Set a lower value for log_every_n_steps if you want to see logs for the training epoch.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d2db2556524c4c6baa62dfea6b142c89",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Training: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f744bbae76bf445398e6d118512ac64b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7a64583bf0a94af3a4d82b9e58be8a31",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "64751b2a8caa4ef19508555b862bb949",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3b9de55034d94d77a1b39aa5d320507a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "015c5dd16e4045b0984c4acd139714e0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37ed13c5f68d414593cf4e01ad84e389",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6283c8c81f9a466884eebb2a9587d4f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a570b88924c24ef88e51e2e1f1a27ee4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "04476ff194d84b01a6dab7dc8157603f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0f638a706e5a4a55982f9e9c380a9d72",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4601eae3bb8b444db7a6c7854ba678df",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1dfc4aa75f5347a99e6de4b72ff88e0d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fb543c4031654c5f90a6aadc96dc52dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2048d5b2f1234f2696779f26da2fc9cd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f226ad1d452e4575abe7ea6f3963592f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ba2ea0fb5584391a95e141e1b57270a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "17714b696cea4142a59a836491f02cdd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5d76940978544f6397d7698ecc3cdcba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "17eaa7852d1644c2801a12424861bd26",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "28d5bc0ac6ef4056a0eac87f7ede7f60",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2ef77e24994341e985048bb7dd0509dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f9c1c4d43f24267bb8481b34093e128",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f432427c3fb458791bd850f9219da06",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7eb1b5efabf043e1b0615a547b358356",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "022c1d5f5bcd4562ab5fbaa080faef11",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "931ec4a729c9499a889dd1d8c4390166",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8b2fddb3ad304bf68a3796c61bda73a0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ad59a8ef6f64f57a5e73ea2eae9d014",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eeec7a30501542b0bb206ead29308101",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "caa8ced8a6b049d588ffdb8f4a52c0b8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a8af35c287334d1ebf49c05249f76d79",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4495ee4bd65547e895d3948768fbe42d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "215b74622aaf43099b76ea5e90e42fe4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6d65f0f95c804dcc819d6e6aaf4a4e2b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "214744c5ecb84372a74e031580cc1639",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8d64e008d3fe4904958a5a624c0f92c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "307fe0e1bac7489b9a70df67e4bf60e1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0ea009cf91de46ffb834dcf2567e6f5b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8ee76bb072a74fbabdaa28b6d4f345fb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0cd2ec8b9bd24241ba0a09de11eb6794",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9dd2dca221994ba9839ebc56425b070c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b61df963fe5a40398aded6f018c04231",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f97eca4017ee42b1a9f45b87efa07e0c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2160f8f458444c2ebd361c288c013af6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4239fc6f84234523916a62d627116441",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b6abd718665848da88292e60b14f275b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1aeda59569c74f65bb7190793c1ac6c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e3b7cfe248a34d39951adcfc2befda60",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6c99dc4a030743648b7fed286a784edd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "317ea89af7fc448c987cfd9b8436e77a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b840f9e6d65f45ecb674e026b86dc0de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ce5a414e58b425d813be1684b90d63c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6c917544ed614ec3a46c2d51454dedad",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "48f83faca6894c8185bea013620d3b5b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ff997bc486514c2ba8d88fe0aafeb635",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "86d63e31ce864132b8e19906fa9c4de6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "71bfa78afb6f4169b3f065e0352cb085",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8c0721a3018349b6abc50c0ad20787ab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "43ade954fae245179e4b279ec8fca770",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0ce0bb8cbdde416090e043317d84ee4b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ace70ee2570f491ca15c59570fce4178",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a0e2f9ce1f94dddb2d0908898ec3640",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f98177977864ec5b817904f9582edf0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4131205b351848b1bf6f8542c907298c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1bb0c46d71e04aaa92f7b36b220ce250",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d18b91bf028f4d21b98dcdec3c5a0a5a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "49bed86f66654299bd76420044d8b326",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ebece709ef024e27a27295d0f908544f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "344144c689f34438b57311801d98fb98",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9dd2d58837144ae1be11777c4b562e32",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "90e8ac96da8d4a6a819d5f0636ca3e39",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f592390fdb749c9b75f47fa87616159",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a84a73ee91b4a5ba5e42bb849776e25",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b2e2da4496394206bee08cd9e8892400",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6734b7d097f54aeaaba69d3b30efa445",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=75` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best train acc: 0.9738578796386719, Epoch: 56\n"
     ]
    }
   ],
   "source": [
    "net = train_model(net, epochs, learning_rate, seed, train_dl, test_dl, results_dir, accelerator, wandb_logger)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Testing the model and saving the outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Testing the model \n",
    "c_preds_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "c_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "y_preds_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_cf_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_cf_target_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "c_cf_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "z2_total = torch.empty(0, net.emb_size)\n",
    "z3_total = torch.empty(0, net.emb_size)\n",
    "\n",
    "for X_test, c_test, y_test in test_dl:\n",
    "    y_prime = randomize_class(y_test, include=False)\n",
    "    if y_test.shape[-1] == 1:\n",
    "        y_prime = None\n",
    "    (c_preds, y_preds, explanations,\n",
    "    c_cf, y_cf, y_cf_target, explanation_cf, \n",
    "    p_z2, qz2_x, pz3_z2_c_y, qz3_z2_c_y_y_prime,\n",
    "    pcprime_z3, py_c, py_c_cf, pc_z2, c_cf_true, weights, z2, z3, c_pred_d) = net.forward(X_test, test=True, y_prime=y_prime, explain=True, include=False, inference=True)\n",
    "\n",
    "    c_preds_total = torch.cat((c_preds_total, c_preds), dim=0)\n",
    "    c_total = torch.cat((c_total, c_test), dim=0)\n",
    "    y_preds_total = torch.cat((y_preds_total, y_preds), dim=0)\n",
    "    y_total = torch.cat((y_total, y_test), dim=0)\n",
    "    y_cf_total = torch.cat((y_cf_total, y_cf), dim=0)\n",
    "    y_cf_target_total = torch.cat((y_cf_target_total, y_cf_target), dim=0)\n",
    "    c_cf_total = torch.cat((c_cf_total, c_cf), dim=0)\n",
    "    z2_total = torch.cat((z2_total, z2), dim=0)\n",
    "    z3_total = torch.cat((z3_total, z3), dim=0)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ROC AUC Concept Accuracy (%):  97.85359784937881\n",
      "Entire Concept Accuracy (%):  79.00390625\n",
      "ROC AUC Task Accuracy (%):  99.35452363881126\n",
      "Validity (%):  100.0\n",
      "Variability:  0.5714285714285714\n",
      "IOU (%):  56.00000000000001\n",
      "Proximity (%):  0.9835379464285714\n",
      "Delta Sparsity (%):  4.338727678571429\n",
      "CF Time:  0.0291440486907959\n"
     ]
    }
   ],
   "source": [
    "# Compute metrics\n",
    "concept_accuracy = roc_auc_score(c_total.cpu(), c_preds_total.detach().cpu())\n",
    "print('ROC AUC Concept Accuracy (%): ', concept_accuracy*100)\n",
    "concept_acc = (c_preds_total > 0.5).float().eq(c_total).float().all(dim=-1).float().mean().item()\n",
    "print('Entire Concept Accuracy (%): ', concept_acc*100)\n",
    "task_accuracy = roc_auc_score(y_total.cpu(), y_preds_total.detach().cpu())\n",
    "print('ROC AUC Task Accuracy (%): ', task_accuracy*100)\n",
    "task_cf_accuracy = roc_auc_score(y_cf_target_total.squeeze().cpu(), y_cf_total.detach().cpu())\n",
    "print('Validity (%): ', task_cf_accuracy*100)\n",
    "cf_variability = variability(c_cf_total.cpu(), c_preds_total.cpu())\n",
    "print('Variability: ', cf_variability)\n",
    "cf_iou = intersection_over_union(c_cf_total.cpu(), c_total.cpu())\n",
    "print('IOU (%): ', cf_iou*100)\n",
    "mean_distance_train = distance_train(c_cf_total.cpu(), c_cf_set.cpu(), y_cf_total.detach().cpu(), concept_labels.cpu()).item() / c_cf_total.shape[-1]\n",
    "print('Proximity (%): ', mean_distance_train*100)\n",
    "\n",
    "pdist = torch.nn.PairwiseDistance(p=2)\n",
    "hamming_distance = torch.norm((c_preds_total>0.5).float().cpu() - (c_cf_total>0.5).float().cpu(), p=0, dim=-1).mean().item() \n",
    "oracle = Oracle()\n",
    "oracle_results, oracle = train_oracle(oracle, test_dl, c_cf_set, concept_labels, wandb_logger)\n",
    "oracle_sparsity = oracle_results['hamming_distance']\n",
    "delta_sparsity = abs(hamming_distance - oracle_sparsity) / c_cf_total.shape[-1]\n",
    "print('Delta Sparsity (%): ', delta_sparsity*100)\n",
    "\n",
    "cf_time_total, cf_found = net.counterfactual_times(test_dl, accelerator, rerun=False)\n",
    "print('CF Time: ', cf_time_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_set_c_and_cf(c_preds_total, y_preds_total, y_cf_total, c_cf_total, model, fold, log_dir)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing feature importance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsUAAAHSCAYAAAAE8LamAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAACrXUlEQVR4nOzdd3xTVf8H8M9N0rTpbimjUEoLpWxkVIYyZcqSURRRKMgGmYIPTuARHxF8lKEgQ4YgPxGoCPIAsvcQUMCCMkopo6WU7p1xf3+Epr1NUpoO0jSf9+sV5Z577jnnJm3zzcn3niuIoiiCiIiIiMiOyaw9ACIiIiIia2NQTERERER2j0ExEREREdk9BsVEREREZPcYFBMRERGR3WNQTERERER2j0ExEREREdk9BsVEREREZPcYFBMRERGR3VNYewBEZJ86deqEo0ePGrYPHz6MTp06WdRGRkYGLl68iFu3biEpKQmpqalwcnKCi4sLqlWrhoCAANStWxeurq6lPPrya8SIEdiwYYNhe926dRgxYoT1BkREZCMYFBORTcnOzsbWrVuxatUqnDp1ClqtttD6MpkM9erVQ6tWrdC9e3d0794dPj4+z2i0RERkKxgUE5HNOH36NN566y38/fffRT5Gp9Ph2rVruHbtGjZs2ACZTIaMjAw4OjqW4UhtR1RUFNavX2/YDggI4MwyEdklBsVEZBO2b9+O1157zezMsFwuh5ubG3Q6HVJSUsy2o9PpIIpiWQ3T5kRFRWHevHmG7Y4dOzIoJiK7xAvtiKjcO3XqFF5//XWjgLhjx45Yt24dbty4AbVajcTERCQnJ0OtVuPGjRv44YcfMGHCBFSrVs1KIyciIlvBoJiIyjWtVouJEydCrVYbylQqFX766SccOXIEI0aMQFBQEARBMOxXKBQICgrC0KFDsXz5cty/fx+HDx9GaGgo5HK5NU7jmVm/fj1EUTQ8OOtLRFQ0TJ8gonLt4MGDuHTpkqRs3bp1GDx4cJHbkMlk6NSpEzp16oS7d+9CqVSW9jCJiMjGMSgmonJt586dku1GjRrhtddeK3Z7NWvWLOmQiIioAmL6BBGVaxEREZLtjh07WmkkRERUkXGmmIhKTWZmJo4ePYro6GjEx8fD2dkZtWvXxgsvvFDstYEfPnwo2fb09CyFkZZcZGQkzp07h3v37kGj0aBatWoICgrCCy+8AJms9Ocb0tPTcebMGVy/fh2JiYmQyWSoVq2aTeQMX7t2DREREXj06BESExPh6emJKlWqoFWrVvD39y9x+2lpabh8+TL+/vtvJCUlISMjA05OTnB1dUXNmjVRp04dBAcHl8nrQkQViEhEVEIxMTHiiBEjRBcXFxGA0UMul4v9+vUTr1y5YjimY8eOkjqHDx822XbDhg0l9cLCwsr8fObMmSPpc86cOYZ9u3btEkNCQkyeJwCxatWq4vvvvy9mZGQUub/Dhw9L2ujYsaNh3/Xr18WhQ4eKjo6OJvsrKCwsTLJ/3bp1T+3P0kdRxMbGitOnTxf9/f0Lbathw4biypUrRY1GU+TnK9exY8fEV155RVQqlU8ds5ubm9ijRw9x5cqVFr02RGQ/+LGZiEpk586daNCgAdavX4/09HSTdbRaLXbu3IkWLVpg3bp1FrVftWpVyfaePXuQkZFR7PEWl1arxYQJE9C3b1+cP3/ebL2HDx/iP//5Dxo3bozLly+XqM+1a9eiSZMm2Lx5M7Kzs0vU1rO0aNEi1KlTB1999RWio6MLrXv16lWMGzcOzz33HCIjI4vUfu5r0aFDB/zyyy/Iycl56jGpqanYt28fxo0bh3/++adI/RCRfWFQTETFtnPnToSGhiIpKclon1wuh5eXl2SpNLVajVGjRmHbtm1F7qN169aS7bi4OLz11lvIysoq9riLY+rUqfj2228lZQqFwmw6R2RkJLp06YIrV64Uq78NGzZg1KhRRsGwp6cnHBwcitVmWVOr1Rg5ciTeffddkx+QHBwc4O3tDYXCOHMvIiICbdu2LdIHiYkTJxq9FrmUSiUqVaoEd3d3pksQkUWYU0xExRIZGYnXX39dsn6wTCbDmDFjMHr0aDRv3hxyuRxqtRonTpzAsmXL8PPPP0MURYwePbrIN9QYNGgQFixYICnbsmULzp8/j2nTpmHw4MFGs8mlbe/evTh79iwAfdA1depUhIWFoUGDBpDJZMjKysLBgwfx3//+F4cPHzYcFx8fjwEDBuDy5ctwdnYucn/R0dGYOHEiAP1zGhYWhhEjRqBNmzZQKpUQRRHR0dH48ccfi3U+wcHBWLFiBQDg+vXr+Oqrrwz76tatixkzZhSr3WnTpkluGQ0AzZs3x6RJk9ClSxcEBAQAAERRxLVr17BlyxYsXrzYcAfCuLg4DBo0CBcvXoSbm5vJPk6fPo1Vq1YZ9TFt2jR07twZfn5+hg9ioijizp07uHLlCg4cOICdO3ciKiqqWOdGRHbAutkbRGSrXnrpJUnOpkqlEvfv31/oMWvWrBEFQTCZ82kup1gURfGVV14xmysqk8nE5557Thw3bpz43XffiZcvXy5Wfmp+BXOKcx+VKlUS//jjD7PH6XQ6ce7cuUbHTZs2rdD+zOX4urm5Ffq8mFKUnOLC+s6fz2yJn376SdKOIAjiokWLRJ1OV+hxt27dEuvXry85dtKkSWbrjx8/XlJ3wIABolqtLtIYdTqduHv3bvHBgwcWnRsR2QcGxURksZMnTxoFcD/88EORjp03b57FQfHjx4/F4ODgIl8I5urqKvbo0UP87LPPxMjISIvPz1RQLAiCePz48SIdP3LkSMmxjo6O4qNHj8zWNxcU79q1y+KxWyMoVqvVYq1atSTtLF68uMjH37p1S/Tw8JB8wIqLizNZt1WrVpJ+/v77b4vHS0RkChOuiMhiK1eulGx37NgRQ4cOLdKxs2fPRu3atS3qz9vbG6dPn0bv3r2LVD8tLQ379u3De++9hzp16qBr1644c+aMRX0WNHz4cLRr165IdRctWgQPDw/DdnZ2NtauXWtRf3369EGfPn0sOsZafvrpJ9y5c8ew3bZtW0yZMqXIx9euXRvTpk0zbGdmZmLjxo0m6yYmJkq2AwMDLRssEZEZDIqJyCKiKOLXX3+VlE2aNKnIxyuVSowZM8bifr29vfHrr79i79696Nixo+QCvsKIooiDBw+ibdu2GD9+vCQH2hKWnGOlSpUwZMgQSVnBO/M9zdixYy2qb03/93//J9mePHlykV+fXAWfr6NHj5qsV/DCxsJWAiEisgSDYiKyyI0bN5CQkGDYlsvlRZ7BzdW/f/9i99+jRw8cOXIEkZGR+PLLL9G3b194eXkV6diVK1fi5ZdfhkajsahPX19fPP/88xYdU/AcL168WOSAXBAEm7lzn06nw4kTJyRlPXv2tLid+vXrQ6VSGbZPnz5tsl6rVq0k22FhYbh06ZLF/RERFcTVJ4jIIgUDkPr161u0sgKgX/3AxcXF7LrGRREQEIDp06dj+vTpAPSrYfzxxx84e/YsDh48iIsXL5o87uDBg3jvvfewaNGiIvfVokULi8dX8JjMzExcv34djRo1euqxtWrVgru7u8V9WkPuXeRyubi4YMuWLcVqS6lUIjMzE4B+5Q6tVgu5XC6pM3bsWCxfvhyiKAIAbt68iebNm6Nz584YNGgQunTpgnr16hXvZIjIrjEoJiKLPH78WLJdq1Yti9uQyWTw9/fHtWvXSmtYqF27NmrXro1BgwYB0AdLX375JVavXm00M7xkyRJMnjy5yLcYLs45VqlSBSqVyhDkAcbPnTmVKlWyuD9rKXgb7vT0dEyYMKHE7YqiiISEBFSuXFlS3rRpU3z66ad4//33JXUPHTqEQ4cOAQAqV66Mtm3bon379ujcuTNatmxZ4vEQUcXH9AkiskjBG3UUd0Yz/4VoZSEoKAjLly/H0aNHjfpSq9UWXfhWWudY8CIxc1xdXYvVnzXkT6UpbebuXPjee+9h06ZNZte6fvToEXbu3IlZs2YhJCQEtWvXxieffILk5OQyGysR2T4GxURUob3wwgtGq2UAMMwqUskU5RbLxZWbImHKG2+8gcjISKxfvx49e/aEi4uL2bq3b9/Gxx9/jDp16hhdJEpElItBMRFZpODV/7l3I7PUs5y1e/XVV1GjRg1J2c2bN4t8fGmdY1EvCLQl3t7eku0qVapA1K+BX+JH7h3wzFGpVAgLC8OePXuQmJiIM2fOYNGiRXjllVeMxgXo01f69++PvXv3luZTQEQVBINiIrJIwXzX/OvTFpVOp8Pdu3dLa0hPJQiCUV5pUfN7geKdY1xcnCSfGLCtXOGiKpjzm5CQUOgMb1lxcHBA69atMXPmTOzYsQNxcXE4evQohg4dKlkeTqvVYsKECcVemo+IKi4GxURkkeeee06y/ffff5vN/TTn+vXrSEtLK81hPVXBFTIsWTHD3EoWlhyjUqkQHBxscTvlXYMGDeDo6GjY1mg0+Ouvv6w4Ij25XI4OHTrghx9+MFoNIyoqCqdOnbLSyIiovGJQTEQWqVu3ruSraa1Wi927d1vUxo4dO0p5VE937949yXbVqlWLfGxMTAx+//13i/oreI4tWrSAg4ODRW08CwqFdBEirVZr0fEqlQovvviipMzSn4eyNnjwYLRu3VpSdvnyZSuNhojKKwbFRGQRQRCMbtaxfPnyIh+fk5ODNWvWlPawChUfH4+zZ89Kypo3b25RG5ac4+PHj/Hjjz9Kyvr27WtRf8+Km5ubZLs4ud6hoaGS7SVLllj87UFZK3g76JKskU1EFRODYiKy2Lhx4yTbR44cwebNm4t07IIFC3Dr1q0i9zVmzBhs2rQJOp3OojHmN2vWLKMcUkuD1A0bNuDkyZNF7i9/cKlUKvHWW29Z1N+zUnBZs1u3blm8osRbb70FPz8/w3ZsbCxGjRpVonGZyksWRbHYPwcF18Q2t5wbEdkvBsVEZLEXX3wRnTp1kpSNHj0aBw8eLPS4tWvXYu7cuRb1dePGDQwbNgwNGzbEsmXLEB8fX+RjMzIyMGnSJKxfv15SXrt2bQwcONCicYiiiP79+z/1lsL//ve/sW7dOknZ+PHjjS5IKy+qVq0KX19fw3ZGRobR+J/G0dERn3/+uaTsxx9/xMCBAy1ax1ij0eDnn39Gx44dTeZxJycnIzg4GMuWLbNoRZAVK1ZIXjdBEIx+fomIIBIRFcONGzdElUolAjA8ZDKZOG7cOPHChQuiVqsVRVEUc3JyxMOHD4sDBw401PP09BTr1asnOfbw4cMm++nYsaOknoODg9inTx/xiy++EE+dOiUmJiZK6qelpYlnzpwR58yZI/r5+UmOzR3j7t27Cz23OXPmSI5p1aqV4d9KpVJ89913xYiICFGn04miKIqZmZni7t27xc6dOxv1FxgYKKalpRXa3+HDhyXHdOzYsUivgSlhYWGSttatW/fUY8aNGyc5RhAEsUePHuKcOXPEZcuWiStWrJA8zJkxY4bR+bu7u4vTp08XDx48KKakpEjqZ2RkiBcvXhTXr18vvvnmm6KXl5fhuN9//92o/cTERMnr0Lt3b/Gbb74Rz5w5I6ampkrqJiUliXv37hVDQ0ONxvTKK68U6bkkIvvCoJiIii08PFxUKBRGQQcAUS6Xi15eXqIgCEYB19atW42C3aIGxaYeCoVCrFSpkuji4lJoPZlMJq5fv/6p51UwKJ4zZ4749ttvG7Xn4OAgCeQKPipVqiT++eefT+3P2kHxP//8Izo7Oz/1ec59mKPRaMQpU6YUeqxKpRJ9fHxER0fHQus9LSg29XB0dBR9fHxEV1dXs3Vq1aolxsTEFPv5JaKKi+kTRFRsAwYMwNatW03eslmr1SIxMVGSG6pUKrF27VqjC7MK07VrV1SpUqXQOhqNBo8fPy704qnGjRvj6NGjCAsLK3Lf+S1evBjjx4+XlKnVarO3bg4ICMCBAweMlrArj4KDg/HTTz+VeB1luVyOJUuW4IcffjD7mmVmZiI+Ph7Z2dlm2/H39zd584386w2bkp2djfj4eLPL/bVr1w6nTp1iPjERmcSgmIhKpH///rh27RrCwsLM3mpXJpOhb9++uHDhAkaMGGFR+x9++CFiYmJw4sQJzJkzB126dIGrq2uRjnVxccGAAQMQHh6OP/74A+3atbOo7/zkcjlWrFiBXbt2Gd0IJL8qVargvffeQ0REBJo1a1bs/p613r1748aNG1ixYgUGDhyI4OBgeHp6Gi3ZVhRDhw5FVFQUli5dipYtW0Ime/pbTb169TBp0iQcPHgQUVFRqF27tlEdDw8PREVFYdmyZejbt2+Rgni5XI7u3btj69atOH78OKpXr27x+RCRfRBE0Qq3HiKiCikjIwNHjx5FdHQ04uPj4ezsjNq1a+PFF1+Ej49PqfWj0+lw584dXL9+HXfv3kVKSgoyMjKgUqng5uYGHx8fNG7cGEFBQUUKyAqaO3cu5s2bZ9ieM2eO0QWCkZGROHv2LO7duweNRoOqVauibt26eOGFFyCXy0t6ihVKcnIyzpw5g9jYWDx+/BiZmZlwdXWFp6cn6tSpgwYNGhR7ljoyMhI3btzAnTt3kJycjOzsbDg7O8PT0xP16tVD06ZNjZadIyIyxfIpACIiM5ydnfHyyy+XeT8ymQyBgYFGa88+S7Vr1zY5m0nGPDw80KNHjzJpm68DEZUWpk8QERERkd1jUExEREREEnPnzjV7/Ub+fVFRURAEAdu2bbOo/eIeV5aYPkFERERExeLr64vTp08jODjY2kMpMQbFRERERFQsjo6OaNOmjbWHUSqYPkFERERExWIqDSInJwdTpkyBt7c3PD09MW7cOGzevBmCICAqKkpyfFZWFt5++214eXnB19cXM2fOhEajecZnocegmIiIiIhM0mg0Rg+dTlfoMbNnz8bKlSvxr3/9C1u2bIFOp8Ps2bNN1v3ggw8gk8nw008/Yfz48fjvf/+LNWvWlMWpPBXTJ4iIiIjISHp6OhwcHEzuM3ezpoSEBKxYsQIffvgh/vWvfwEAevToga5du+Lu3btG9Vu3bo2lS5cCALp164bDhw9j27ZtRncQfRYYFBMRFTB37lyjm3WUd2q1GuvWrQMAjBw50uwbGRHZOWGgdFsMN1tVpVLh2LFjRuWrVq3C5s2bTR5z5coVZGVloV+/fpLyV155BQcPHjSq3717d8l2w4YNcejQIbNjKksMiomIiIjshlDkmjKZDCEhIUblv/76q9ljYmJiAACVK1eWlFepUsVkfU9PT8m2UqlEVlZWkcdYmphTTERERGQ3hAKP0uXr6wsAePTokaQ8Li6u1PsqbQyKiYiIiKhUNG7cGE5OTvjll18k5Tt27LDOgCzA9AkiIiIiu1H6s8P5VapUCRMmTMCnn34KJycnNGvWDFu3bsX169cB6FMyyqvyOzIiIiIiKmVlmz4BAAsWLMDYsWPx2WefYfDgwVCr1YYl2Tw8PMqkz9IgiKIoWnsQRERUMlx9goiKRHhVui3+9Ey6HTZsGE6cOIHbt28/k/6Kg+kTRERERHajbNMnAODo0aM4efIkWrZsCZ1Oh19//RU//PADvvzyyzLvuyQYFBMRERFRqXF1dcWvv/6Kzz//HJmZmQgMDMSXX36JadOmWXtohWJQTERERGQ3yn6muGXLljh16lSZ91PaGBQTERER2Y2yD4ptFYNiIiIiIrvBoNgcLslGRERERHaPM8VEREREdoMzxeYwKCYiIiKyGwyKzWFQTERERGQnxAJBMUPkPMwpJiIiIiK7x6CYiIiIiOwe0yeIiIiI7AYTJsxhUExERERkJ5hTbB6DYiIiIiK7wTDYHOYUExEREZHd40wxERERkd3gTLE5DIqJiCqAsD3A/6WMACBgx8/A/1619oiIqDwqmFNMeZg+QURk46p/o8H/XQf0f9IF7IkGXL/UWHlURKXktUVAlRHA4cvWHkkFIRR4UC7OFBMR2biYTED65iYgXWelwRCVFlEEZIPytl+aCygEQL3dWiOqEERrD6Ac40wxEZHNM/U2x7c+snH5A+JcGhHIzn72YyG7wKCYiIiIbEfT6dYegY1j+oQ5TJ8gIrJ1Iozf2zhRTBXV9Vhrj8Cm8UI78xgUExEREdkNBsXmMH2CiIiIbAdjOiojnCkmIiIi28HUoBJh+oR5DIqJiIiI7AaDYnMYFBMREZHtYExXIpwpNq/McopDQkIwd+7csmqeiIiI7BHTJ6iMWDxTfO/ePWzYsAEXL15EbGwslEolKlWqhEaNGqFv374ICQkpi3E+E3/99Rf27NmDa9eu4caNG8jMzMScOXPQt29faw+NiIiIiMqQRUHx1atXMXbsWCgUCvTu3Ru1a9dGdnY27t69izNnzsDZ2dmmg+KTJ09i69atCAgIQN26dXH5Mu+zTkREVK7w2/8SYfqEeRYFxatXr0ZWVhY2b96M4OBgo/3x8fGlNjBrCA0NxfDhw6FSqXDgwAEGxURkm0QREIEzd9VoU9PB2qMhKl1MnyghBsXmWBQUR0dHw8PDw2RADAA+Pj5GZZcvX8bXX3+Nq1evwtHREZ06dcI777wDZ2dnQ52oqCj8+OOPhpQMrVaLwMBAhIaGon///pL2Vq5cidWrV2PLli0IDw/HgQMHkJaWhqCgIEyaNAmtWrUyGsPZs2fx/fffIyIiAjk5OfD390doaChCQ0Ml9SpVqmTJ00FEVP48CYgBoO1mAKI6dwcA/YUkog5QCiIcZYCDHBjVTIYFXRRouzobF2JEyAQRTnL9W2d1NwE+TiIaV5XjvY4OqOlp2aUosUlafPtbBq7HaNEqyAFjuzrD2dGyN+U7t7Owb3cSUlO1aNnKFR1fcocgmG/j/s0MHP85DhkpGjR+0RPP96iEG2cS8cevDyHIBLToWxV1nvfEnzticP14PFy8lWg1xA9VglwtGldhdGotzo4+ibiTcZA7yuFa0wUOzgrUGFALAcPqlFo/5qRuv46U765AcJTD8+3mUHWqidSvzyNz5w3I/dzh/q82UDasbKiftS0CmWsvQnBUwHlyayhfqm3Ypzl9B9lfHYeYnAXlG82hHN4S6q1/Qr3uHKDRQeYAIC0b4sNUiA+S9T9UOg1kAiDr/xyUa4dBO2kTxB/PATodIBMh02iBVrWBnydDNvxb4JcLgE4EvJyBxtWBk1fL/DmyV5wpNs+ioNjPzw937tzBoUOH8NJLLz21/vXr1zF9+nT07dsXPXr0wIULF/DLL79AJpPhgw8+MNQ7f/48Ll68iHbt2qF69erIysrCgQMHMH/+fCQmJmLkyJFGbc+ZMwcymQzDhw9HRkYGwsPDMXnyZCxduhStW7c21AsPD8dnn32GJk2a4K233oJKpcLZs2exYMEC3L9/H1OnTrXkKSAiKr/yBcQA8iaExLwNHQCIOmRrgOwnuxee0mHV71lIyso7MEejbyg5WwREEcfvaPC/61r8PU0FJ4eivanmaES8viQJd+N1AIBzN9W4ek+DVeM8inxKD2NzsOCT+8jJ1o/n6l+ZSE3Rou8Ab5P14x9kYdXsG1Bn6/u8+Wcq7lxJxfV9ebcGvnEmEU3ae+Lvg4/yyk48xlvrW8KjmlORx1aYI30OIuHPBACAOlWDrEdZkGtEPDoSC3VSDupOblAq/ZiS+n/XEDt0t2E7fecteITWRuZP1wxlmTtvwPfqWCh8XZH5wyWkvLndsC9759/wOjISyvYB0Pz5AGmdVgI5WgCA5rcb0By4Du3G3wGIkEGr/5kyIkIHLbDuNHIORUB255FknwgthAMRQPWpQGp63q7EDOB4ROEnyNuOURmxKCgeNWoUzp49i3fffRf+/v547rnn0KhRI7Rs2RKBgYFG9W/cuIF169ahcePGAIBBgwYhPT0dO3fuxPTp0w2zxb179zaatR06dCjGjx+P9evXY9iwYVAopEOVy+VYs2YNHBz0Xw3269cPoaGhWLRoEbZt2wZAn87xxRdfoHv37vj0008Nxw4ePBhffPEFfvjhBwwaNAh+fn6WPA1ERLZDgPHXzTIB0EoL8wLi3OMEfZCdz50kEf+7rsXARkV76zh+LccQEOc69FcOYhK18PWSF6mNU8dTDQFxrsMHks0GxRcPJBgC4lxXTiXBMX+BCFw/Kk33U2dqEfHbQ7wwvFaRxvU0uQGxgSBAlIkQdMDttdfLNChOWv6ntECnQ2b4P9KipCxk/F8E3Ge0RubycwXqi8hceR7K9gHI+e53Q0CcS7PtTwgAhELnHAXoo1cdhDsFUysFiJBBgA5CaoYlp/ZkfJYfQvlxptgciz5vNW3aFJs2bUKfPn2QlpaGXbt2YcGCBRg8eDDGjBmDe/fuSeo3adLEEBDnev7556HVavHgwQNDmUqlMvw7OzsbSUlJSElJQZs2bZCeno6oqCijsQwdOtQQEANA1apV0bNnT0RFReH27dsAgAMHDiAnJwevvPIKkpKSJI/27dtDp9Ph3LlzRm3bioSEBGRnZxu209LSkJqaatjOycnB48ePJcfExMQUuh0bGwsx3xsh+2Af7KP891GoUs6/zB2apedRcEhFfa7MNGGyj4SEBGg0miKchRli2bzmBWk10iCz1H+uTDxnpl4LjVpjtr5Oq9X3YeoFsHJOb/7uy8vvoKV9WJP45OOM+JSPNfbI4iXZgoKCDOsPx8TEGFIi/vjjD7zzzjvYtGmTIVitUaOG0fEeHvqvzZKTkw1lGRkZWLVqFfbv34+HDx8aHZOSkmJUZmpmunZtfQ7U/fv3ERgYaAimJ06caPZ8EhISzO4r77y9pTMlrq7SfLjc5fLy8/X1LXS7WrVq7IN9sA8b6wN4kjdsYnbXJBNVPByB5Oz8dYwr1fQQ0Kue3OS4TZ2HVyURft7puJeQN7XXqaES1b3kAIr2XL3QPgf79yQhJydvPB1f8jD0kZ+3tzee7+6MM7sToMlXv3FrD9w4IJ0KD2rvg+uH877Sd1DJ0LB7FXj6qiT1ivuaV2rujcd/5Ht/EfWzxABQZ3T9Uukjv/zPv8f455B18n7eTkGA8yv1kBn+d16RuyPchzUFAKjGPw/16bt59WUCXMa3grJSJWjeeh45q84B6rxAXjGgKbT/d+FJUGVu3lFE7pSuGFAZQlScZJ+Qu8/dGUJKuvHhhcjfX3n5HbS0DyqfSnRHO19fX/Tp0we9e/fG6NGjcenSJURERKBZs2YA9CkO5uT/FPbBBx/gxIkTGDBgAFq0aAEPDw/IZDKcPHkSmzdvhk5XvO9KcvuYN2+eyYsAAdOBOxGRzcqfR5z7yBcF67/QBhwVgJMcUMqB0c1l+KSTA1qtzsGlWP2FdiqFPsvC11WApxJoVFWODzs5QFXEfGIAcHQQsHmqJ5b/loHrDzRoFeSACT1cLDqdar5KvPthDezdnYTUFA1CWrmiczfzOcmV/Zww5rO6OB4eh/RkDZq080TrXj7450UP/LE770K7uq29cKGxO64f019o13qon1FAXBIdd3XBubGnEXfiIWSOcrhUV8HBSY4aA2shICyo1Poxxf3NhhAUMqSsvQIo9RfaOXethZTF5/QX2tV0h8e/2kJR3Q0AoBreDHCQIWvtRcBJAefJbaDsqJ94UrSoAdeDY5D9pf5CO4c3msFxVCuo+9SHet3vgEYLmYMAMS0LSMiAGJuSd6EdAPmgZnBY9Qa0UzdD/OGs/ipPGSCoNUDbOsDWScCo1cC2c/oPYl7OQP06wJm/9RflET1DpXKbZ0EQ0LhxY1y6dAlxcXFPPyCf1NRUnDhxAr169cL7778v2VdYasPt27eNVsGIjIwEkBfo1qxZEwDg6ekpufiOiKjCEvKi4vPDgJa+RV+S7cL40rnILL/q3nLMH+JWojYC6zhhwpRqT6/4RM1gFwydLf02sX77SqjfXjqbFxJaAyGhZTMxInOQo826dmXSdlG4DakPtyHSGWmPmW3gMbONyfqq15tC9XpTk/sU7QOhaC99Ph2GtoTD0JZFHo98yVBgyVDTO7dMMV0uDCxy+1R0TJkwz6Kc4jNnzpjM18rKysKZM2cA5KUwFHkAMv0QCuY7xcfHY8eOHWaP27x5M9RqtWH74cOH2LdvH2rVqmVIrejWrRuUSiVWrlyJrKyCV5Ho84Kemo9HRGSjLAmIicheCAUelMuimeIvv/wSycnJ6NChA4KCguDk5ISHDx9i7969iI6ORu/evREUZNnXQi4uLmjTpg327NkDR0dHNGrUCDExMQgPD0eNGjUkucf5abVajB49Gj169EBGRga2b9+O7OxszJo1y1CnatWqmD17NubPn4/BgwejV69e8PX1RWJiIm7evIkjR45g69atqF69OgB9jvTu3fplbHJnnY8dO2bIc+7duzfzgoiIiKypaAuXkBmcKTbPoqB4xowZOHr0KP78808cOnQIaWlpcHV1RVBQEMLCwtC3b99iDeKTTz7BsmXLcPz4cezevRs1a9bExIkToVAoMG/ePJPHzJs3D9u3b8eGDRuQmpqKoKAgzJkzB23aSL8a6tevH/z9/bFp0yaEh4cjNTUVnp6eqFWrFiZMmCBJjr9//z6+/fZbyfGHDx/G4cOHAQDNmjVjUExERGRN2qdXIfMYFJsniObWzCmncu9ot3PnTsMMLxGRPRMWqfPlEj8hihBnMX2CbJi5nGIZAG34Mx1KRZIqzJBsu4lfWmkk5Q/vC0NERES2g4tSUBkpldUniIiIiKj8Y/qEeQyKiYiIiOwGg2JzbC59Yty4cTh//jzziYmIiIio1HCmmIiIiGwHJzpLhOkT5jEoJiIiIttR28faI7BpDIrNY1BMREREtuPKUmuPwMYxKDbH5nKKiYiIyA5otxmXyQConJ75UMg+MCgmIrJxPkoA+e/DJIpw5GQQ2TqZDBDDgZebA54qYNf7vGlHKRALPCiPzd3RjoiIjPXdqsavt0UAAjrUAI6+wbvZEZGxBGG2ZNtbXGClkZQ/zCkmIqoAwvsD69atBwCMfHWkVcdCROUZv0Yyh0ExERERkZ3g6hPmMaeYiIiIiOweZ4qJiIiI7ARnis3jTDERERER2T3OFBMRVRA/prZEDhTgZXZEZA5nis3jTDERkY07fFsD5RLgsPgcToqNoFwCfPeHxtrDIiKyKQyKiYhs3EvbAekySwJGH7TSYIioXBMhSB6Uh+kTRERERHaDgbA5DIqJiIiI7ARvY2weg2IiIiIiO8GUCfOYU0xEREREdo8zxZRHGCjdPvFv4MXG1hkLERERlTrOFJvHmWLSUww0Lmv38bMfBxEREZUhocCDcnGmmPS01h4AERERlTXOFJvHmWIiIiIisnucKSYiIiKyE1ySzbwymykOCQnB3Llzy6p5IiIiIrIQ72hnnsUzxffu3cOGDRtw8eJFxMbGQqlUolKlSmjUqBH69u2LkJCQshhnmRNFEXv27MHx48dx7do1PHr0CJ6enggODsaoUaPQuDFXYSAiIiJbx0DYHIuC4qtXr2Ls2LFQKBTo3bs3ateujezsbNy9exdnzpyBs7OzzQbFOTk5+PjjjxEcHIzu3bujevXqiI+PR3h4OEaOHIl58+ahV69e1h4mEZFEpcVq/fehAt/oiIhKwqKgePXq1cjKysLmzZsRHBxstD8+Pr7UBvasyeVyrFy5Ei1btpSUDxgwAK+++ioWL16Mnj17Qiazs2sThdAn/5ABjg6ARgc0CwAyNBC9XIDfowCNFmLtqkBMMhBUBUhXAw5yiMPbA7fiIIYEQAz/A2JtHyBHB+FBMsRXngMu3IW2ujvw7UlALod830Qom/pBjE+Ddv8/ECu7QHvqDvAwFcqZnSELrCQZWtbKs9D+fg+K/g0hpuRA5usKUS1CTMyEPLgSNBGPIPNzR9Yv1yE4yuH6QXvI3ByRfSIayfNOwKFBJXgu7g5BVngwoXmUgfT9d+Dg5wbnDn6SfboMNVL23IHMUQ63Hv4QHOSGfdosNWIW/AlNfBa8Qusg+24aXFv4wLmRt6SNnIeZSDz4AI7+rvBsV1Xad7oaj357ALmTHD7dqkOmyPv502ZqcG3JVahT1Kg3qT6ca7iYHH/GoyzEnIyDS3VnqDM10KRr4OrvisRbKajc2AteddwKPX8AeByVjofXUlCtgTu8A0z3k9+j6EzEXE+DTy1nJMZmQ+kkQ50WHpDJTT/XsXezcO9WJvzrOqNKDUeTdTQaERFXMqBWi2jS1BmOTjJkZupw6UomVCoBCoWAxCQd/Go44M59NapVUaBeHX1bUQ/UuHFHjVrVFbj3SAtnJwGnrmbjdqwWAzqokJ4joEYlGZIyRag1QIeGSqiU0rEeu6XGvSQRjX1luByjQw0PAb/d0CJLLeK9zo6o4iZDcpaIvdc18HAELj/U4VaCiFcbKxCTBgR6AQmZgFoHpOaIOB4loqUvsPMG4OsGrOgth6NCjp1/a7HknBZt/AS08ZNDowOuPdbhYJQODgLwW7QAGQAdADF3iHb2Z4mIio8pE+YJoigWOed60KBBSEpKwsGDB59aNyQkBH369MHAgQPx9ddf4+rVq3B0dESnTp3wzjvvwNnZ2VA3KioKP/74oyElQ6vVIjAwEKGhoejfv7+k3ZUrV2L16tXYsmULwsPDceDAAaSlpSEoKAiTJk1Cq1atjMZy9uxZfP/994iIiEBOTg78/f0RGhqK0NBQo7qmzJo1C4cPH8bevXvh4+NTpGNsTsEbdxjkvtvmX89Q8eSXKq9MLFBHB7lkn76+tEwH4Un7eb+gQlgbaLdeBjJyChwrwHH1YChHtwUAJAUuhC4q0aiOtF082S9AhAxwkEHRMxhZu27mnZ6DDNUfz4DczXQglrb3Nu4P2AkxS79mncvLAfDb2R+CQoasfxJxq1M4NLEZAADH+l4IOjYIisoqZEen4nK9HyFmaaEzjEl/nn4fNIf//OcBAPG77yJi0GHosvXtV+pbE01+fgmCXIa0v5NxpsdvyHmYBQBwbeiBNvt7QFnJEel3UrGv/R7osnWGl6fVt23h37+WZPzRBx7gyNtnoc3RGZ4rrQwQFXnBe8u366Pl2/VNnj8AnPkuEqfX3DZstx1TG23eCjRb/8jGezi26b5hWycIEAUB1WqrMOLz+lC5Sj+L7/2/h9i/Nc6w3euNqugyqIqkTmqqFgs/uY8H9/U/Fx6ecgwdURmr1j9GWlreuakFGbSyvOe6XStneFZR4Me96dAByBH049EKAiAI0ADIFmCYZdUAUAsCqrjL8MNUDwRWUUCjFdHvuzTs+VujH4ws/+8CAJm+aHE/J8w5mIPEzCftFZy5lcFEWV49mQA8Xx04G2OqTr7tfOPNa9dE2wDEmbyWmoikooVPJdv+4gdWGkn5Y9H8gp+fH5KTk3Ho0KEi1b9+/TqmT5+Ohg0bYvr06WjdujV++eUXfPXVV5J658+fx8WLF9GuXTtMmTIFEyZMgEKhwPz587Fu3TqTbc+ZMwdXrlzB8OHDMWLECMTFxWHy5Mk4e/aspF54eDjefvttZGZm4q233sL06dPh5+eHBQsWYMmSJUU6j7i4ODg4OMDN7ekzahVX/s9OQoH/S0Nj0cQ+ocD1rk/CAEjf7QHdhrOGgBgF9ma/swsAkLnslCEglrYvokC4km/sIqDWIWvXDekutQ6PXws3OiLXwymHDQExAKTviULqz/qg+uGcs4aAGACy/07Eoy//AABEjTsGMUubL0jPG9W9z/5E1u0UAMCNKWcNATEAPN51F/E77wIArs/70xAQA0Da1WRELbsGADg/8/e8gPjJKf75/kXpWYsizs67ZAiIkTuKAsHTxRX/IC020+T5p8Zl4cy6KEnZmbW3kRaXZbJ+clw2jm++LykTRBEQRcRGZuLcrjjJvoS4HBzYLi3btyUOKYlqSdn+PUmGgBgAkpO02Lj+kSEgzqUVpM/1iXMZ2LonDQCgeRI4isj7f3aBYFIBQCaKiEvRYclu/WsbfkWdFxALJn7CREAnArP2ZOsDYkO9AgoJiAF9G2fvw1jBpkQAuXMZgokyIqJC8EI78ywKikeNGgWFQoF3330XAwcOxLx587Bt2zbcvn3bZP0bN25gyZIlmDZtGgYNGoT//Oc/ePHFF7Fz505kZOQFE71798ZPP/2EKVOmIDQ0FG+++SbWrl2LFi1aYP369dBoNEZty+VyfPfdd3jjjTcwZswYrF+/HkqlEosWLTLUiY+PxxdffIHu3btj7dq1GD58OAYPHowvvvgCQ4YMwQ8//IB79+4Ves4nTpxAREQEunXrBkdH07OJ1pKQkIDs7GzDdlpaGlJTUw3bOTk5ePz4seSYmJiYQreLrrBfJON9Rf+1M35jNwTUqfpATHMmulijKRis51JHxJt8rh5E34f6RpJR/Zyr+npplx4a7cv4S59ClHU92fzodCIy/06CNlODrMhUFJR+Vd9n6lXjvhMuP0J2djbSb6cZn0dSjuQ8NOkapN3PMKpnFGNpRSTlG0f+n6vEOxkQtaJR/TsRsZKy3J+j+LtZEKVxqqS/R9GZkj7i7mcb1ddqRMREp0tej/wBca70VBN3nDERjMqeBIu53Yj5/2+ifm7JzVgNYmJiEBGbr59C8nYNn23M1SnLoNXMTHGugr/nsbGxyP8lYVn8LWEf7IN9mN+2JgbF5lkUFDdt2hSbNm1Cnz59kJaWhl27dmHBggUYPHgwxowZYxRgNmnSxGjVhueffx5arRYPHjwwlKlUKsO/s7OzkZSUhJSUFLRp0wbp6emIiooyGsvQoUPh4OBg2K5atSp69uyJqKgoQ5B+4MAB5OTk4JVXXkFSUpLk0b59e+h0Opw7d87s+UZHR2POnDmoUqUKpk+fbslT9Ux4e3tLAnVXV1fJbHbuyiD5+fr6FrpddIW9wYtG+4seDpia59WXCTU8AACOw5oXOpqCfeVuCyb3AqqX65h8rqr714DqherG9Tvq84o9ugYY7XPvXPPJ//MfJ+1T5iSHa+sqkKsUcGtlnI7j2bEaAKBSh2pG+6p18YOjoyN82lYx2ufs7yI5DwdXB1Rq7GlUr+AzoHCWo0oTL8N2/p+rqg3c4aCSS+o7OMsR1EqaW537c1SjngscHKV/VvL3F9DETdKHf11nOBTI3XVyliEg2E3yetRroEJBPlUcJNsCnsxKFyBzyPteIrdeYfVzg+dWdZXw9fVFpzr5UhAKCWw9HYXC6xT3QrhSCKYL/p5Xq1YNQr7xlMXfEvbBPtiH+W0qnyy+PCMoKAhz587Fb7/9hl27dmHu3Llo3rw5/vjjD7zzzjtQq/O+9qxRo4bR8R4e+sAmOTlvJi0jIwOLFy9G79698eKLL6Jr167o2rUrli9fDgBISUkxaicw0DinsXbt2gCA+/f130HmBtMTJ040tJn7mDRpEgD9J0BT7t+/jwkTJgAAli5dCi8vL5P17Ef+H5XcMFUHQMwXAguG/wr5SvX/khmOzfuvDgVDNPmu0RAaPQkGhXztuirhtOMtAICyZz04vNok32iejEgug5j79baDvj9RyEuqkNXygMfi7tJ00Jpu8P7W/Koi1dZ0g7KB/sI4wVGOSh+3gUsnfeBb7d+t4drFzzBWzyF1UentpgCAWivaw6mB55PsZtHQp8LbEUHrO8HB2wkA0GBtOzjX0/9OyJzkCJjX3HCxXfDcZqjU8cmFdzIB1YcEwn9sPQBAy/8+D9egvD/KDu4OeHFjB6Pxt1sYAvcAV/0Q5QJEmX4oMoV+QE5eSnRe0BJKNwejYwHA0VWBnh83hMpTv1/l6YCeHzWEo4vpXFUnVwX6z6oDlbt+v0wuQCcIEOQCmnXzQfMelSX1nV3leH1KTTi76QNvV3f9tmOBQLxzVw+0fsHVEFfWb6TClOnVEBykf6MSBP1zJNfpkJsu7agUMOJVD8x8yxtuLgIcRP2PhRz6YFiACEcxLzCWywC1AIiCgBfrOWBaL/11D53rOuCjbk5wVAAQxdwfrSepKPqHj4uA395SoXXNJzvFgr8VgEIoMCejEyUBr5cTMKutqcBZMN4sGGAzc4KIikwo8KBcJboKw9fXF3369EHv3r0xevRoXLp0CREREWjWrBkAfYqDOfm/mvjggw9w4sQJDBgwAC1atICHhwdkMhlOnjyJzZs3Q6fTmW2nMLl9zJs3z+wFcqYC9wcPHmD8+PHIzMzE8uXLERQUVKz+Kwy5DHB2Aj4aCGw9C6yfABy8CqFFAMRvDkC4cg/iujHA3B3A5G7ApXsQHBUQhrYBLt+D2CEY2HwOaFoDyNIAkfEQBrWAeOImhBB/qJcdBZyVcHynq76/Ps9Bd+MRBB8XiAkZ0MWmQvGi9EOQ25ah0H2dBs3lWCg6BUKMTITg4wJodBBTsyGr6QHtrQTIa3lCffURBEcFHBrrZ1fdJj+P9O8vw6F5VTg+Zzwbm59jg0qofXUEcm4kQl5ZBbmnk2GfwssJdQ4MQE50KgSlDA7V8lZlkDnI0fTqEGTeSIYmPhMuLSsjKzIVTgGukDnl/dq5NPJCq2sDkHkjBcqqKig8lIZ9ykqOaL2vOzLvpEHmKIdjtbzZUrlSjp4neyP1ZgpyktWo1FI6S5HLu74HBh7sjpTbaVD5OEGbo4UmSwvnKk5IvZcBNz9nyJXmf08BIKhTFQS84IOUB5lwr66CQln4Z+kG7b1Rt7UnkmKz4VnNEamJajg4yuDqaTrwfu4FDzQMcUNCXA4qVVVC4WDcvkIhYOykanjtDQ3UahE+lfVtzf2oOuIeqeHkKINcLiAlVYsqleWIjdPC21MOlUrf1gvNnBAbr4FvZQUeJWmhchQQn6zD39Fq9HzeEfcSRFTxkCEjB1BrRFT3lj4n/35ZhRmdHPEoTUSdSjLciNehursMd5K0yNIAIX761/TMRAUiE3RwUwKZGuB2og7ta8lx47GIGu4CUnMAjU6EmxI4/0CHdv4ybL+mQ6CngBf89X3+u7MW318W8VKAAGelDFoRgE6H/0WK6BmgQ9/tAhr66NvfGQl9QMzVJ4ioiPgZ2rxSuTRZEAQ0btwYly5dQlxc3NMPyCc1NRUnTpxAr1698P7770v2FZbacPv2baNl4SIjIwHkBbo1a+pn9Dw9PdG6desijefBgwcYN24c0tLSsHz5ctSvb/6qfLsgbpNuz+qv/39DfwCA8KL++REA4Nd39Pt6NM2r36Wh/v9hL+SVta2j/3/XBgAAx4+MZ2pldfUzioKXM2R1TH+gkVV2hbLLkw8sdfPVqawPThX19W0oW0pTIASZANcRz5ls0xxlXfPfFCj9zV+AqarrAdTVzwQ71/c0WUcQBDgHe5hvo5ar2X1uQe5m9+Vv36N27hjzAlPP2ubHXZBCKSvSUmz56/v464N4r6pPz8V3UMpQ1c/pqfU8PI3/ZFWpnHdOLi766LCGrzRKVDoI8PfV16vuo2/Dy02Oun76ssAnE/IuhQzBUyWD55PPJfWq6APYxtWMx1PbO69vf0/9v+tV1s/GuDoCuTMzXevo973RVDpWJwc5xkpXhgQgx7gW+n9dHiPds+2aGoN/NT9uIqL8mEdsnkXzC2fOnDF50VtWVhbOnDkDIC+FocgDeLLub8GV4eLj47Fjxw6zx23evFmSqvHw4UPs27cPtWrVMqRWdOvWDUqlEitXrkRWlvHV8mlpacjJybuAJyYmBuPHj0dqaiq+/vprNGjQwKJzISJ61kIbOPDGHUREpcCimeIvv/wSycnJ6NChA4KCguDk5ISHDx9i7969iI6ORu/evS1ONXBxcUGbNm2wZ88eODo6olGjRoiJiUF4eDhq1KghyT3OT6vVYvTo0ejRowcyMjKwfft2ZGdnY9asWYY6VatWxezZszF//nwMHjwYvXr1gq+vLxITE3Hz5k0cOXIEW7duRfXq1ZGeno7x48fjwYMHeO2113Dnzh3cuXNH0mfr1q2NkumJiIiIbAVnis2zKCieMWMGjh49ij///BOHDh1CWloaXF1dERQUhLCwMPTt27dYg/jkk0+wbNkyHD9+HLt370bNmjUxceJEKBQKzJs3z+Qx8+bNw/bt27FhwwakpqYiKCgIc+bMQZs2bST1+vXrB39/f2zatAnh4eFITU2Fp6cnatWqhQkTJhiC3OTkZMMFelu2bDHZ57fffsugmIiIiGwWg2LzLLqjXXmQe0e7nTt3onp14+WyqJjM3dFONH9jCyIqH4QvjNPaAN7RjoiM3RAWSbbrirPM1LQ//ItJREREZDc4U2wOF/IhvaY1rT0CIiIiIqthUEx6l5YALfKtBSwA0G232nCIiIio9PE2z+bZXE4xERFJMaeYiIrqH+FLyXY9cYaVRlL+8C8mERERkZ3gTKh5TJ8gIiIiIrvHmWIiIiIiO8E8YvMYFBMRERHZCQbF5jF9gojIxmlnyKDPFMx7pE+x7piIqHwSCzwoD4NiIiIbJ5PJkDMVWOm+Divd1yFnKuCs5BeBRESW4F9NIiIiIjvB9AnzGBQTERER2QkGxeYxKCYiIiKyE8wjNo9BMREREZGd4EyxebzQjoiIiIjsHmeKiYgqAM9lQIZuJADg7SVAzkwrD4iIyiXOFJvHmWIiIhsnfKFBhk4AoH+oIUD4QmPtYRFROcR1is1jUExERESU604c4PkGoHoV2H/R2qMpdSIEyYPyMCgmIiIiAoD/hgMB44HkTCBLA3SfDzSYbO1R0TPCnGIiIlsnioAgGJcRkWVmbjIu+/v+sx9HmbL92eH79+/j2LFjiIuLw6BBg+Dn5wetVovk5GR4eHhALpcXq13OFBMRERHZCVtOnxBFETNmzEBgYCDeeOMNzJgxA9evXwcApKWlISAgAMuWLSt2+wyKiYiIiOyELV9ot2jRIixZsgQzZ87E/v37Ieb7RszDwwMDBw7E9u3bi90+g2IiIiIiO2HLM8WrV6/G8OHD8Z///AfNmjUz2t+0aVPDzHFxMCgmIiIionLv7t27eOGFF8zud3FxQUpKSrHb54V2RERERADyLkITC2xXHLaWMpFflSpVcPfuXbP7L1y4AH9//2K3z5liIiIiIgB5IaMMeSGSLYeRxnQQJA9bMnDgQHz77beIjIw0lAlPVt757bffsH79egwePLjY7ZdZUBwSEoK5c+eWVfNEREREZcCWL0V7OlvOKZ43bx58fX3RrFkzDB8+HIIg4PPPP0e7du3w8ssvo2nTpnj//feL3b7F6RP37t3Dhg0bcPHiRcTGxkKpVKJSpUpo1KgR+vbti5CQkGIPxto2bdqEY8eO4c6dO0hJSYG7uzsCAgIwZMgQdO7c2drDIyIiomei4gXDFYGHhwfOnDmD//73v9i2bRucnJxw9OhR1KlTB3PmzMGsWbOgUqmK3b5FQfHVq1cxduxYKBQK9O7dG7Vr10Z2djbu3r2LM2fOwNnZ2aaD4oiICFSvXh0vvvgiPD09kZKSggMHDmDWrFkYP348Ro8ebe0hEhEV2YFINbrWdrD2MIhsw9Voa4/gmbD1cF+lUuHDDz/Ehx9+WOptWxQUr169GllZWdi8eTOCg4ON9sfHx5fawKzhs88+Myp7/fXXMWzYMHz//fcYOXJkse+SQkT0rHXbCkBUQxCA73uKcHcW0K+uA1KydHBzFKDWihABaHUi/owV0aamHA/TdPBw1H+lmpgpooaHHFqdCLlMMKwJKhS8e14BBesDQGqWCHeVNGNPpxMhk+W1lb/93DYK1sl/XP76uWWm6hfGVP3sDA2Uqry/9YIgQNSJEGR5/y8NRX0+1WlqOLg6PLV+wTHmry9qdRDkMpPj16TmQOGmLLSt/GXa1GzI3Ryl7efuS8+BTOVg8jkSdTr9nRdFEWJGDmSuThB1Oggy05mcpurr0rIgOCshyGSG/bqox5AFVIL26gMIHioIlV0hxqZAXssHurRMCM6OgE6EqNZASM8G1hwDxnSE8M0+oJon8Gk4EP3oSa8CbD9sLJytpUw8SxYFxdHR0fDw8DAZEAOAj4+PUdnly5fx9ddf4+rVq3B0dESnTp3wzjvvwNnZ2VAnKioKP/74oyElQ6vVIjAwEKGhoejfv7+kvZUrV2L16tXYsmULwsPDceDAAaSlpSEoKAiTJk1Cq1atjMZw9uxZfP/994iIiEBOTg78/f0RGhqK0NDQp56zQqFA5cqVcfPmTWg0GgbFRFT+iaLkfV0UgWF7cjdyAN2TnZLUSRGARnp8blCrkwYJzgpArQV8nIHENB2qugn46CUlAjxlCN2YjqRMQIAIUScaHwsRteQ6yHNEiCKgVABOGi1UMiAnB5CJIhSi/niZCDiIImQCoFIA0OgAjb5NAYAMef+XqbVQQYSgAwQZ0LqdG0ZM9DV6am5eTsOutQ8QF50JuVqnD+YAyB0EQKvT9/HkvBVaLWRPxgKtDnJRBzzZVsgFKGRA8EuV0XlKXZxfF4m/dtyDTC6g6WB/PDfYDyf+E4GoQzFw9nFCyNv1ENzHDwCgydJi9+AjSIhIAgSgakglvPRtW1z48CLu7XsAVTUVms5sjNQrCfjn678Nr4mg0UGhBQSlAEEEKnf2xXNftcKlVw4h9WICgCfP25PnRQ6tPvwRAEHUPbmISAQgwOtlP7g19EDcf/9EbpapzEEGmVIGMVMDQaeDXNBBEHNDKBGADtJ3QBEy6CCHTpKdKgBQNK0Mn02vIGXS/5Bz8g5ksievH3SQ5fvhzL3US3BSAA5yOL7ZDI4fdkTmc19BjE839JE3BhECdIZz1dNAXiCQFSA+qaXN6wPik1oi8N4WiNDme05yR17x2XJQ/NZbbz21jiAI+O6774rVviDm/yj/FFOnTsXJkyexcOFCvPTSS4XWDQkJQXBwMB4+fIi+ffuiZs2auHDhAn777TcMGDAAH3zwgaHutm3b8NNPP6Fdu3aoXr06srKycODAAfz111+YNGkSRo4caaibGxTXr18fMpkMPXr0QEZGBsLDw5GQkIClS5eidevWhvrh4eH47LPP0KRJE3Tq1AkqlQpnz57FkSNHMGzYMEydOtVo7MnJydDpdEhKSsKBAwewatUqhISEYMWKFUV9qoiInhlhkVo/o5afKOJJVPBk28S+/HUKvhXkD6xF4+BWsk+r31BChxxtgTa0OslhKp0OdXTSMkEnwkOnD0YdRWloIogilKIIiCJUWp306nAxLwB00GihKtDXG2OqoH0XT8N2WrIGn429BnW2CIVGA1n+U9LpDG3lb99Bow8sZVot5AXGLXuyr0Z9F8RdTpLsqx6kQvyVfGUCEPpTB/g08MC+sON4cDxOUt+9mhOy76bnO28dHHJE6esqipBn6wNTfWgLOLs7APcyJW3lBsaACDn0z5nxOgM6OD4JmvPq53GApkBZbnAqSMoEqOHwpA1p+yLkbg4QUrMg5AbnMH6ORQBySJ9XhZsMSM1+0qfWqF0ZtJISARqjNnKfH0D7ZJ+pi+bEJ2PTQf+BUID+F0IHI2K4cZmNOi6skWy3F20nNTQgIMDomxKtVouYmBhotVpUrlwZLi4uktUpLGFRUHz58mWMHTsWGo0G/v7+eO6559CoUSO0bNkSgYGBkrohISEQBAHr1q1D48aNDeVTp07FmTNncPjwYcNscWZmplFitE6nw/jx4/HPP//g4MGDUCj0k9q5QXGjRo2wZs0aODjo8+UePnyI0NBQVK1aFdu2bQOgT+fo168fOnfujE8//VTS/hdffIGffvoJ4eHh8PPzk+zr0qULkpOTAQByuRydOnXC7Nmz4eXlVdSniojomSlSUAwUCHJReFCcW5Y7Y2wuKAaezABCX6dgO1qdpKyqVovKJgJwT60OMlGE0sQwlDr9PmetcbAiE/XBnlyng4taGiwFBDli9vxahu0LhxOxZYl+jVMHtUYabOl0RrONAKDQaCETRQg6HRTaAsGYTgeZToSDTpv3HOSOOSvbKAZrOb4unn+7PjY22gFNprQtmU6EQ77zE9Q6OJh4LmRqLRTavKDPMU0DudHTIhrORQbtk9ld0WiG1vFJcCkzCphFKFHg+XlyjHGig9ZQ13j+UQcFdIagWCgwS5y/Xv52FcgBIDypb/yaCwXGJkeOUd+5z49gCO5NryShb0sLQAsGxbZLrVZj5cqVWLx4Mfbv328UkxaVRUuyNW3aFJs2bUKfPn2QlpaGXbt2YcGCBRg8eDDGjBmDe/fuSeo3adJEEhADwPPPPw+tVosHDx4YyvIHxNnZ2UhKSkJKSgratGmD9PR0REVFGY1l6NChhoAYAKpWrYqePXsiKioKt2/fBgAcOHAAOTk5eOWVV5CUlCR5tG/fHjqdDufOnTNqe9GiRfj666/x8ccfo3Xr1sjOzkZ6erpRPWtLSEhAdna2YTstLQ2pqamG7ZycHDx+/FhyTExMTKHbsbGxkjxA9sE+2Ef576PMFGXKRBLgmgms89GYaKLQL3NFwxfehQ5HMLHT1U2QPFcqt8I6Mtd+Ib0+2aVwNH4rVTgZp9qpfJwAAHJn4/qCvMCzIMDkB5WC5ykWOb9ZLLAlFOnlfRrBVABZpBGYLyv8J8LUESVNB5Dla9e4fREo9d9za7LlJdnMcXBwwNtvv43u3bvj7bffLnY7Fi/JFhQUZFh/OCYmBhcuXMAvv/yCP/74A++88w42bdpkCFZr1KhhdLyHhwcAGGZiASAjIwOrVq3C/v378fDhQ6NjTN2yz9SngNq1awMA7t+/j8DAQEMwPXHiRLPnk5CQYFTWokULw7/79euH999/H6NGjcLWrVvh7u5utq1nzdvbW7Lt6uoq2c5dLi8/X1/fQrerVavGPtgH+7CxPgA1LGJIoSzkoqL8AZnRzK7xv2t5CajsJMP5e/mCJBNBXZIgoKooSm6LIBfFJxmr+vm6/OGkHHkhj67APkP7T2ZyxXx15XJgyMhqcMt3AVn9Fp4IbJiA21fToRUEyMV8IYFMBuhMzASLptuHKOrzbWVAyMhAnF99C5ps/bkrXRRoNiQA57/+x9CWRy0XBPfRvyeGzGqKk7MvSPqq/0Zt3Fx3w7DtGuwBdWQqdDnS51Oukz79VYfXRvzaW/lCm/wzwqIk1UJ6cgIEhQxQ66CDYJTWoIXsSa5wvkOMWhKfvB76bN2Cfaj6B0O9429Jxm7BFvSpG/koZJB3qw/tnmuGwL1g2oeUaDT+gj+e+rGZ+lk3TikxPZsMODo6GrZL4/fcmipKIGzKc889h40bNxb7+BLd5tnX1xd9+vRB7969MXr0aFy6dAkRERFo1qwZABR6UVr+mZAPPvgAJ06cwIABA9CiRQt4eHhAJpPh5MmT2Lx5M3S6on8SNdXHvHnzTF4ECJgO3Avq06cPfvvtNxw6dMjowj8ionLPEDwCEACFADjIRWh1T74s1unDAzn0F7/JhSdBqijCRwXIBAFVXABvJ/2/2/rLkK0RUMMNiEsTUdlFQFhLB3g7C/jsYBZ2RqhRzVVASrYO2WrgaowOqdlATU8Bw55zgpNcwN37aqRmiGgeoICDCCjlwLXbOdBqRWSk65CUqkP1SjKoALi5CqhTQwmNRoc7UTm4ezcHnh4yuKkEyOQCXB2B1CQtfLzlSE1Qw8NTgUFvVkYlH+lydDKZgDHzAvHHsSQ8vJuF1Lgc3PkrFU7OcgSHuEEuFxB1MQnx97Lg6q6AVyU55HIZHJ1kSE/MgYNCQFJ0Bhxd5agd4gmFUobgl6qgarAbgl+qir/3PIBMLkOD3r5wq6ZCzbaVcftQLFwqOyL4lZpQuurHE/xqANxrueDPZdcgc5ChxTuN4NPYC4Gv1MT93/QX2gUOqgWFiwLH+h9C0l+JULo7QMjWQOGoQJWu1aFQKVC5sy+qdPFF4si6uDrmFLSpGjh4KKB9nAXHGs5wcJVBplRA4SKHOi4LMqWArOtJUFZzRtCmznAKcseNzjuQdTkBDjVd4NkvADIHGXKuJ0J9Nw2ONV2gvZcKQaWAJioJuowcyB3k0CVkQebtCFGthszRAco6HkBGDkS1Btq/H0Puo4LPzlfh0KgKsn6+BvWZe9AlZEC9/yZEARDUGiA1B0IVFwgZ2RAqu0DZPQiCkwOUQ5pC0bgaslecQs5nByHKAGTnQEjLBjydICRlAC4OgJOD/mrP1HQgXYROECDLTW+RP5lRd5JDyBEhKpWAUgYhRw1kZEGaJpEbCMtgMm2iAiqNbwjKq/3790sWcrBUiYLiXIIgoHHjxrh06RLi4uKefkA+qampOHHiBHr16mV0FxJTqQ25bt++bbQKRm5idW6gW7NmTQCAp6en5OI7S+V+bWJqxpqIyOoKWdJrVRfg1UZyeKjMT1KUpve6OOG9Lk7PpK/iUDjI8HwXb/MVRvqZ31cIz5rOaDM2SFJW9TkvVH3O9LUo1VpXRs/WlSVllVv6oHJL6QROp11dn9q3V7uqePHaAAtHrFf/5NNXYSoJ1aCGUA1qaPFxjhNegOOEF8pgRGZcjARavvvs+qNi+fe//22yPCkpCceOHcPFixcxe/bsYrdvUVB85swZhISEGC56y5WVlYUzZ84AyEthKCrZk/UJC17vFx8fjx07dpg9bvPmzXjppZckF9rt27cPtWrVMqRWdOvWDcuXL8fKlSvRsmVLODlJ/1CnpaVBqVRCqVQiMzMToigafcLQarXYunUrAH2ONBGRTRAEiP8qlXkPooqvRW1A3AYIA609kjJny+kTuem7BXl5eaFOnTr49ttvMWbMmGK3b9FfzC+//BLJycno0KEDgoKC4OTkhIcPH2Lv3r2Ijo5G7969ERQU9PSG8nFxcUGbNm2wZ88eODo6olGjRoiJiUF4eDhq1KghyT3OT6vVYvTo0YYl2bZv347s7GzMmjXLUKdq1aqYPXs25s+fj8GDB6NXr17w9fVFYmIibt68iSNHjmDr1q2oXr06oqOjMXbsWHTp0gW1atWCh4cH4uLisG/fPty5cwd9+vRB8+bNLTo3IiIiovLEltMniptOW1QWBcUzZszA0aNH8eeff+LQoUNIS0uDq6srgoKCEBYWhr59+xZrEJ988gmWLVuG48ePY/fu3ahZsyYmTpwIhUKBefPmmTxm3rx52L59OzZs2IDU1FQEBQVhzpw5aNOmjaRev3794O/vj02bNiE8PBypqanw9PRErVq1MGHCBENyfNWqVdGrVy/8+eefOHLkCNLT0+Hq6op69eph9OjR6NmzZ7HOjYiozImicQpF0VfbJCI7YsszxWXNonWKy4PcdYp37tyJ6tWrW3s4RERWZ26dYnGWg+kDiMg0c+kTFWid4oPCesl2F3GEVcZRFNHR0cU6zt/fv1jHMeGMiIiIyE7Y0kyxqTvYFYW2wI12iopBMREREZGdsKWF59auXVusoLi4GBQTERER2Ymi3wXR+kaMGPFM+7PoNs/lwbhx43D+/HnmExMRERFZSBSkD8rDmWIiIiIishknT57ExYsXkZycbLRMmyAI+Oijj4rVLoNiIiIiIjthS+kTBSUkJKB37944d+4cRFGEIAiGm7/l/rskQbHNpU8QERERlQlTS689Xvfsx1GGRJn0YUtmzZqFy5cvY/PmzYiMjIQoiti3bx+uX7+O8ePHo1mzZnjw4EGx27exp4OIiIioDInh0oe3h7VHVKpEuSB52JL//e9/GDduHF577TW4ubkBAGQyGYKCgvDNN98gICAA06ZNK3b7DIqJiGzcwg6C9A52oojxTW3rzY6I6GmSkpLQqFEjAICrqysAIC0tzbC/e/fu2LdvX7HbZ1BMRGTjZrVW4PFEwAeJ8EYyYsYCK3rwkhEiMqaTCZKHLalevTpiY2MBAI6OjqhSpQouXbpk2H///v0SrWvMv5pERBWAmxL41P1nAEAl55FWHg0RlVe2lkecX4cOHbB//3588MEHAIDXXnsNCxcuhFwuh06nw+LFi9GjR49it8+gmIiIiMhO2PLqEzNmzMD+/fuRnZ0NR0dHzJ07FxEREYbVJjp06IBly5YVu30GxURERER2wpZv2NGkSRM0adLEsO3l5YUDBw4gKSkJcrnccPFdcdnwJDoRERER2YurV6+aLPf09CxxQAwwKCYiIiKyG6JMkDxsSePGjdG0aVP85z//wc2bN0u9fQbFREQVwLFoYFzKcIxLCcPO0n+vIKIKQidIH7ZkxYoVqFy5Mj7++GPUq1cPLVu2xKJFi3Dnzp1SaV8QxfyLWxIRka3p+n8aHLwvAsh9hxNR113A9bG8bISIpLZV/VGyHfpwiJVGUnwPHz7E1q1b8dNPP+HkyZMAgFatWmHIkCEYPHgwqlevXqx2GRQTEdk44QuNyXJxJoNiIpKqCEFxfvfv3zcEyOfOnYMgCFCr1cVqi+kTRERERHZCFKQPW+fr64tGjRqhQYMGcHZ2hk6nK3ZbnEYgIiIishNiCe74Vl6IoogjR45gy5Yt+PnnnxEfHw8vLy8MGTIEr732WrHbZVBMRERkzsmrQLsP9f9WCEDWT4Bcbt0xEZWArV1cl9/x48fx008/Ydu2bYiLi4O7uzv69++P1157DV27doVCUbKwlkExERGRKYkpeQExAGhEQDEYEMOtNyYiO9axY0e4urqib9++eO2119CzZ08olcpSa59BMRERkSneI0yXz/oOWDTqmQ6FqLTY2trE+W3duhW9e/eGk5NTmbTPC+2IiIgs8cVua4+AqNhs+UK7QYMGlVlADHCmmIiIiMhuVIQL7coKg2IiIiIiO2HLF9qVNaZPEBEREZHds+ugeOzYsejbt2+R6j548AAhISFYuXJlGY+KiIiIqGyIgiB5UB6L0idCQkKKXHfnzp3Fvvc0EREREZU+W7u47lmyKCj+97//Ldn+448/8PPPP2PAgAFo3ry5ZJ+Xl1fJR1eO+Pr64uTJk5Bz0XYiIiKyUTobnx1OSUnB8uXLcfjwYcTFxWHlypVo1aoVEhISsH79evTr1w9BQUHFatuioLhXr16Sba1Wi59//hlNmzY12lfRCIIAR0dHaw+DiKhoRBH1V6oh1+ng4yzgv90VaFlNwPYILQ7d0qJBFRneaqmAizLvDfL0LTV+/jMHlVwEhLV1QjWPwjPsIq+m49KpZCiVAgQAOVk6NGnrgTpNXPH4Tgau7ImFTq2DSgFkJ+Wgegsv1O1eDUIx35RFUUTilptIO/YADpWUkKVlQ1DK4DGyMRzrexvqaWNTkbX6PHRx6RC8VRAfZUBWSQUhLROCDJCrBCAhHfLOdSELbQ7xQhTEd34C4lMgaHMgxKUAaRkAANsOH4gqlnv37qFjx464e/cu6tati7///htpaWkAAG9vb6xcuRJ37tzBkiVLitV+qa4+kZOTg86dO6Nr166YN2+eofzTTz/Fzz//jCFDhmDmzJmG8vfeew+nTp3CwYMHDbfme/DgAVasWIGzZ88iNTUVVapUQffu3TFq1Kgir0138eJFrFmzBhEREdBoNAgICMDgwYPRv39/k/Xv3buHL7/8EhcuXAAAPP/885g2bRr8/PwMdR48eIB+/fphzJgxGDdunKVPDRHRM/dPEvSXmseLaP2dGq/XE/HDn1rD/o1/aHB6vBPkMgE//p6N8ZvSDPvWnszCsVmeqOpuOjD+/XAiflx2DxBFyMS84PHU/x6j60Af/LUxEppsLZSZOZDrdACAK9vu4sEfieg0u2GxzufupGOIX/EXZNDBEWpDn4lL/4D/sdeger4atLGpSGyxArqYVKPjBeiggAYCRDggC9oVxyF/vTnkW05C0IkQoHlSUwfka5+oIrHl9IlZs2YhNTUVf/75J6pUqYIqVapI9vfv3x+//vprsdsv1QvtlEolmjZtivPnz0vKf//9d8hkMvz++++GMlEUceHCBTRr1swQEMfExCAsLAwHDhxAjx49MGPGDDRo0ADr1q3DlClToNFo8DTHjh3DhAkTEBUVhTfffBMTJ06EQqHA/Pnz8c033xjVz8zMxLhx4+Dg4IC3334b/fr1w8mTJzFq1CjEx8eX8BkhIrKyJ2+AOp2IzfkCYgD4/b4Ov93Ql33xW4Zk38MUERvPZJlt9sC2OEPzBd9jj/8aD02ODjKtzhAQ5/or/B4yE3MsPg11XAbiV0UAABTQSvoUs7RI+FI/qZH13QWTATEAiJBBfDJiLRz0hT+egaAToQ+ExSc1tQyIqcKy5QvtfvvtN0yZMgUNGzY0+Y1T7dq1cffu3WK3X+qrT4SEhODhw4eIjo4GAMTGxuLevXvo0aMHbt26hcePHwMAbt26hYSEBDz//POGY7/55hskJiZi0aJFeOeddzB48GAsWLAAw4YNw8WLF58a/Wu1WixcuBAqlQobNmzAmDFj8MYbb2DNmjVo2rQpNmzYYBhXrqSkJLz00kv4/PPPMXjwYLzzzjv4z3/+g8ePH2PVqlWl/OyUroSEBGRnZxu209LSkJqa92aQk5NjeL5zxcTEFLodGxsLURQN2+yDfbCP8t9HXjBnQr43DlO1Hmfq+0hI0xntS0gXzZ5HWorabKNqtfnhiFoR2Wlqi58rbXIOoNV3JpjoVPs4CwkJCVA/SjPaZ3IcT/4viPnbEgrsNS07378r8s8V+yi7PqzJloPizMxMVK5c2ez+/K9LcZR6UJwb5ObOCv/++++Qy+UYN24cBEEwlOfOJueuaKHT6XDs2DHUq1cP7dq1k7Q5YsQIyGQyHDlypNC+r127htjYWPTr10/ypDk4OGD48OHQ6XQ4evSo0XFhYWGS7c6dO6NWrVom65Yn3t7ekjxnV1dXuLm5GbaVSiUqVaokOcbX17fQ7WrVpPl+7IN9sI/y30ehma+5b+6CgEBvaT03R6BXsBze3t4Y2EJ6zYQgAP2bKc2eR/N2+oupRcE4hAysq09108llRvsq13eHZ00Xi58rp7qeUDX3AQBoYXzBs/trwfD29obLkOckHwSkRENALYd+hlwXWPVJiQx5Z1L4W2P+Z6oi/1yxj7Lrw5ps+TbPDRs2xLFjx8zu37Fjh9HCD5Yo9aC4YcOGcHFxMQS9v//+Oxo0aAA/Pz8EBQVJyj08PFCvXj0AQGJiIjIyMlC7dm2jNj08PODj44P79+8X2veDBw8AwGQbderUAQCjNtzc3ODj42NUPzAwEI8fP0ZmZubTTpmIqJwSAY0IRwUwuZUcJ8Y4YVAjObxUwAv+MuwJc4K3s/5d8ZNXXDCmvRMquwqoX02O1cNc0SrQwWzL/Ub44oWe3nD1UMDdxwEePg5w8ZCjTU9vjPx3EDqOC4S7rxMUNVzhWl0FR3cFAjtWQe8vmhX7bOrs6AWPVwIheqqAWp6QV3WGopY7Ki9oB89RTQAADm1qwv2HUMgbVobg4wxZgCfg6QR5LQ84VHGCrJorFLVcIfdSQjbwOSiPz4IwpRtERwfooHjy+UL2JNWCiMqTadOm4ccff8Tnn3+O5ORkAPpJ1Zs3b2LYsGE4ffo0pk+fXuz2S/02zwqFAs2aNcP58+chiiLOnz+P3r17A9DPCh87dgw6nQ4XL15ESEhIsa9CJiKiQggCxH8ZB7Xbhpq+YFmlFLAo1AWLQl2K1LzSUYZBY2tg0NgaJve3HloTrYfWLPp4i9Knvxvq7Hj6SkdOrzeF0+tNi9yusGQosGSoiR0DLRkekU0QZbYbd7355pu4c+cOPvzwQ3zwwQcAgJ49e0IURchkMvznP/8xu6hCUZR6UAzoUyhOnjyJgwcPIi4uzpBS0apVK/zf//0fDh06hNTUVEk+sZeXF1xcXBAZGWnUXkpKCuLj4xEcHFxovzVq6P84m2ojtyy3Tq7U1FTEx8cbzRbfvn0b3t7eUKlURThjIiIiovLP1vKIC/rggw8wbNgwbN++HTdv3oROp0OdOnUwcOBAk5kCliiT2zzn5gmvXLkSSqUSzz33HACgefPmkMvlhgvY8gfFMpkM7du3xz///INTp05J2lu/fj10Oh06depUaL/169dHtWrVsGvXLsnKERqNBhs3boQgCOjYsaPRcRs2bJBsHz58GHfu3DFZl4iIiMhWiTJB8rAVGRkZaNmyJb799lv4+/tj+vTp+Oabb7BixQrMnDmzxAExUEYzxfXq1YOHhwdu376Nli1bGhLUXV1d0aBBA/z111/w8fFBYGCg5LhJkybh7NmzmDlzJkJDQ1GzZk1cvHgR+/fvR4sWLdCnT59C+5XL5Xj33Xcxa9YshIWFYcCAAXB2dsb+/ftx5coVjBw5Ev7+/pJjPD09cejQITx69AgtW7ZEdHQ0tm3bhkqVKnE9YiIiIqJywNnZGbdv3y7TtNsymSkWBAEtWrQAIJ0Nzr+dO5ucn6+vL9avX48uXbpgz549+O9//4urV69i5MiRWLp0qWE948J06NABy5cvR61atbBx40Z8/fXXyM7OxocffohJkyYZ1VepVFi5ciVycnLw9ddf45dffkHbtm2xZs0akxfgEREREdksQZA+bEjPnj2xb9++MmtfEEWRF9gWwb1799C/f3+MHz8eo0ePtvZwiIgMhC9M39hInFkmXwbaj8IutBPDn904iErRiqbSez5MuFz4t/DlybVr1zB48GA0b94c48aNQ2BgoMlrv7y9vU0c/XT8i1lEjx49AlD8J5qIiIjI2mz5QrtGjRoBAK5evYrNmzebrafVas3uKwyD4qfIzMzEvn378Msvv0Aul6NVq1bWHhIREVmTn4e1R0Bklz7++OMyzSlmUPwUiYmJWLBgAWrWrIlPP/0Ufn5+1h4SERE9Cx/0Bz7dYVx+d92zHglRqRGFMrmc7JmYO3dumbbPoPgpqlevjjNnzlh7GERE9KzNHw6sPADEp+WVze5vteEQlQZbWobtWWNQTEREZM6j7609AqJSZcs5xf/+97+fWkcQBHz00UfFap+rTxAR2TiuPkFERbUsRLqk2eTzPaw0EsvJZOZTPwRBgCiKEASh2Bfa2W5iCRERERHZDZ1OZ/TQaDS4desWpk+fjpCQEMTFxRW7fQbFRERERHZCFATJw9bJZDIEBgbiiy++QN26dTF58uTit1WK4yIiIisQZyrgBBF48pBBZOoEEZkkygTJoyLp0KED/ve//xX7eAbFREQVQMpUYKX7Oqx0X4esqdYeDRGVVxVtpji/8+fPF5p3/DScSiAiIiKicu/7702vBpOUlIRjx44hPDwco0ePLnb7DIqJiIiI7IQtzw6PGDHC7D4fHx/Mnj0bH3/8cbHbZ1BMREREZCdsOSi+ffu2UZkgCPDy8oKbm1uJ22dQTERERGQnbDkoFgQBlStXhkqlMrk/MzMTjx49gr+/f7Ha54V2REQVRJLGEUkaJ2sPg4jKMVu+0C4wMBA///yz2f07d+5EYGBgsdvnTDERkY1LzdLA/WsAGAoA+NcSIGqUBrW8+CeeiCqOp92EWa1Wc/UJIiJ7pg+IpTM+Ad8B4kyrDIeIyjFbmx1OSUlBUlKSYfvx48eIjo42qpeUlIQff/wRvr6+xe6LQTERERGRnbC1G3Z89dVX+Pe//w1An1M8bdo0TJs2zWRdURQxf/78YvfFoJiIiIjITtjaTHH37t3h6uoKURTx7rvv4vXXX0eLFi0kdQRBgIuLC1q2bImQkJBi98WgmIiIiIjKpbZt26Jt27YAgPT0dAwaNAiNGzcuk74YFBMRERHZCVubKc5vzpw5Zdo+g2IiouLQaoHG04CMbODqEsDF9LqZRETliS0HxblOnjyJixcvIjk5GTqdTrJPEAR89NFHxWqXQTERkaW+3QNMWJ237foGMLg18NO/rDcmIqIisOWgOCEhAb1798a5c+cgiiIEQTAs05b775IExbx5BxGRpfIHxLm2nn324yAisiOzZs3C5cuXsXnzZkRGRkIURezbtw/Xr1/H+PHj0axZMzx48KDY7TMoJiIiIrITtnxHu//9738YN24cXnvtNbi5uQEAZDIZgoKC8M033yAgIMDscm1FwaCYiIiIyE7YclCclJSERo0aAQBcXV0BAGlpaYb93bt3x759+4rdfrkOiseOHYu+fftaexhEREREFYIoSB+2pHr16oiNjQUAODo6okqVKrh06ZJh//379yGUINAvlQvtsrKyEB4ejkOHDiEyMhLp6enw8PBA/fr10a1bN7z88stQKGzjmr6MjAxs2rQJ165dwz///IO4uDi0aNECq1atsvbQiIiIiErE1maH8+vQoQP279+PDz74AADw2muvYeHChZDL5dDpdFi8eDF69OhR7PZLHKnevXsXU6dORXR0NFq1aoURI0bA09MTCQkJOHfuHObNm4fIyEhMnTq1pF09E0lJSVi1ahUqVaqE+vXr4/Hjx9YeEhEREZHdmzFjBvbv34/s7Gw4Ojpi7ty5iIiIMKw20aFDByxbtqzY7ZcoKM7KysK0adNw//59LFy4EC+99JJk/4gRIxAREYGrV6+WpJtSlZ6eDhcXF7P7fXx8sHv3blStWhUA0L59+2c1NCIiIqIyZcszxU2aNEGTJk0M215eXjhw4ACSkpIgl8sNF98VV4mC4h07duDOnTsICwszCohzNWrUyJAUnevIkSP4/vvvcf36dQiCgLp162L48OHo1KlTkfq9ePEi1qxZg4iICGg0GgQEBGDw4MHo37+/pN7YsWMRExODFStWYOnSpTh//jxSUlJw/vx5s20rlUpDQExERERUkehsOCg2x9PTs1TaKdGFdocOHQIADBgwoMjHbN26FTNnzkRKSgpGjx6NUaNGISUlBTNnzkR4ePhTjz927BgmTJiAqKgovPnmm5g4cSIUCgXmz5+Pb775xqh+RkYGxo0bB7lcjokTJ2Ls2LFFP0EiIiKiCkSEIHnYmujoaIwfPx716tWDt7c3jh07BgCIj4/HlClT8McffxS77RLNFN+6dQsuLi7w8/MrUv2UlBQsXboUfn5+WL9+vWE5jdDQULzxxhtYvHgxunXrZnb6W6vVYuHChVCpVNiwYQMqV64MAHj11Vcxbtw4bNiwAX379oW/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",
      "text/plain": [
       "<Figure size 800x430 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "c_preds_total_train = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "for X_train, c_train, y_train in train_dl:\n",
    "    \n",
    "    y_prime = randomize_class(y_test, include=False)\n",
    "    if y_train.shape[-1] == 1:\n",
    "        y_prime = None\n",
    "    (c_preds, y_preds, explanations,\n",
    "    c_cf, y_cf, y_cf_target, explanation_cf, \n",
    "    p_z2, qz2_x, pz3_z2_c_y, qz3_z2_c_y_y_prime,\n",
    "    pcprime_z3, py_c, py_c_cf, pc_z2, c_cf_true, weights, z2, z3, c_pred_d) = net.forward(X_train, test=True, y_prime=y_prime, explain=True, include=False, inference=True)\n",
    "\n",
    "    if not net.bool_concepts:\n",
    "        c_preds = torch.sigmoid(c_preds)\n",
    "\n",
    "    c_preds_total_train = torch.cat((c_preds_total_train, c_preds), dim=0)\n",
    "\n",
    "idx = CLASS_TO_VISUALISE[str(c_preds_total_train.shape[-1])]\n",
    "print_concept_importance(net, idx, c_preds_total_train, c_preds_total, show=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing mesures sampling more than once"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------5 SAMPLES-----------------\n",
      "CF Time 5 samples:  0.05852007865905762\n",
      "Variability 5 samples:  1.3243243243243243\n",
      "IOU 5 samples (%):  65.38461538461539\n",
      "Proximity 5 samples (%):  1.4090401785714286\n",
      "Delta Sparsity 5 samples (%):  4.310825892857143\n",
      "--------------10 SAMPLES-----------------\n",
      "CF Time 10 samples:  0.0797576904296875\n",
      "Variability 10 samples:  1.3333333333333333\n",
      "IOU 10 samples (%):  58.490566037735846\n",
      "Proximity 10 samples (%):  1.3950892857142858\n",
      "Delta Sparsity 10 samples (%):  4.401506696428571\n",
      "--------------100 SAMPLES-----------------\n",
      "CF Time 100 samples:  0.543816328048706\n",
      "Variability 100 samples:  1.3714285714285714\n",
      "IOU 100 samples (%):  62.745098039215684\n",
      "Proximity 100 samples (%):  1.5904017857142856\n",
      "Delta Sparsity 100 samples (%):  4.408482142857143\n"
     ]
    }
   ],
   "source": [
    "n_times_list = [5, 10, 100]\n",
    "for n in n_times_list: \n",
    "    print(f'--------------{n} SAMPLES-----------------')\n",
    "    c_preds_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "    c_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "    y_preds_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "    y_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "    for X_test, c_test, y_test in test_dl:\n",
    "        y_prime = randomize_class(y_test, include=False)\n",
    "        (c_preds, y_preds, explanations,\n",
    "        c_cf, y_cf, y_cf_target, explanation_cf, \n",
    "        p_z2, qz2_x, pz3_z2_c_y, qz3_z2_c_y_y_prime,\n",
    "        pcprime_z3, py_c, py_c_cf, pc_z2, c_cf_true, weights, z2, z3, c_pred_d) = net.forward(X_test, test=True, y_prime=y_prime, explain=True, include=False, resample=n)\n",
    "\n",
    "        c_preds_total = torch.cat((c_preds_total, c_preds), dim=0)\n",
    "        c_total = torch.cat((c_total, c_test), dim=0)\n",
    "        y_preds_total = torch.cat((y_preds_total, y_preds), dim=0)\n",
    "        y_total = torch.cat((y_total, y_test), dim=0)\n",
    "\n",
    "    cf_time, cf_found, cf, c_preds_total, y_cf_total = net.counterfactual_times(test_dl, accelerator, rerun=False, n_times=n, return_cf=True)\n",
    "    print(f'CF Time {n} samples: ', cf_time)\n",
    "    \n",
    "    cf_variability = variability(cf.cpu(), c_preds_total.cpu())\n",
    "    print(f'Variability {n} samples: ', cf_variability)\n",
    "    cf_iou = intersection_over_union(cf.cpu(), c_preds_total.cpu())\n",
    "    print(f'IOU {n} samples (%): ', cf_iou*100)\n",
    "    mean_distance_train = distance_train(cf.cpu(), c_cf_set.cpu(), y_cf_total.detach().cpu(), concept_labels.cpu()).item() / cf.shape[-1]\n",
    "    print(f'Proximity {n} samples (%): ', mean_distance_train*100)\n",
    "    hamming_distance = torch.norm((c_preds_total>0.5).float().cpu() - (cf>0.5).float().cpu(), p=0, dim=-1).mean().item() \n",
    "    delta_sparsity = abs(hamming_distance - oracle_sparsity) / c_cf_total.shape[-1]\n",
    "    print(f'Delta Sparsity {n} samples (%): ', delta_sparsity*100)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing metrics for task driven interventions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------0.1 NOISE LEVEL-----------------\n",
      "ROC AUC Task Accuracy 0.1 noise level (%):  98.45068273239454\n",
      "ROC AUC Task Accuracy CF 0.1 noise level (%):  100.0\n",
      "Accuracy Intervention 0.1 noise level (%):  79.39453125\n",
      "Proximity Intervention 0.1 noise level (%):  0.32784598214285715\n",
      "--------------0.2 NOISE LEVEL-----------------\n",
      "ROC AUC Task Accuracy 0.2 noise level (%):  67.41483394068133\n",
      "ROC AUC Task Accuracy CF 0.2 noise level (%):  100.0\n",
      "Accuracy Intervention 0.2 noise level (%):  79.443359375\n",
      "Proximity Intervention 0.2 noise level (%):  0.4045758928571429\n",
      "--------------0.5 NOISE LEVEL-----------------\n",
      "ROC AUC Task Accuracy 0.5 noise level (%):  78.32774817337803\n",
      "ROC AUC Task Accuracy CF 0.5 noise level (%):  99.99468952004248\n",
      "Accuracy Intervention 0.5 noise level (%):  79.345703125\n",
      "Proximity Intervention 0.5 noise level (%):  0.34877232142857145\n",
      "--------------1.0 NOISE LEVEL-----------------\n",
      "ROC AUC Task Accuracy 1.0 noise level (%):  0.6957549475907374\n",
      "ROC AUC Task Accuracy CF 1.0 noise level (%):  99.9695664502503\n",
      "Accuracy Intervention 1.0 noise level (%):  78.759765625\n",
      "Proximity Intervention 1.0 noise level (%):  0.32784598214285715\n"
     ]
    }
   ],
   "source": [
    "p_list = [0.1, 0.2, 0.5, 1.0]\n",
    "for p in p_list:\n",
    "    print(f'--------------{p} NOISE LEVEL-----------------')\n",
    "    c_preds_total_noise = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "    c_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "    y_preds_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "    y_prime_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "    y_cf_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "    c_cf_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "    for X_test, c_test, y_test in test_dl:\n",
    "        y_prime = y_test.clone()\n",
    "        y_cf_logits, c_cf, y_preds, c_preds = net.predict_counterfactuals(\n",
    "            X_test, y_prime=y_prime, resample=1, return_cf=True, auto_intervention=p, full=True\n",
    "        )\n",
    "\n",
    "        c_preds_total_noise = torch.cat((c_preds_total_noise, c_preds), dim=0)\n",
    "        c_total = torch.cat((c_total, c_test), dim=0)\n",
    "        y_preds_total = torch.cat((y_preds_total, y_preds), dim=0)\n",
    "        y_prime_total = torch.cat((y_prime_total, y_test), dim=0)\n",
    "        y_cf_total = torch.cat((y_cf_total, y_cf_logits), dim=0)\n",
    "        c_cf_total = torch.cat((c_cf_total, c_cf), dim=0)\n",
    "    \n",
    "    task_accuracy = roc_auc_score(y_prime_total.cpu(), y_preds_total.detach().cpu())\n",
    "    print(f'ROC AUC Task Accuracy {p} noise level (%): ', task_accuracy*100)\n",
    "    task_accuracy_cf = roc_auc_score(y_prime_total.cpu(), y_cf_total.detach().cpu())\n",
    "    print(f'ROC AUC Task Accuracy CF {p} noise level (%): ', task_accuracy_cf*100)\n",
    "    cf_concept_acc = (c_cf_total > 0.5).float().eq(c_total).float().all(dim=-1).float().mean().item()\n",
    "    print(f'Accuracy Intervention {p} noise level (%): ', cf_concept_acc*100)\n",
    "    mean_distance_train = distance_train(c_cf_total.cpu(), c_cf_set.cpu(), y_cf_total.detach().cpu(), concept_labels.cpu()).item() / c_cf_total.shape[-1]\n",
    "    print(f'Proximity Intervention {p} noise level (%): ', mean_distance_train*100)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# dSprites with high correlation between color and task"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Counterfactual CBM "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !python3 experiments/dsprites/save_embeddings_mod.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = 'CFCBM'\n",
    "\n",
    "# Set seed\n",
    "seed_everything(seed, workers=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Loading modified data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load train data\n",
    "dataset_name = 'dsprites_mod'\n",
    "X, c, y = load_data(dataset_name)\n",
    "if len(y.shape) == 1:\n",
    "    y = y.unsqueeze(1)\n",
    "    # Unique [concepts, labels]\n",
    "    c_cf_set = torch.unique(torch.cat((c, y), dim=-1), dim=0)\n",
    "    concept_labels = c_cf_set[:, -1]\n",
    "    c_cf_set = c_cf_set[:, :-1]\n",
    "else:\n",
    "    c_cf_set = torch.unique(torch.cat((c, torch.argmax(y, dim=-1).unsqueeze(-1)), dim=-1), dim=0)\n",
    "    concept_labels = c_cf_set[:, -1]\n",
    "    c_cf_set = c_cf_set[:, :-1]\n",
    "    concept_labels = one_hot(concept_labels.long(), num_classes=y.shape[1]).float()\n",
    "\n",
    "# Load test data\n",
    "X_test, c_test, y_test = load_data(dataset_name, split='test')\n",
    "if len(y_test.shape) == 1:\n",
    "    y_test = y_test.unsqueeze(1)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Creating directories for results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# creates directory for results\n",
    "results_root_dir = f\"./results/\"\n",
    "os.makedirs(results_root_dir, exist_ok=True)\n",
    "results_dir = f\"./results/{dataset_name}/\"\n",
    "os.makedirs(results_dir, exist_ok=True)\n",
    "figures_dir = f\"./results/{dataset_name}/figures/\"\n",
    "os.makedirs(figures_dir, exist_ok=True)\n",
    "log_dir = f\"./results/{dataset_name}/logs/\"\n",
    "os.makedirs(log_dir, exist_ok=True) "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Setting up dataloader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create DataLoader\n",
    "train_data = TensorDataset(X, c, y)\n",
    "train_dl = torch.utils.data.DataLoader(train_data, batch_sampler=torch.utils.data.BatchSampler(RandomSamplerClassBatch(y, batch_size=batch_size, replacement=False), batch_size=batch_size, drop_last=True), pin_memory=True)\n",
    "test_data = TensorDataset(X_test, c_test, y_test)\n",
    "test_dl = torch.utils.data.DataLoader(test_data, batch_sampler=torch.utils.data.BatchSampler(RandomSamplerClassBatch(y_test, batch_size=batch_size, replacement=False), batch_size=batch_size,  drop_last=True), pin_memory=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Choosing and training the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: True (mps), used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "MPS available but not used. Set `accelerator` and `devices` using `Trainer(accelerator='mps', devices=1)`.\n",
      "`Trainer(limit_train_batches=1.0)` was configured so 100% of the batches per epoch will be used..\n",
      "`Trainer(limit_val_batches=1.0)` was configured so 100% of the batches will be used..\n",
      "Global seed set to 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running CounterfactualCBM_V3(\n",
      "  (cross_entropy): BCEWithLogitsLoss()\n",
      "  (bce): BCELoss()\n",
      "  (bce_log): BCEWithLogitsLoss()\n",
      "  (model): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "    (4): Linear(in_features=128, out_features=1, bias=True)\n",
      "  )\n",
      "  (encoder): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "  )\n",
      "  (relation_classifiers): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=7, bias=True)\n",
      "  )\n",
      "  (reasoner): Sequential(\n",
      "    (0): Linear(in_features=7, out_features=1, bias=True)\n",
      "  )\n",
      "  (classification_loss): BCELoss()\n",
      "  (concept_mean_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_mean_z3_predictor): Sequential(\n",
      "    (0): Linear(in_features=136, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_z3_predictor): Sequential(\n",
      "    (0): Linear(in_features=136, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_mean_qz3_predictor): Sequential(\n",
      "    (0): Linear(in_features=137, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_var_qz3_predictor): Sequential(\n",
      "    (0): Linear(in_features=137, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "  )\n",
      "  (concept_predictor): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=7, bias=True)\n",
      "  )\n",
      "), epochs=90, learning_rate=0.005\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "   | Name                       | Type              | Params\n",
      "------------------------------------------------------------------\n",
      "0  | cross_entropy              | BCEWithLogitsLoss | 0     \n",
      "1  | bce                        | BCELoss           | 0     \n",
      "2  | bce_log                    | BCEWithLogitsLoss | 0     \n",
      "3  | model                      | Sequential        | 82.3 K\n",
      "4  | encoder                    | Sequential        | 82.2 K\n",
      "5  | relation_classifiers       | Sequential        | 903   \n",
      "6  | reasoner                   | Sequential        | 8     \n",
      "7  | concept_mean_predictor     | Sequential        | 33.0 K\n",
      "8  | concept_var_predictor      | Sequential        | 33.0 K\n",
      "9  | concept_mean_z3_predictor  | Sequential        | 34.0 K\n",
      "10 | concept_var_z3_predictor   | Sequential        | 34.0 K\n",
      "11 | concept_mean_qz3_predictor | Sequential        | 34.2 K\n",
      "12 | concept_var_qz3_predictor  | Sequential        | 34.2 K\n",
      "13 | concept_predictor          | Sequential        | 17.4 K\n",
      "------------------------------------------------------------------\n",
      "385 K     Trainable params\n",
      "0         Non-trainable params\n",
      "385 K     Total params\n",
      "1.541     Total estimated model params size (MB)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "20defe69e14546549a3d6c0a93ff2bd8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Sanity Checking: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The dataloader, val_dataloader 0, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The dataloader, train_dataloader, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The number of training batches (7) is smaller than the logging interval Trainer(log_every_n_steps=50). Set a lower value for log_every_n_steps if you want to see logs for the training epoch.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "244ea014c9224980afc1210c50e5272c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Training: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c9c1268ca7e345dc920782bbfdeb6c26",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b326b215d5a04d4e88e312878df0ec1d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "149adeb90464407dbea530ffc245ef25",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f406873ea7ad4492b96d8bf237138881",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5cf7e9225db0484ea95a1e07ab7a94b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0deb717ead8d406cb6d2454c3710be73",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d7f2d7dac44d4ed28f26357b1871ea65",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "20c7df5fdf1143dda472fb5c52c0863f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "941ab9a29dd54deab4b5f65c113cb498",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3cb7d1cf220d4c6bbeb37a06688821ff",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f20045f8088c49efb256324f5c2ff097",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "14824d0edc6a494ca75e1b0e41cc4daa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b02002b71a1142958b0d98e3dbfc0a2c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "41ec870e80a743ba9728474daa72c7bc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0f0946cba56b4996b85df564419ca6ec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "32e9d06242024ea0b4288fe331cf8d31",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bb6db63dc0b143ecafa785749648cb77",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "47687bde1ca34b5a8ca06d4bee306c20",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59aa5abfbe83424d85188a0854507772",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "21e5c7bc42a84d8591fc480c3735adf4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6cc9ae8990664238a78831aea9c30a98",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b7eb0ea0fb394ccfb83473f636f5d5ec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "426e45df289845d5b2d7d872f9f129a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c38c82283ce94b70b86a1bded6388e53",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ab7e6fa38bc42bda552e8d810068a90",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f49fa52b6d3d4ceda81eacc87e9ba76c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e33abd0900fb4d89944351e1687c5951",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1e593b0a23a74c219cafe12613cfdb11",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "75b07e29ec3447078ba79586e1139449",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bc7f0f4cad1144a5a00fcfec17e0de96",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0cbcfbd144834537a2c8b89191f97589",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f65f1d34c71428db85758f78d96deb7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e2f60f0b03fe477a942296a2ccbaf8cc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "85f9ef214d244bc2b3e803bed4856cdf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ba72d611b8924cb99e315886875be2b9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f0e513e03fbe4363b539b8e607c3d5f3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c1361108a6fd4d859539a82f7b63754f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "01072a73bf4d43159c38504a073614a0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d696aa9485f14849869a96ddd50b2144",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8d1c5d98decd47eeb42691c58295850d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3d46bbe781344020809e0a8c02f5826b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c758a69827d048c7bd282bad0efc0744",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6efd50cd5d0448e4b2a974c18f852e20",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd5b6834de0c4881803e796f4b709b0f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1e4b4ffb9d4c4ce8ba05a80f982dadf3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "df939c7a336443e2ba0ba73ec1eb4014",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "88110eff398b4402ae5a0a4476139511",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "83698d032f6c49dfa600e52ccfb7b707",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f92e216ea7004909aef5afc084f60d50",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8682a64f9d4a47f3b8b1baee65b770d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0b3b8bbdda644b08af72f8023ad46727",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9fccc8cf616c47dda961bd63227b6018",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4bf408a96717434084e835ad7fec16e5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "29f433a376df48b884e3acb8327aec65",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e64778d597b40e3ac989007c8ab64e8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "035fefef8ee248098aa8b3a1692fb304",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4fb51506b49c43118c020f6663c477ef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "54a1878ca7054432ad399be227712548",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5277fe835181452b8e79b805c73763c0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "63886053800c4731b9a6c3db3bcce862",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5c1b99e6912d4565b9d6fa70db4484b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3200c043229246ebbe866bf00adfe639",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "be81d01dae17401b8380a3760fa95f77",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f66da00ddca74e26a8d873f8612a58f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4a864c5db6ac46bb81d9bc6aaabec62d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "35fbfd374eec433bad8d4f41239aa229",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "781783d364184a6f84a3768bcbcbc594",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e422eec57e90434e9d8e43406bb3e778",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "22fee1ad67fe4370b383a7582653faaa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "708939e1897a4de6b5c50c3116097d5b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c461c8aa722249b7a23f74e6acd7c34d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b849339f0066424cb66a6864e422aae2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "668132b7954749df847160017b0a0757",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd46b568f051486eaf31cb179196d58b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dab216f54fff4378807d17bffb54c7fc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b8f6bc229b541e8b35269003e9c30a3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b14f1f7b18cc48f9b909e893b8007bc8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4d1a3f0cface4b9aa7be0621a33058b6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ce143f4fd11438cbfecd14537b38f13",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e160cdf8edd4d6aaf4efdb984a79bdf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "92ac3291b3fb4ab48b3492dd6bc110d6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "accb33cc35de4161868b066478789406",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ccf4a88b55714548981b6ec44068d6e8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bd310e72b1344ce5bc0e868e4811800e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5abc698fbeef44c7bdc92a63c3c89f17",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "df14d65dc20547c488280922c2eb71c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b1f628ae5c264eb19a68bf637d5e254e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ffcc74391816488fa2bf53cca7c3ab3a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0b882577e95f4f678ae4853d82741781",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f4aa226136142cba6f158b1b70ac5ee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=90` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best train acc: 0.9216848611831665, Epoch: 88\n"
     ]
    }
   ],
   "source": [
    "# Define models\n",
    "models = {\n",
    "            'Oracle': Oracle(),\n",
    "            'DeepNN': StandardE2E(X.shape[1], y.shape[1], emb_size, learning_rate),\n",
    "            'StandardCBM': StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=False),\n",
    "            'CFCBM': CounterfactualCBM_V3(X.shape[1], c.shape[1], y.shape[1], emb_size, c_cf_set, concept_labels, learning_rate=learning_rate, resample=0, bernulli=False, deep=False, reconstruction=False),\n",
    "            'VAECF': (StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True), \n",
    "                      VAE_CF(c.shape[1], y.shape[1], emb_size, None, learning_rate)),\n",
    "            'CCHVAE': (StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "                       CCHVAE(c.shape[1], y.shape[1], emb_size, None, learning_rate)),\n",
    "            'VCNET': ConceptVCNet(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "            'BayCon': StandardCBM(X.shape[1], c.shape[1], y.shape[1], emb_size, learning_rate, bool_concepts=True, deep=True),\n",
    "        }\n",
    "net = models[model]\n",
    "net = train_model(net, 90, learning_rate, seed, train_dl, test_dl, results_dir, accelerator, wandb_logger)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Testing the model and saving the output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Testing the model \n",
    "c_preds_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "c_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "y_preds_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_cf_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_cf_target_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "c_cf_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "z2_total = torch.empty(0, net.emb_size)\n",
    "z3_total = torch.empty(0, net.emb_size)\n",
    "\n",
    "for X_test, c_test, y_test in test_dl:\n",
    "    y_prime = randomize_class(y_test, include=False)\n",
    "    if y_test.shape[-1] == 1:\n",
    "        y_prime = None\n",
    "    (c_preds, y_preds, explanations,\n",
    "    c_cf, y_cf, y_cf_target, explanation_cf, \n",
    "    p_z2, qz2_x, pz3_z2_c_y, qz3_z2_c_y_y_prime,\n",
    "    pcprime_z3, py_c, py_c_cf, pc_z2, c_cf_true, weights, z2, z3, c_pred_d) = net.forward(X_test, test=True, y_prime=y_prime, explain=True, include=False, inference=True)\n",
    "\n",
    "    c_preds_total = torch.cat((c_preds_total, c_preds), dim=0)\n",
    "    c_total = torch.cat((c_total, c_test), dim=0)\n",
    "    y_preds_total = torch.cat((y_preds_total, y_preds), dim=0)\n",
    "    y_total = torch.cat((y_total, y_test), dim=0)\n",
    "    y_cf_total = torch.cat((y_cf_total, y_cf), dim=0)\n",
    "    y_cf_target_total = torch.cat((y_cf_target_total, y_cf_target), dim=0)\n",
    "    c_cf_total = torch.cat((c_cf_total, c_cf), dim=0)\n",
    "    z2_total = torch.cat((z2_total, z2), dim=0)\n",
    "    z3_total = torch.cat((z3_total, z3), dim=0)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing common metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ROC AUC Concept Accuracy (%):  98.3177937914769\n",
      "Entire Concept Accuracy (%):  79.833984375\n",
      "ROC AUC Task Accuracy (%):  99.86408792240302\n",
      "Validity (%):  94.87202721838014\n",
      "Variability:  0.7916666666666666\n",
      "IOU (%):  48.275862068965516\n",
      "Proximity (%):  1.0672433035714286\n",
      "Delta Sparsity (%):  2.7553013392857144\n",
      "CF Time:  0.012737035751342773\n"
     ]
    }
   ],
   "source": [
    "# Compute metrics\n",
    "concept_accuracy = roc_auc_score(c_total.cpu(), c_preds_total.detach().cpu())\n",
    "print('ROC AUC Concept Accuracy (%): ', concept_accuracy*100)\n",
    "concept_acc = (c_preds_total > 0.5).float().eq(c_total).float().all(dim=-1).float().mean().item()\n",
    "print('Entire Concept Accuracy (%): ', concept_acc*100)\n",
    "task_accuracy = roc_auc_score(y_total.cpu(), y_preds_total.detach().cpu())\n",
    "print('ROC AUC Task Accuracy (%): ', task_accuracy*100)\n",
    "task_cf_accuracy = roc_auc_score(y_cf_target_total.squeeze().cpu(), y_cf_total.detach().cpu())\n",
    "print('Validity (%): ', task_cf_accuracy*100)\n",
    "cf_variability = variability(c_cf_total.cpu(), c_preds_total.cpu())\n",
    "print('Variability: ', cf_variability)\n",
    "cf_iou = intersection_over_union(c_cf_total.cpu(), c_total.cpu())\n",
    "print('IOU (%): ', cf_iou*100)\n",
    "mean_distance_train = distance_train(c_cf_total.cpu(), c_cf_set.cpu(), y_cf_total.detach().cpu(), concept_labels.cpu()).item() / c_cf_total.shape[-1]\n",
    "print('Proximity (%): ', mean_distance_train*100)\n",
    "\n",
    "pdist = torch.nn.PairwiseDistance(p=2)\n",
    "hamming_distance = torch.norm((c_preds_total>0.5).float().cpu() - (c_cf_total>0.5).float().cpu(), p=0, dim=-1).mean().item() \n",
    "oracle = Oracle()\n",
    "oracle_results, oracle = train_oracle(oracle, test_dl, c_cf_set, concept_labels, wandb_logger)\n",
    "oracle_sparsity = oracle_results['hamming_distance']\n",
    "delta_sparsity = abs(hamming_distance - oracle_sparsity) / c_cf_total.shape[-1]\n",
    "print('Delta Sparsity (%): ', delta_sparsity*100)\n",
    "\n",
    "cf_time_total, cf_found = net.counterfactual_times(test_dl, accelerator, rerun=False)\n",
    "print('CF Time: ', cf_time_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_set_c_and_cf(c_preds_total, y_preds_total, y_cf_total, c_cf_total, model, fold, log_dir)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing concept importance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n"
     ]
    },
    {
     "data": {
      "image/png": "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bZw+fRrfffedThszZszA888/Dw8PD80fYkIIREZG4sqVKzh06BD27NmDiIgIk/pGRGagYmdvEFFV9cILL2jN2bSxsREHDx4s8pz169cLSZL0zvk0NKdYCCEGDBhgcK6oTCYTzz77rJg4caL4/vvvxeXLl02an1pQ4TnFeY9q1aqJv//+2+B5arVaLFy4UOe8GTNmFNmeoTm+Dg4ORT4v+hRnTnFRbRecz2yMX375RaseSZLE0qVLhVqtLvK8W7duicaNG2udO3XqVIPHT5o0SevYQYMGiZycnGLFqFarxR9//CEePHhgVN+IyDwwKSYio508eVIngfvxxx+Lde6iRYuMTorj4uJEw4YNi30hmL29vejZs6f49NNPRXh4uNH905cUS5Ikjh8/Xqzzx4wZo3WulZWVePTokcHjDSXFe/fuNTr2ikiKc3JyRL169bTqWb58ebHPv3XrlnByctL6AysmJkbvsW3atNFq599//zU6XiIifTjhioiMtnbtWq3twMBAjBgxoljnvvPOO/Dx8TGqPVdXV5w+fRp9+vQp1vGpqak4cOAA3n33XdSvXx/dunXDmTNnjGqzsJEjR6JTp07FOnbp0qVwcnLSbGdlZeGHH34wqr2+ffuib9++Rp1TUX755RdERkZqttu3b4+33nqr2Of7+PhgxowZmu2MjAxs2bJF77EJCQla297e3sYFS0RkAJNiIjKKEAK///67VtnUqVOLfb6lpSXGjx9vdLuurq74/fffsX//fgQGBmpdwFcUIQQOHz6M9u3bY9KkSVpzoI1hTB+rVauGl19+Waus8J35nmTChAlGHV+RfvrpJ63tadOmFfv1yVP4+QoJCdF7XOELG4taCYSIyBhMionIKDdu3EB8fLxmWy6XF3sEN8/AgQNNbr9nz544evQowsPD8eWXX6Jfv35wcXEp1rlr167Fiy++CKVSaVSb7u7ueO6554w6p3AfQ0NDi52QS5JUZe7cp1arceLECa2yXr16GV1P48aNYWNjo9k+ffq03uPatGmjtT1q1ChcunTJ6PaIiArj6hNEZJTCCUjjxo2NWlkByF39wM7OzuC6xsXh5eWFmTNnYubMmQByV8P4+++/cfbsWRw+fBihoaF6zzt8+DDeffddLF26tNhttW7d2uj4Cp+TkZGB69evo2nTpk88t169enB0dDS6zYqQdxe5PHZ2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",
      "text/plain": [
       "<Figure size 800x430 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "c_preds_total_train = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "for X_train, c_train, y_train in train_dl:\n",
    "    \n",
    "    y_prime = randomize_class(y_test, include=False)\n",
    "    if y_train.shape[-1] == 1:\n",
    "        y_prime = None\n",
    "    (c_preds, y_preds, explanations,\n",
    "    c_cf, y_cf, y_cf_target, explanation_cf, \n",
    "    p_z2, qz2_x, pz3_z2_c_y, qz3_z2_c_y_y_prime,\n",
    "    pcprime_z3, py_c, py_c_cf, pc_z2, c_cf_true, weights, z2, z3, c_pred_d) = net.forward(X_train, test=True, y_prime=y_prime, explain=True, include=False, inference=True)\n",
    "\n",
    "    if not net.bool_concepts:\n",
    "        c_preds = torch.sigmoid(c_preds)\n",
    "\n",
    "    c_preds_total_train = torch.cat((c_preds_total_train, c_preds), dim=0)\n",
    "\n",
    "idx = CLASS_TO_VISUALISE[str(c_preds_total_train.shape[-1])]\n",
    "print_concept_importance(net, idx, c_preds_total_train, c_preds_total, show=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Flipped labels (%):  0.1953125\n"
     ]
    }
   ],
   "source": [
    "y_preds = net.reasoner(c_preds_total)\n",
    "\n",
    "identity = torch.Tensor([[0, 0, 1], [0, 0, 1], [1, 0, 0]])\n",
    "c_preds_total_int = c_preds_total.clone()\n",
    "c_preds_total_int[:, -3:] = identity[c_preds_total_int[:, -3:].argmax(dim=-1)]\n",
    "\n",
    "y_preds_int = net.reasoner(c_preds_total_int)\n",
    "tot = ((y_preds > 0) == (y_preds_int > 0)).float().sum().item()\n",
    "print('Flipped labels (%): ', (1 - tot/c_preds_total.shape[0])*100)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Standard CBM "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Selecting the model "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`pytorch_lightning.utilities.seed.seed_everything` has been deprecated in v1.8.0 and will be removed in v1.10.0. Please use `lightning_lite.utilities.seed.seed_everything` instead.\n",
      "Global seed set to 0\n"
     ]
    }
   ],
   "source": [
    "model = 'StandardCBM'\n",
    "seed_everything(seed, workers=True)\n",
    "net = models[model]"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Training the model "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: True (mps), used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "MPS available but not used. Set `accelerator` and `devices` using `Trainer(accelerator='mps', devices=1)`.\n",
      "`Trainer(limit_train_batches=1.0)` was configured so 100% of the batches per epoch will be used..\n",
      "`Trainer(limit_val_batches=1.0)` was configured so 100% of the batches will be used..\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 0\n",
      "Checkpoint directory ./lightning_logs/boglad0j/checkpoints exists and is not empty.\n",
      "\n",
      "  | Name                 | Type              | Params\n",
      "-----------------------------------------------------------\n",
      "0 | cross_entropy        | BCEWithLogitsLoss | 0     \n",
      "1 | bce                  | BCELoss           | 0     \n",
      "2 | bce_log              | BCEWithLogitsLoss | 0     \n",
      "3 | model                | Sequential        | 82.3 K\n",
      "4 | encoder              | Sequential        | 82.2 K\n",
      "5 | relation_classifiers | Sequential        | 903   \n",
      "6 | reasoner             | Sequential        | 8     \n",
      "-----------------------------------------------------------\n",
      "165 K     Trainable params\n",
      "0         Non-trainable params\n",
      "165 K     Total params\n",
      "0.662     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running StandardCBM(\n",
      "  (cross_entropy): BCEWithLogitsLoss()\n",
      "  (bce): BCELoss()\n",
      "  (bce_log): BCEWithLogitsLoss()\n",
      "  (model): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "    (4): Linear(in_features=128, out_features=1, bias=True)\n",
      "  )\n",
      "  (encoder): Sequential(\n",
      "    (0): Linear(in_features=512, out_features=128, bias=True)\n",
      "    (1): LeakyReLU(negative_slope=0.01)\n",
      "    (2): Linear(in_features=128, out_features=128, bias=True)\n",
      "    (3): LeakyReLU(negative_slope=0.01)\n",
      "  )\n",
      "  (relation_classifiers): Sequential(\n",
      "    (0): Linear(in_features=128, out_features=7, bias=True)\n",
      "  )\n",
      "  (reasoner): Sequential(\n",
      "    (0): Linear(in_features=7, out_features=1, bias=True)\n",
      "  )\n",
      "  (classification_loss): BCELoss()\n",
      "), epochs=75, learning_rate=0.005\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "878fa39c285a4cb6a79736e7d3843c3b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Sanity Checking: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The dataloader, val_dataloader 0, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The dataloader, train_dataloader, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` (try 8 which is the number of cpus on this machine) in the `DataLoader` init to improve performance.\n",
      "The number of training batches (7) is smaller than the logging interval Trainer(log_every_n_steps=50). Set a lower value for log_every_n_steps if you want to see logs for the training epoch.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c27b8689177f4c7d912be3329173cd8d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Training: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "355a8bfb4d754232932ab8d5c22259fc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bfd0b3b31b3c4eb6939a132646f34cf8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b41ae948bb754e7bbc463245fd4f66a7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "78e25e0d62f14bcb846a0c6a6bb59e74",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f6a775b5103f4cd59d8045f49deaeb52",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0a3ca2c47cdc48788da5e95e60c03dcd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "490648f245494f3fa3b377640366b445",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ca214e0fb96242c885cf293c270cfb5c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6794c9f5c60942fa90269500670b263c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "72e617f263aa4ddb94cbc14f51bcf149",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fe08665770914f5ca0bc55c67e931d77",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "74c40780a34e4a5898320cb3ac35e89a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "961ce8dcc64d475bbc9dc6b0fbdb142f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cf8b854a5f8a475290dbd2afedfbd71a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7d496e52f0524c2095c02357c7aa5429",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "88441b77007a41b7a9327aef863d9468",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bce8bb172e204e60b65a9e86d703ca69",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "84f9e4d673034d1f945faf1843d71de8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "30066b0257ec46a29a3daafb21cfc1ab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7d745fd4741f476999ddfba74f7d3eea",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2cc916511c644b7e85fe0dc04f6c3738",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7ad2fa0431da4d81ac9175113d6abb80",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ffec87f8649d4611828e9f0d7893206d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5e0005c798c343dab3ecbfcbdfbe0461",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b23808077bdb456a9a44f40a14311377",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ddc273e3bfe9459bb63f69f790fdb1c8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1229051a722b494e872fa2a535c4b3a8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ee3d9bfba584a50910d27f685c4bea1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "38762a43d9f64447a393f0073e92e45c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "06d319aff84640649106f58f68fb4b4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae540e5f191e4d1e8d8d78a33bda128d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1095ebfbb4364875af9f5dc3f4e07f9a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4882797696004995ba483c3c98710785",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e6df7f9fccb4e8ba8d3778ced607250",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3e47a516e86143a196b3b9bf3e8811f6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2d79fc9afec94be9b5baae11eb8f5dbb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "be137c2ed2f34a3c8bf88eeda08fa73a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b9ae158cfabf4a8ebba07a7730ebc907",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f782373c203f4ceb827695408bb6e96c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "043c4a2a95d849d7947f15d4b351cf13",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f7c4392a3c3d47a796819d2ad4f6cc1b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "460d999205d847d9bb51c38756143124",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "110a343e77bb4162b6498d7fd3b790d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "061071edaff74374bf8c03b58722e856",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "775d2a154da147788290c12b4a35aa4f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "da45a42c33794bb09ca3b1d3cc9e6016",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "35a71ee775c940f4a5da5c6be3058cfb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ba751969ee546918b07e97ba3c51465",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e79f2f8161444a46862559d90996dba2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7052ffe80d9549d5960b60a7409e3b8e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "64f1674171004a23af7d77aed2942fa0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aa4107e885b04ec39cb608886c53628e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7615505dc1ce47db983ff873da28fcd2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "993cbfd1ad1642a0baa9596db6b498db",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fe53edc5a19348758dcfd5812752d932",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bd5a5a71988341f79dd87ad53ba95907",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "efc3511820e94a059ebbeac51a70d957",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4774f8c001af40158334e96d7fbd9c5c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f34eaf03f57b439590dab47c439aebbe",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e471d1e691394c0aa664f1260348e841",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c0fc3a12016b4a0c9a040910547f9ab4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ff270838f1d4d8da86217c100836052",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1872997fbbdd43b68a1c69869c8bcb47",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ab360ae24ca48659db7842eb22f51b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "762ad9aefdef4511a7c6909de93f116d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2a603269c1ea4600b0cb1f37960bac98",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e9baa32d451448be88ac9553ca45a82a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2694612d585f441784d662435ba37944",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2405e116e78447ca9d57d847948cd337",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd13586adacb4de7a52b9edbe1d48fff",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "749f6afb70064e23af8aa8cd9caa4f55",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "42f758f1389e48a5912e7d740125fa47",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "da4672f386794e7082e9f3643412158f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8f695787022a4cbfaab71b910c8a7ecf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "08614a93e7654bed9ddfc9b4c2597c32",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: 0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=75` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best train acc: 0.989919585949183, Epoch: 27\n"
     ]
    }
   ],
   "source": [
    "net = train_model(net, epochs, learning_rate, seed, train_dl, test_dl, results_dir, accelerator, wandb_logger)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Testing the model, saving the output and computing metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_preds_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "y_total = torch.empty(0, train_dl.dataset[0][-1].shape[-1])\n",
    "c_preds_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "c_total = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "\n",
    "for X_test, c_test, y_test in test_dl:\n",
    "\n",
    "    c_preds, y_preds, _ = net.forward(X_test)\n",
    "\n",
    "    if not net.bool_concepts:\n",
    "        c_preds = torch.sigmoid(c_preds)\n",
    "\n",
    "    c_preds_total = torch.cat((c_preds_total, c_preds), dim=0)\n",
    "    c_total = torch.cat((c_total, c_test), dim=0)\n",
    "    y_preds_total = torch.cat((y_preds_total, y_preds), dim=0)\n",
    "    y_total = torch.cat((y_total, y_test), dim=0)\n",
    "\n",
    "concept_accuracy = roc_auc_score(c_total.cpu(), c_preds_total.detach().cpu())\n",
    "concept_acc = (c_preds_total > 0.5).float().eq(c_total).float().all(dim=-1).float().mean()\n",
    "p_c = (c_preds_total > 0.5).float().eq(c_total).float().mean(dim=-1).float().mean()\n",
    "task_accuracy = roc_auc_score(y_total.cpu(), y_preds_total.detach().cpu())"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Computing concept importance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsUAAAHSCAYAAAAE8LamAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAACvTUlEQVR4nOzdd3gU5drH8e/sbnpCQu+hI0gRAQGPCFgoCigoqMdCUaSqoIKvHTg2RI8HwYaNKkcEsaDHQkcQUMAKKCV0Qg3pbcu8fyTZZLNZSIMQ9ve5rtXMzNNmEpJ7n73nGcM0TRMRERERET9mKesBiIiIiIiUNQXFIiIiIuL3FBSLiIiIiN9TUCwiIiIifk9BsYiIiIj4PQXFIiIiIuL3FBSLiIiIiN9TUCwiIiIifk9BsYiIiIj4PVtZD0BE/FO3bt1Ys2aNe3vVqlV069atSG2kpqaydetW9uzZQ3x8PElJSQQHBxMWFkaNGjWoX78+TZo0ITw8vJRHf+EaMmQIc+bMcW/PmjWLIUOGlN2ARETKCQXFIlKuZGRksGjRIt59911+/PFHnE7nGctbLBYuueQSOnToQI8ePejRowdVqlQ5T6MVEZHyQkGxiJQbGzZs4N577+Wvv/4qdB2Xy8WOHTvYsWMHc+bMwWKxkJqaSlBQ0Dkcafmxb98+Zs+e7d6uX7++ZpZFxC8pKBaRcuHTTz/l9ttv9zkzbLVaiYiIwOVykZiY6LMdl8uFaZrnapjlzr59+5g8ebJ7u2vXrgqKRcQv6UY7Ebng/fjjj/zzn//0Coi7du3KrFmz2LVrF3a7ndOnT5OQkIDdbmfXrl189NFHjBo1iho1apTRyEVEpLxQUCwiFzSn08no0aOx2+3ufSEhIXzyySesXr2aIUOG0LhxYwzDcB+32Ww0btyYO++8k7feeovDhw+zatUqBgwYgNVqLYvTOG9mz56NaZrul2Z9RUQKR+kTInJBW7FiBb/99pvHvlmzZjFw4MBCt2GxWOjWrRvdunXj4MGDBAYGlvYwRUSknFNQLCIXtC+//NJju0WLFtx+++3Fbq9u3bolHZKIiFyElD4hIhe0bdu2eWx37dq1jEYiIiIXM80Ui0ipSUtLY82aNRw4cICTJ08SGhpKw4YN+cc//lHstYGPHTvmsR0VFVUKIy25mJgYfvrpJw4dOoTD4aBGjRo0btyYf/zjH1gspT/fkJKSwsaNG9m5cyenT5/GYrFQo0aNcpEzvGPHDrZt28aJEyc4ffo0UVFRVKtWjQ4dOhAdHV3i9pOTk/n999/566+/iI+PJzU1leDgYMLDw6lbty6NGjWiadOm5+T7IiIXEVNEpIRiY2PNIUOGmGFhYSbg9bJareZNN91k/vHHH+46Xbt29SizatWqAtu+9NJLPcoNHjz4nJ/PxIkTPfqcOHGi+9jSpUvN9u3bF3iegFm9enXzySefNFNTUwvd36pVqzza6Nq1q/vYzp07zTvvvNMMCgoqsL/8Bg8e7HF81qxZZ+2vqK/COHr0qPnwww+b0dHRZ2zr0ksvNWfOnGk6HI5CX68ca9euNW+++WYzMDDwrGOOiIgwe/bsac6cObNI3xsR8R962ywiJfLll1/SvHlzZs+eTUpKSoFlnE4nX375JW3btmXWrFlFar969eoe29988w2pqanFHm9xOZ1ORo0aRd++fdm8ebPPcseOHePFF1+kZcuW/P777yXq88MPP6RVq1YsWLCAjIyMErV1Pr3yyis0atSI//znPxw4cOCMZbdv386IESO47LLLiImJKVT7Od+LLl268MUXX5CZmXnWOklJSXz33XeMGDGCv//+u1D9iIh/UVAsIsX25ZdfMmDAAOLj472OWa1WKlas6LFUmt1u57777mPx4sWF7qNjx44e28ePH+fee+8lPT292OMujrFjx/LOO+947LPZbD7TOWJiYrjuuuv4448/itXfnDlzuO+++7yC4aioKAICAorV5rlmt9sZOnQojz32WIFvkAICAqhUqRI2m3fm3rZt27jyyisL9UZi9OjRXt+LHIGBgVSuXJkKFSooXUJEikQ5xSJSLDExMfzzn//0WD/YYrFw//33M2zYMC6//HKsVit2u51169YxY8YMPvvsM0zTZNiwYYV+oMatt97KlClTPPYtXLiQzZs3M27cOAYOHOg1m1zavv32WzZt2gRkBV1jx45l8ODBNG/eHIvFQnp6OitWrODf//43q1atctc7efIk/fv35/fffyc0NLTQ/R04cIDRo0cDWdd08ODBDBkyhE6dOhEYGIhpmhw4cICPP/64WOfTtGlT3n77bQB27tzJf/7zH/exJk2a8MgjjxSr3XHjxnk8Mhrg8ssvZ8yYMVx33XXUr18fANM02bFjBwsXLmTatGnuJxAeP36cW2+9la1btxIREVFgHxs2bODdd9/16mPcuHFcc8011KlTx/1GzDRN9u/fzx9//MHy5cv58ssv2bdvX7HOTUT8QNlmb4hIeXXttdd65GyGhISYy5YtO2Od999/3zQMo8CcT185xaZpmjfffLPPXFGLxWJedtll5ogRI8wPPvjA/P3334uVn5pX/pzinFflypXNX375xWc9l8tlTpo0yaveuHHjztifrxzfiIiIM16XghQmp/hMfefNZy6KTz75xKMdwzDMV155xXS5XGest2fPHrNZs2YedceMGeOz/MiRIz3K9u/f37Tb7YUao8vlMr/++mvzyJEjRTo3EfEPCopFpMjWr1/vFcB99NFHhao7efLkIgfFp06dMps2bVroG8HCw8PNnj17mi+99JIZExNT5PMrKCg2DMP84YcfClV/6NChHnWDgoLMEydO+CzvKyheunRpkcdeFkGx3W4369Wr59HOtGnTCl1/z549ZmRkpMcbrOPHjxdYtkOHDh79/PXXX0Uer4hIQZRwJSJFNnPmTI/trl27cueddxaq7uOPP07Dhg2L1F+lSpXYsGEDvXv3LlT55ORkvvvuO5544gkaNWrE9ddfz8aNG4vUZ36DBg2ic+fOhSr7yiuvEBkZ6d7OyMjgww8/LFJ/ffr0oU+fPkWqU1Y++eQT9u/f796+8soreeihhwpdv2HDhowbN869nZaWxrx58wose/r0aY/tBg0aFG2wIiI+KCgWkSIxTZOvvvrKY9+YMWMKXT8wMJD777+/yP1WqlSJr776im+//ZauXbt63MB3JqZpsmLFCq688kpGjhzpkQNdFEU5x8qVK3PHHXd47Mv/ZL6zGT58eJHKl6X//ve/HtsPPvhgob8/OfJfrzVr1hRYLv+NjWdaCUREpCgUFItIkezatYu4uDj3ttVqLfQMbo5+/foVu/+ePXuyevVqYmJieO211+jbty8VK1YsVN2ZM2dyww034HA4itRnzZo1ueKKK4pUJ/85bt26tdABuWEY5ebJfS6Xi3Xr1nns69WrV5HbadasGSEhIe7tDRs2FFiuQ4cOHtuDBw/mt99+K3J/IiL5afUJESmS/AFIs2bNirSyAmStfhAWFuZzXePCqF+/Pg8//DAPP/wwkLUaxi+//MKmTZtYsWIFW7duLbDeihUreOKJJ3jllVcK3Vfbtm2LPL78ddLS0ti5cyctWrQ4a9169epRoUKFIvdZFnKeIpcjLCyMhQsXFqutwMBA0tLSgKyVO5xOJ1ar1aPM8OHDeeuttzBNE4Ddu3dz+eWXc80113Drrbdy3XXXcckllxTvZETErykoFpEiOXXqlMd2vXr1ityGxWIhOjqaHTt2lNawaNiwIQ0bNuTWW28FsoKl1157jffee89rZvj111/nwQcfLPQjhotzjtWqVSMkJMQd5IH3tfOlcuXKRe6vrOR/DHdKSgqjRo0qcbumaRIXF0fVqlU99rdu3ZoXXniBJ5980qPsypUrWblyJQBVq1blyiuv5Oqrr+aaa66hXbt2JR6PiFz8lD4hIkWS/0EdxZ3RzHsj2rnQuHFj3nrrLdasWePVl91uL9KNb6V1jvlvEvMlPDy8WP2VhbypNKXN15MLn3jiCebPn+9zresTJ07w5ZdfMmHCBNq3b0/Dhg157rnnSEhIOGdjFZHyT0GxiFzU/vGPf3itlgG4ZxWlZArziOXiykmRKMhdd91FTEwMs2fPplevXoSFhfksu3fvXp599lkaNWrkdZOoiEgOBcUiUiT57/7PeRpZUZ3PWbvbbruN2rVre+zbvXt3oeuX1jkW9obA8qRSpUoe29WqVcPMWgO/xK+cJ+D5EhISwuDBg/nmm284ffo0Gzdu5JVXXuHmm2/2Ghdkpa/069ePb7/9tjQvgYhcJBQUi0iR5M93zbs+bWG5XC4OHjxYWkM6K8MwvPJKC5vfC8U7x+PHj3vkE0P5yhUurPw5v3FxcWec4T1XAgIC6NixI+PHj+fzzz/n+PHjrFmzhjvvvNNjeTin08moUaOKvTSfiFy8FBSLSJFcdtllHtt//fWXz9xPX3bu3ElycnJpDuus8q+QUZQVM3ytZFGUOiEhITRt2rTI7VzomjdvTlBQkHvb4XDw559/luGIslitVrp06cJHH33ktRrGvn37+PHHH8toZCJyoVJQLCJF0qRJE4+Ppp1OJ19//XWR2vj8889LeVRnd+jQIY/t6tWrF7pubGwsP//8c5H6y3+Obdu2JSAgoEhtnA82m+ciRE6ns0j1Q0JCuOqqqzz2FfXn4VwbOHAgHTt29Nj3+++/l9FoRORCpaBYRIrEMAyvh3W89dZbha6fmZnJ+++/X9rDOqOTJ0+yadMmj32XX355kdooyjmeOnWKjz/+2GNf3759i9Tf+RIREeGxXZxc7wEDBnhsv/7660X+9OBcy/846JKskS0iFycFxSJSZCNGjPDYXr16NQsWLChU3SlTprBnz55C93X//fczf/58XC5XkcaY14QJE7xySIsapM6ZM4f169cXur+8wWVgYCD33ntvkfo7X/Iva7Znz54iryhx7733UqdOHff20aNHue+++0o0roLykk3TLPbPQf41sX0t5yYi/ktBsYgU2VVXXUW3bt089g0bNowVK1acsd6HH37IpEmTitTXrl27uOeee7j00kuZMWMGJ0+eLHTd1NRUxowZw+zZsz32N2zYkFtuuaVI4zBNk379+p31kcL/+te/mDVrlse+kSNHet2QdqGoXr06NWvWdG+npqZ6jf9sgoKCePnllz32ffzxx9xyyy1FWsfY4XDw2Wef0bVr1wLzuBMSEmjatCkzZswo0oogb7/9tsf3zTAMr59fERFMEZFi2LVrlxkSEmIC7pfFYjFHjBhhbtmyxXQ6naZpmmZmZqa5atUq85ZbbnGXi4qKMi+55BKPuqtWrSqwn65du3qUCwgIMPv06WO++uqr5o8//miePn3ao3xycrK5ceNGc+LEiWadOnU86uaM8euvvz7juU2cONGjTocOHdxfBwYGmo899pi5bds20+VymaZpmmlpaebXX39tXnPNNV79NWjQwExOTj5jf6tWrfKo07Vr10J9DwoyePBgj7ZmzZp11jojRozwqGMYhtmzZ09z4sSJ5owZM8y3337b4+XLI4884nX+FSpUMB9++GFzxYoVZmJiokf51NRUc+vWrebs2bPNu+++26xYsaK73s8//+zV/unTpz2+D7179zbffPNNc+PGjWZSUpJH2fj4ePPbb781BwwY4DWmm2++uVDXUkT8i4JiESm2JUuWmDabzSvoAEyr1WpWrFjRNAzDK+BatGiRV7Bb2KC4oJfNZjMrV65shoWFnbGcxWIxZ8+efdbzyh8UT5w40XzggQe82gsICPAI5PK/KleubP76669n7a+sg+K///7bDA0NPet1znn54nA4zIceeuiMdUNCQswqVaqYQUFBZyx3tqC4oFdQUJBZpUoVMzw83GeZevXqmbGxscW+viJy8VL6hIgUW//+/Vm0aFGBj2x2Op2cPn3aIzc0MDCQDz/80OvGrDO5/vrrqVat2hnLOBwOTp06dcabp1q2bMmaNWsYPHhwofvO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evUYNWoUlStXBrIC6BtvvJFff/2V1atXk5KSQnh4OJdccgnDhg2jV69exTo3ERERucD9686slx8ozzPF51qJVp8oCzmrT3z55ZfUqlWrrIcjInJR8rVOsTlB6RMi5dkKY7bH9nXmkDIZR2EcOHCgWPWio6OLVa9UbrQTERERkQtfeZoprl+/vtcT7ArD6SzeUwoVFIuIiIj4iXOblVu6Pvzww2IFxcWloFhERETET5iW8jNTPGTIkPPaX5Ee83whGDFiBJs3b1Y+sYiIiEgRmYbnS3JpplhEREREyo3169ezdetWEhISvJZpMwyDZ555pljtKigWERER8RPlKX0iv7i4OHr37s1PP/2EaZoYhuF++FvO1yUJistd+oSIiIiIFI9p8XyVJxMmTOD3339nwYIFxMTEYJom3333HTt37mTkyJG0adOGI0eOFLv9cnY5RESkTJgm5WglJxHxwbQaHq/y5H//+x8jRozg9ttvJyIiAgCLxULjxo158803qV+/PuPGjSt2+wqKRUTES/VgIysQznkZsOnO8vUHVEQuLvHx8bRo0QKA8PBwAJKTk93He/TowXfffVfs9hUUi4iIl6MP2vi2HwQZGVQ2EkgYBR1q6TYUkfLOZTE8XuVJrVq1OHr0KABBQUFUq1aN3377zX388OHDJVrXWL/hRESkQNfWh+kVFgAQEji0bAcjIqWivOUR59WlSxeWLVvGU089BcDtt9/O1KlTsVqtuFwupk2bRs+ePYvdvoJiERERET9RnlefeOSRR1i2bBkZGRkEBQUxadIktm3b5l5tokuXLsyYMaPY7SsoFhEREfET5fmBHa1ataJVq1bu7YoVK7J8+XLi4+OxWq3um++KqxxPoouIiIiIv9i+fXuB+6OiokocEIOCYhERERG/YVoMj1d50rJlS1q3bs2LL77I7t27S719BcUiIlKgFzbCiMTBjE68m0MJZT0aESkNLsPzVZ68/fbbVK1alWeffZZLLrmEdu3a8corr7B///5Sad8wc56PJyIiks36qgMXJrlP7DCZ39Pgrla6FUWkPFtc/WOP7QHH7iijkRTfsWPHWLRoEZ988gnr168HoEOHDtxxxx0MHDiQWrVqFatdBcUiIuLFeNVR4H5zvIJikfLsYgiK8zp8+LA7QP7pp58wDAO73V6stpQ+ISIiIuInTMPzVd7VrFmTFi1a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zVNPPQVAr169ME0Ti8XCiy++SL9+/Yrd/jn57XbFFVewfv16VqxYwfHjx90pFR06dOC///0vK1euJCkpySOfuGLFioSFhRETE+PVXmJiIidPnqRp06Zn7Ld27doABbaRsy+nTI6kpCROnjzpNVu8d+9eKlWqREhISCHOWEREREpd5uKsh8ZYbi3rkVw0ylsecX5PPfUU99xzD59++im7d+/G5XLRqFEjbrnllgIzBYrinDzmOSdPeObMmQQGBnLZZZcBcPnll2O1Wt03sOUNii0WC1dffTV///03P/74o0d7s2fPxuVy0a1btzP226xZM2rUqMHSpUs9Vo5wOBzMmzcPwzDo2rWrV705c+Z4bK9atYr9+/cXWFZERETOo3IexF1oTIvh8SovUlNTadeuHe+88w7R0dE8/PDDvPnmm7z99tuMHz++xAExnKOZ4ksuuYTIyEj27t1Lu3bt3Anq4eHhNG/enD///JMqVarQoEEDj3pjxoxh06ZNjB8/ngEDBlC3bl22bt3KsmXLaNu2LX369Dljv1arlccee4wJEyYwePBg+vfvT2hoKMuWLeOPP/5g6NChREdHe9SJiopi5cqVnDhxgnbt2nHgwAEWL15M5cqVGTFiROleGBEREREpstDQUPbu3XtO027PyUyxYRi0bdsW8JwNzrudM5ucV82aNZk9ezbXXXcd33zzDf/+97/Zvn07Q4cOZfr06e71jM+kS5cuvPXWW9SrV4958+bxxhtvkJGRwdNPP82YMWO8yoeEhDBz5kwyMzN54403+OKLL7jyyit5//33C7wBT0RERKTcMgzPVznSq1cvvvvuu7MXLCbDzP84ECnQoUOH6NevHyNHjmTYsGFlPRwRkXPKeLXgh3OY43WjnZQB45aC95t60EdRvd3a85kPo34/86fwF5IdO3YwcOBALr/8ckaMGEGDBg0KvPerUqVKxWpfv90K6cSJE0DxL7SIiIhIWSvPN9q1aNECgO3bt7NgwQKf5ZxOZ7HaV1B8FmlpaXz33Xd88cUXWK1WOnToUNZDEhEREfE7zz777DnNKVZQfBanT59mypQp1K1blxdeeIE6deqU9ZBERET8S+828PWvnvta1i6opJyFaZyT28nOi0mTJp3T9hUUn0WtWrXYuHFjWQ9DRETEf331LGzeDR0eAxNYMQmubV3WoyqXytMybOebgmIR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s37OsYLq5+w7U30px27uAJc3gJuvgBpRcOPlcHVzjAbVMPq39wiI8zJa18XSry2WGpFYerXA0rUplujKWPpfroBYiiww0ODyy0Jo1jS4RE9NMgyDzg0DuPHSwAsmIM5rcmeblmMTuUiV5yfatW3blq+//rrAYw6Hg48//phOnToVu/0SBcX9+vWjXr16zJs3j9WrVxdYZseOHSxatAiAjh07EhISwsKFCz3SLlJSUli4cCGhoaFnPJlmzZpRo0YNli5dysmTJ937HQ4H8+bNwzAMunbtWpJTkrI2p4CHd1zb/PyPQ0RERC4oTzzxBN9++y2jRo3izz//BODYsWMsX76cHj16sGPHDh5//PFit1+i9Ing4GCmTZvG2LFjGT9+PJ06daJjx45ERkZy+vRptmzZwoYNGxg0aBAAERERPPTQQ7z88ssMGTKEPn36APDVV19x8OBBnnzySa9cnbysViuPPfYYEyZMYPDgwfTv35/Q0FCWLVvGH3/8wdChQz1WniiuhQsXupPoHQ4HR48e5f333wegadOmdOnSpcR9iA+Drst6XfoAJKZCzDsQ6H2Dk4iIiBRdeV6n+IYbbmD27NmMHTuWd999F4C7774b0zSpUKECc+fOLVGMZpj5b90rhvT0dD799FNWrlxJTEwMqampREZG0rx5c3r06EGvXr2wWnPvrl61ahXz5s1j586dQFagWdDDO3IevrF06VKP/Vu2bOGDDz5g27Zt2O126tevz2233ebz4R35659N3759fd4p2qdPHyZNmlSk9kREyhvj1YKXiTPHX3hP4BORwvu/m3/z2H75i8vKaCTFl5KSwvfff8/u3btxuVw0atSInj17lnhhhVIJikVE5OKioFjk4vRYv989tqd+3rqMRlI4Tz75JHfccQetW5/7cZb9c0VFRERERAowZcoUd/4wwKlTp7Bare6nKpcmveUXERER8RPlOac4x7lKclBQLCIiIuInytsybOeTgmIRERERP2GiqNgXBcUiIiIifqI8pk/s27ePrVu3ApCQkADArl27iIqKKrB827Zti9WPVp8QEREvWn1C5OI07tZtHtvTPm1RRiMpHIvF4vUEUdM0C3yqaM5+p9NZrL70201ERETET5jlbKZ41qxZ560vBcUiIiIifqK8BcWDBw8+b31pnWIREfHSuTpATnadCZjYHy5ff0xFxJvL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C80U+6SZYhERERHxe5opFhEREfEXXivLSA7NFIuIiJxv3z1Z8H7n4vM7DhFxU1AsIiJyvvVoD3Uqee7reRlY9GdZzjEj30vclD4hIiJSFg6+X9YjEL+kSNgXvSUVEREREb+nmWIRERERf6GJYp80UywiIiIifk8zxSIiIiL+QjPFPmmmWERERET8noJiEREREfF7Sp8QERER8Rd6op1PCopFRERE/IViYp+UPiEiIiIifk9BsYiIiIj4PaVPiIiIiPgLpU/4pKBYRERExG8oKvZFQbGIiIiIv1BM7JNyikVERETE7ykoFhERERG/p/QJEREREX+h9AmfNFMsIiIiIn5PQbGIiIiIeJg0aRLh4eFlPYzzSukTIiIiIv5C6RM+aaZYRERERPyegmIRERERf2EYnq9i+uOPP+jZsydhYWFERkYyYMAADhw44D5+3333cfXVV7u3T548icVi4YorrnDvS05OJiAggEWLFhV7HKVJQbGIiIiIvzDyvYrh4MGDdOnShVOnTjF//nzeeecdtm7dSteuXUlKSgKgS5cu/Pzzz6SnpwOwdu1agoKC+OWXX9xlfvzxRxwOB126dCn5eZUC5RSXU6Zpun+oRETOBbvdTlpaGgCJiYkEBASU8YhELh4REREYJZipLUv/+c9/sNvtfP/991SqVAmAyy+/nEsvvZTZs2fz4IMP0qVLFzIyMti0aRNdu3Zl7dq19O/fn++//57169fTq1cv1q5dS9OmTalevXoZn1EWBcXlVFJSEpGRkWU9DBHxE+PGjSvrIYhcVBISEqhQocJ579ccX/LQ74cffuDaa691B8QAzZo147LLLmPdunU8+OCDNGjQgDp16rB27Vp3UDxy5EjS0tJYs2aNOyi+UGaJQUFxuRUREUFCQkKpt5ucnEzv3r35+uuv/W4plhy6Bll0HXQNQNcAdA1A1wBK/xpERESUwqjKxunTp2nTpo3X/urVqxMXF+fezgmGExMT+e233+jSpQspKSksXryYjIwMfvrpJ+6///7zOPIzU1BcThmGcU7eYVosFqxWKxUqVPDbX3y6Bll0HXQNQNcAdA1A1wB0DfKqVKkSx48f99p/7NgxmjZt6t7u0qULjzzyCKtXr6ZKlSo0a9aMlJQU/u///o9Vq1aRkZHhcTNeWdONdiIiIiJSaJ07d2bFihWcPn3ave/vv//m999/p3Pnzu59OTPDr732mjtNok2bNoSEhDBlyhTq1q1L/fr1z/fwfdJMsYiIiIh4cTqdLF682Gv/2LFjmTVrFj169OCpp54iPT2dp59+mujoaIYMGeIu16xZM6pVq8aaNWuYPn06AFarlauuuopvvvmGu+6663ydSqEoKBYPgYGB3H///QQGBpb1UMqMrkEWXQddA9A1AF0D0DUA/7wG6enpDBw40Gv/vHnzWLNmDePHj+euu+7CarXSvXt3XnvtNa9c6S5durB48WKPG+q6du3KN998c0HdZAdgmKZplvUgRERERETKknKKRURERMTvKSgWEREREb+noFhERERE/J5utPMzGzduZOnSpfz5558cPnyYgQMH8n//93+FqpucnMxrr73G6tWrcTgcdOrUiccee4wqVap4lPvtt9+YNm0aO3fupGLFigwYMIDBgwdfUI+zXLt2LW+//Tb79++nRo0aDBkyhJtuuumMdWbOnMl7771X4LFbbrmFJ5988ozlHn/8cQYMGFDywZeS4lyDI0eOFFimZcuWzJ4922PfxfpzsG3bNhYvXswvv/zCiRMnqFatGtdddx333XcfISEh7nIX2s/Bvn37mDp1Kr///jthYWHceOONjB49+qyPbjZNkzlz5rBo0SLi4+Np2rQpjzzyCK1atfIod+LECaZOncqmTZuw2Wxcc801PPzwwxfUeq7FuQYnT57ko48+YtOmTRw6dIjw8HAuv/xyHnjgAWrWrOkut3nzZkaOHOlVv3v37rz00kvn5HyKo7g/B3379iU2NtZr//r16wkKCnJvX6w/B76+vwD16tXj008/PWO5C+3nQAqmoNjPbNiwgV27dtG2bVsSExOLVPeJJ54gJiaGJ554gsDAQN566y0eeugh5s6di82W9aN08OBBHnzwQTp27MioUaPYtWsXb7zxBlarlXvuuedcnFKR/frrr0yYMIGbb76ZRx99lJ9//pnnnnuO0NBQrr/+ep/1+vXrxz/+8Q+PfVu3bmXGjBle+4OCgnjnnXc89tWuXbv0TqKEinsNcowZM4b27du7t0NDQz2OX8w/B8uWLePgwYMMGjSI6OhoYmJimDlzJn/++afX9/xC+TlITExk5MiRREdH88orr3D8+HH+85//kJ6eftY3xXPmzGHmzJk88MADNGnShEWLFvHAAw/w0UcfUadOHQAcDgcPPPAA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",
      "text/plain": [
       "<Figure size 800x430 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "c_preds_total_train = torch.empty(0, train_dl.dataset[0][1].shape[-1])\n",
    "for X_train, c_train, y_train in train_dl:\n",
    "\n",
    "    c_preds, y_preds, _ = net.forward(X_train)\n",
    "\n",
    "    if not net.bool_concepts:\n",
    "        c_preds = torch.sigmoid(c_preds)\n",
    "\n",
    "    c_preds_total_train = torch.cat((c_preds_total_train, c_preds), dim=0)\n",
    "\n",
    "idx = CLASS_TO_VISUALISE[str(c_preds_total_train.shape[-1])]\n",
    "print_concept_importance(net, idx, c_preds_total_train, c_preds_total, show=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### You can notice a greater importance given by this model to colors concepts compared to the Counterfactual CBM."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Flipped labels (%):  16.50390625\n"
     ]
    }
   ],
   "source": [
    "y_preds = net.reasoner(c_preds_total)\n",
    "\n",
    "identity = torch.Tensor([[0, 0, 1], [0, 0, 1], [1, 0, 0]])\n",
    "c_preds_total_int = c_preds_total.clone()\n",
    "c_preds_total_int[:, -3:] = identity[c_preds_total_int[:, -3:].argmax(dim=-1)]\n",
    "\n",
    "y_preds_int = net.reasoner(c_preds_total_int)\n",
    "tot = ((y_preds > 0) == (y_preds_int > 0)).float().sum().item()\n",
    "print('Flipped labels (%): ', (1 - tot/c_preds_total.shape[0])*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.9.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
