{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "NpxYXJJs5GpH"
   },
   "source": [
    "# Initialization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 957
    },
    "executionInfo": {
     "elapsed": 15274,
     "status": "ok",
     "timestamp": 1643722649652,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "F6uX-GO84nLb",
    "outputId": "c7980b61-12f9-4681-c413-679c9c636856"
   },
   "outputs": [],
   "source": [
    "!pip install -r requirements.txt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 4339,
     "status": "ok",
     "timestamp": 1643722662873,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "Jq27TqVV4qSx"
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('./packages/gcn_interpretation/gnn-model-explainer')\n",
    "sys.path.append('./packages/ldbExtraction')\n",
    "sys.path.append('./packages/RCExplainer/gcn_interpretation/gnn-model-explainer')\n",
    "from explain_graphs import *\n",
    "import dnn_invariant.extract_rules as extract\n",
    "import os\n",
    "import explainer_main3\n",
    "import configs3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import shutil\n",
    "logdir = './ckpt/Mutagenicity/_logdir'\n",
    "if os.path.exists(logdir):\n",
    "    shutil.rmtree(logdir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1643722662874,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "egdSEpim4vGT"
   },
   "outputs": [],
   "source": [
    "# setup notebook\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1643722662874,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "J2eAdj5j411l"
   },
   "outputs": [],
   "source": [
    "# import dependencies\n",
    "import torch\n",
    "import numpy as np\n",
    "import random\n",
    "\n",
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 4,
     "status": "ok",
     "timestamp": 1643722662874,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "28B3lmmA451P"
   },
   "outputs": [],
   "source": [
    "# configure libraries\n",
    "torch.manual_seed(20)\n",
    "random.seed(0)\n",
    "np.random.seed(0)\n",
    "\n",
    "# configure GPU\n",
    "gpu_id = 0\n",
    "torch.cuda.set_device(gpu_id)\n",
    "torch.cuda.manual_seed(0)\n",
    "torch.cuda.manual_seed_all(0)\n",
    "device = 'cuda:0'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 377,
     "status": "ok",
     "timestamp": 1643722665310,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "iiVSD2Y746nG"
   },
   "outputs": [],
   "source": [
    "# get arguments\n",
    "args = get_mutagenicity_args()\n",
    "default_stdout = sys.stdout"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "4sG15GT5jai-"
   },
   "outputs": [],
   "source": [
    "# pip install torch==1.8.0+cu111 torchvision==0.9.0+cu111 torchaudio==0.8.0 -f https://download.pytorch.org/whl/torch_stable.html"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "e-3GChy_5SKt"
   },
   "source": [
    "# Load model and dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9790,
     "status": "ok",
     "timestamp": 1643722677239,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "hgT58fkd4-GT",
    "outputId": "51c0532d-204f-44f3-d759-02d2a91bcf8d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rule label:  0\n",
      "rule: pos samples 1742\n",
      "rule: neg samples 1258\n",
      "Rules extracted:  {'boundary': [{'basis': array([ -0.7778877 ,   2.7435977 ,  17.096867  ,  -2.230471  ,\n",
      "         7.4752607 ,   3.057279  ,  23.858824  ,  17.076761  ,\n",
      "        20.68311   ,  -2.4843447 , -25.7729    ,  -0.6883296 ,\n",
      "        10.373083  , -10.964664  ,  -2.3192563 ,  -1.9224882 ,\n",
      "       -19.005634  , -21.42466   ,   3.007985  ,  -1.1455414 ,\n",
      "        -0.13652898], dtype=float32), 'label': 1}], 'label': 0}\n",
      "rule label:  1\n",
      "rule: pos samples 1258\n",
      "rule: neg samples 1742\n",
      "Rules extracted:  {'boundary': [{'basis': array([  0.7778877 ,  -2.7435977 , -17.096867  ,   2.230471  ,\n",
      "        -7.4752607 ,  -3.057279  , -23.858824  , -17.076761  ,\n",
      "       -20.68311   ,   2.4843447 ,  25.7729    ,   0.6883296 ,\n",
      "       -10.373083  ,  10.964664  ,   2.3192563 ,   1.9224882 ,\n",
      "        19.005634  ,  21.42466   ,  -3.007985  ,   1.1455414 ,\n",
      "         0.13652909], dtype=float32), 'label': 0}], 'label': 1}\n"
     ]
    }
   ],
   "source": [
    "# load ckpt containing model and dataset\n",
    "ckpt = torch.load(\"./ckpt/Mutagenicity/Mutagenicity_base_h20_o20.pth.tar\")\n",
    "cg_dict = ckpt[\"cg\"]\n",
    "\n",
    "# extract model from ckpt\n",
    "input_dim = cg_dict[\"feat\"].shape[2]\n",
    "num_classes = cg_dict[\"pred\"].shape[2]\n",
    "\n",
    "model = get_mutagenicity_model(input_dim, num_classes, device, args).cuda()\n",
    "model.load_state_dict(ckpt[\"model_state\"])\n",
    "\n",
    "\n",
    "# extract dataset from ckpt\n",
    "adj, feat, label, pred, num_nodes = get_dataset_from_ckpt(ckpt)\n",
    "\n",
    "size = 3035\n",
    "train_data = (adj[:size], feat[:size], label[:size], num_nodes[:size])\n",
    "val_data = (adj[size - 100:], feat[size - 100:], label[size - 100:], num_nodes[size - 100:])\n",
    "\n",
    "# get graphs to explain\n",
    "graph_indices = []\n",
    "preds = np.argmax(cg_dict['pred'][0,:,:], axis=1) \n",
    "for i, l in enumerate(preds):\n",
    "    # explain predictions for class 0 (mutagenic) for Mutagenicity\n",
    "    if l == 0:\n",
    "        graph_indices.append(i)\n",
    "\n",
    "rule_dict = extract.extract_rules('Mutagenicity', train_data, val_data, args, model.state_dict(), graph_indices=None, pool_size=50)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "TUtzhG8B5xzt"
   },
   "source": [
    "## Load explainer model\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 407,
     "status": "ok",
     "timestamp": 1643722679059,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "m2EO77iB51sM",
    "outputId": "6cd0c4b9-3511-4d20-d202-3042f58571f2"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "explainer = ExplainModule(\n",
    "    model = model, \n",
    "    num_nodes = adj.shape[1],\n",
    "    emb_dims = model.embedding_dim * model.num_layers * 2, \n",
    "    device = device,\n",
    "    args = args\n",
    ")\n",
    "\n",
    "# Load explainer model from file\n",
    "state_dict = torch.load('./ckpt/Mutagenicity/RCExplainer/rcexplainer.pth.tar')\n",
    "\n",
    "exp_state_dict = explainer.state_dict()\n",
    "for name, param in state_dict.items():\n",
    "    if name in exp_state_dict and not (\"model\" in name):\n",
    "        exp_state_dict[name].copy_(param)\n",
    "explainer.load_state_dict(state_dict)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "1nYQbHTjo4XF"
   },
   "source": [
    "# Code for experiment 1; evaluate the pre-trained model on fidelity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "executionInfo": {
     "elapsed": 422,
     "status": "ok",
     "timestamp": 1643722683149,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "veRcpW_6cdjg"
   },
   "outputs": [],
   "source": [
    "# Function to conduct counterfactuality experiment\n",
    "\n",
    "def evaluate_counterfactuality(path):\n",
    "\n",
    "  with os.scandir(path) as it:\n",
    "    for entry in it:\n",
    "      if entry.path[-1] == 'h' or entry.path[-1] == 'r':\n",
    "        state_dict = torch.load(entry.path)\n",
    "        exp_state_dict = explainer.state_dict()\n",
    "\n",
    "        for name, param in state_dict.items():\n",
    "          if name in exp_state_dict and not (\"model\" in name):\n",
    "            exp_state_dict[name].copy_(param)\n",
    "          explainer.load_state_dict(state_dict)\n",
    "        explanations = evaluate_explainer(explainer, model, rule_dict, adj, feat, label, pred, num_nodes, args, graph_indices)\n",
    "\n",
    "  return explanations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "executionInfo": {
     "elapsed": 713,
     "status": "ok",
     "timestamp": 1643723098451,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "RGUUznB_chEx"
   },
   "outputs": [],
   "source": [
    "# Function to plot counterfactuality experiment results\n",
    "\n",
    "def plot_results(path, label):\n",
    "\n",
    "  our_results = open(path, 'r')\n",
    "  our_results = our_results.read()\n",
    "  our_results = our_results.splitlines()\n",
    "\n",
    "  sparsity = []\n",
    "  fidelity = []\n",
    "  for i in our_results:\n",
    "    i = i.split(\",\")\n",
    "    if i[0] == 'Sparsity':\n",
    "      sparsity.append([float(item) for item in i[3:8]])\n",
    "    elif i[0] == 'Fidelity':\n",
    "      fidelity.append(np.array([float(item) for item in i[3:8]]))\n",
    "  if len(fidelity) > 1:\n",
    "    avg_fidelity = sum(map(np.array, fidelity)) / len(fidelity)\n",
    "    avg_sparsity = sum(map(np.array, sparsity)) / len(sparsity)\n",
    "    std_fidelity = np.dstack(fidelity).std(axis=2)\n",
    "  else:\n",
    "    avg_fidelity = fidelity[0]\n",
    "    avg_sparsity = sparsity[0]\n",
    "    std_fidelity = 0\n",
    "\n",
    "#   print(f'Fidelity avg: {avg_fidelity}')\n",
    "#   print(f'Fidelity stds: {std_fidelity}')\n",
    "  \n",
    "  plt.plot(avg_sparsity, avg_fidelity, '-o', label=label)\n",
    "  plt.xlabel('Sparsity')\n",
    "  plt.ylabel('Fidelity')\n",
    "  plt.legend()\n",
    "\n",
    "  return "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 402
    },
    "executionInfo": {
     "elapsed": 8170,
     "status": "ok",
     "timestamp": 1643722776040,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "MFZji95PgvWh",
    "outputId": "c73ffee0-3319-4f0f-de6f-cb6756b900cb"
   },
   "outputs": [],
   "source": [
    "# pip install matplotlib==3.1.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "executionInfo": {
     "elapsed": 67331,
     "status": "ok",
     "timestamp": 1643722843752,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "wmwfnfSho30t",
    "outputId": "19cc8f9c-60b8-4067-a2fb-dd50e7540535"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Save evaluation results to text file\n",
    "sys.stdout = open('pt_fidelity.txt', 'w')\n",
    "explanations = evaluate_explainer(explainer, model, rule_dict, adj, feat, label, pred, num_nodes, args, graph_indices)\n",
    "sys.stdout = default_stdout\n",
    "\n",
    "plot_results('pt_fidelity.txt', label='Pre-trained')\n",
    "plot_results('./Results_fidelity_paper.txt',label='Paper')\n",
    "plt.title('RCExplainer')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Fidelity RCExplainer_NoLDB\n",
    "prog_args = configs3.arg_parse()\n",
    "sys.stdout = open('pt_fidelity_noldb.txt', 'w')\n",
    "\n",
    "prog_args.exp_path = './ckpt/Mutagenicity/RCExplainer/rcexplainer_noldb.pth.tar'\n",
    "\n",
    "explainer_main3.main(prog_args)\n",
    "sys.stdout = default_stdout\n",
    "\n",
    "plot_results('pt_fidelity_noldb.txt', label='Pre-trained')\n",
    "plt.title('RCExplainer_NoLDB')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "4ElgTDEt5_9B"
   },
   "source": [
    "# Code for experiment 2; train RCExplainer from scratch\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "id": "67lkuqrTqQe_"
   },
   "outputs": [],
   "source": [
    "# Train function as provided by the authors of the paper\n",
    "\n",
    "def train_explainer(explainer, model, rule_dict, adjs, feats, labels, preds, num_nodes, args, graph_indices):\n",
    "    params_optim = []\n",
    "    for name, param in explainer.named_parameters():\n",
    "        if \"model\" in name:\n",
    "            continue\n",
    "        params_optim.append(param)\n",
    "\n",
    "    scheduler, optimizer = train_utils.build_optimizer(args, params_optim)\n",
    "\n",
    "    ep_count = 0\n",
    "    loss_ep = 0 \n",
    "\n",
    "    for epoch in range(args.start_epoch, args.num_epochs):\n",
    "        loss_epoch = 0\n",
    "\n",
    "        stats = accuracy_utils.Stats(\"RCExplainer\", explainer, model)\n",
    "\n",
    "        np.random.shuffle(graph_indices)\n",
    "        explainer.train()\n",
    "        for graph_idx in graph_indices:\n",
    "            # preprocess inputs\n",
    "            sub_adj = adjs[graph_idx]\n",
    "            sub_nodes = num_nodes[graph_idx]\n",
    "            sub_feat = feats[graph_idx]\n",
    "            sub_label = labels[graph_idx]\n",
    "\n",
    "            sub_adj = np.expand_dims(sub_adj, axis=0)\n",
    "            sub_feat = np.expand_dims(sub_feat, axis=0)\n",
    "\n",
    "            adj   = torch.tensor(sub_adj, dtype=torch.float).cuda()\n",
    "            x     = torch.tensor(sub_feat, requires_grad=True, dtype=torch.float).cuda()\n",
    "            label = torch.tensor(sub_label, dtype=torch.long).cuda()\n",
    "\n",
    "            pred_label = np.argmax(preds[0][graph_idx], axis=0)\n",
    "            # extract model embeddings from layer\n",
    "            emb = model.getEmbeddings(x, adj, batch_num_nodes=[sub_nodes.cpu().numpy()])\n",
    "            emb = emb.clone().detach()\n",
    "\n",
    "            gt_pred, gt_embedding = model(x.cuda(), adj.cuda(), batch_num_nodes=[sub_nodes.cpu().numpy()])\n",
    "\n",
    "            # get boundaries for sample\n",
    "            rule_ix = rule_dict['idx2rule'][graph_idx]\n",
    "            rule = rule_dict['rules'][rule_ix]\n",
    "            rule_label = rule['label']\n",
    "\n",
    "            boundary_list = []\n",
    "            for b_num in range(len(rule['boundary'])):\n",
    "\n",
    "                boundary = torch.from_numpy(rule['boundary'][b_num]['basis'])\n",
    "                if args.gpu:\n",
    "                    boundary = boundary.cuda()\n",
    "                boundary_label = rule['boundary'][b_num]['label']\n",
    "                boundary_list.append(boundary)\n",
    "\n",
    "            # explain prediction\n",
    "            t0 = 0.5\n",
    "            t1 = 4.99\n",
    "\n",
    "            tmp = float(t0 * np.power(t1 / t0, epoch /args.num_epochs))\n",
    "            pred, masked_adj, graph_embedding, inv_embedding, inv_pred = explainer((x[0], emb[0], adj[0], tmp, label, sub_nodes), training=True)\n",
    "            loss, bloss_s = explainer.loss(pred, pred_label, graph_embedding=graph_embedding,\n",
    "                               boundary_list=boundary_list, gt_embedding=gt_embedding, inv_embedding=inv_embedding)\n",
    "\n",
    "            if ep_count < 200:\n",
    "                loss_ep += loss\n",
    "                ep_count += 1.0\n",
    "            else:\n",
    "                ep_count = 0.\n",
    "                optimizer.zero_grad()\n",
    "                loss_ep.backward()\n",
    "                optimizer.step()\n",
    "                loss_epoch += loss_ep.detach()\n",
    "                loss_ep = 0.\n",
    "\n",
    "            # evaluate explanation\n",
    "            masked_adj = masked_adj.cpu().detach().numpy() * sub_adj.squeeze()\n",
    "            imp_nodes = None\n",
    "            stats.update(masked_adj, imp_nodes, adj, x, label, sub_nodes)\n",
    "\n",
    "        if scheduler is not None:\n",
    "            scheduler.step()\n",
    "\n",
    "        print(\"Epoch: {} \\t Loss: {}\".format(epoch, loss_epoch))\n",
    "    torch.save(explainer.state_dict(), './ckpt/Mutagenicity/_logdir/rcexplainer_mutagenicity.pth')\n",
    "    print(stats.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "id": "85Cr1JZJ59oe"
   },
   "outputs": [],
   "source": [
    "# Code to activate training: to activate training, set train to True\n",
    "# Saves model in _logdir\n",
    "\n",
    "train = False\n",
    "args.num_epochs = 600\n",
    "if train:\n",
    "    train_explainer(explainer, model, rule_dict, adj, feat, label, pred, num_nodes, args, graph_indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "if train:\n",
    "    prog_args = configs3.arg_parse()\n",
    "    prog_args.explainer_method = 'rcexp_noldb'\n",
    "    prog_args.num_epochs = 600\n",
    "    prog_args.noise = False\n",
    "    prog_args.exp_path = \"\"\n",
    "    prog_args.skip_eval = True\n",
    "    explainer_main3.main(prog_args)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "h4yJRd0fi59y"
   },
   "source": [
    "# Code for experiment 3; evaluate the trained models from scratch on fidelity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "executionInfo": {
     "elapsed": 1305,
     "status": "ok",
     "timestamp": 1643723189204,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "WPIcvlU-K060",
    "outputId": "b61ad0b1-e7ad-44de-a150-f7f37c0e9105"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Evaluate our trained from scratch RCExplainers vs results from paper\n",
    "\n",
    "sys.stdout = open('our_results_rce.txt', 'w')\n",
    "evaluate_counterfactuality('./trained_rcexplainers_ours')\n",
    "sys.stdout = default_stdout\n",
    "\n",
    "plot_results('our_results_rce.txt', 'From scratch')\n",
    "plot_results('Results_fidelity_paper.txt', 'Paper')\n",
    "plt.title('RCExplainer')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "executionInfo": {
     "elapsed": 1125,
     "status": "ok",
     "timestamp": 1643723859142,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "S3yNWLeeL0qz",
    "outputId": "f6c93d84-91c8-4912-9ee9-6bceacbc6e4d"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Evaluate our trained from scratch NoLDB vs results from pre-trained model\n",
    "\n",
    "sys.stdout = open('our_results_noldb.txt', 'w')\n",
    "evaluate_counterfactuality('./trained_noldb_ours')\n",
    "sys.stdout = default_stdout\n",
    "\n",
    "plot_results('our_results_noldb.txt', 'Trained from scratch')\n",
    "plt.title('RCExp-NOLDB')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Code for experiment 4; pretrained models vs trained from scratch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results('pt_fidelity_noldb.txt', 'Pretrained')\n",
    "plot_results('our_results_noldb.txt', 'Trained from scratch')\n",
    "plt.title('RCExp-NOLDB')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "xPIEeBx6dvcT"
   },
   "source": [
    "# Code for experiment 5; evaluate our trained models on robustness\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1643725108992,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "25bz31zKi-Vg"
   },
   "outputs": [],
   "source": [
    "def evaluate_robustness(path):\n",
    "\n",
    "  prog_args = configs3.arg_parse()\n",
    "  prog_args.noise = True\n",
    "  prog_args.explainer_method = 'rcnoiseexplainer'\n",
    "  with os.scandir('trained_rcexplainers_ours') as it:\n",
    "    for entry in it:\n",
    "      if entry.path[-1] == 'h':\n",
    "        prog_args.exp_path = entry.path\n",
    "        prog_args.exp_path1 = entry.path\n",
    "        prog_args.exp_path2 = entry.path\n",
    "        explainer_main3.main(prog_args)\n",
    "\n",
    "  return "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "executionInfo": {
     "elapsed": 2,
     "status": "ok",
     "timestamp": 1643726859229,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "yQrPs3Mcpfa9"
   },
   "outputs": [],
   "source": [
    "sys.stdout = default_stdout\n",
    "def plot_results_robustness(path, label):\n",
    "\n",
    "  our_results = open(path, 'r')\n",
    "  our_results = our_results.read()\n",
    "  our_results = our_results.splitlines()\n",
    "\n",
    "  summary = False\n",
    "  noise = []\n",
    "  results = []\n",
    "\n",
    "  for line in our_results:\n",
    "    if line == 'NOISE SUMMARY':\n",
    "      summary = True\n",
    "    if line == 'SUMMARY':\n",
    "      summary = False\n",
    "    if summary:\n",
    "      if line != 'NOISE SUMMARY':\n",
    "        line = line.split(\",\")\n",
    "        line = line[1].split(\" \")\n",
    "        results.append(line[1:])\n",
    "  for i in results:\n",
    "    noise.append(float(i[0][1:]))\n",
    "  if len(results) == 21:\n",
    "    w, y, z = noise[:7], noise[7:14], noise[14:]\n",
    "    noise_avg = sum(map(np.array, [w, y, z])) / 3\n",
    "    noise_std = np.dstack([w, y, z]).std(axis=2)\n",
    "  else:\n",
    "    noise_avg = noise\n",
    "    noise_std = 0\n",
    "\n",
    "  x = np.arange(0, 35, 5)\n",
    "  plt.plot(x, noise_avg, '-o', label=label)\n",
    "  plt.xlabel('Noise')\n",
    "  plt.ylabel('AUC')\n",
    "  \n",
    "#   print(f'Noise avg: {noise_avg}')\n",
    "#   print(f'Noise stds: {noise_std}')\n",
    "\n",
    "  return"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "executionInfo": {
     "elapsed": 430,
     "status": "ok",
     "timestamp": 1643726968547,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "dyxZD9i9ljpW",
    "outputId": "272aea5b-d147-4402-c5e7-ae45bdd98597"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Evaluate our trained models on robustness\n",
    "sys.stdout = open('noise_scratch.txt', 'w')\n",
    "evaluate_robustness('trained_rcexplainers_ours')\n",
    "sys.stdout = default_stdout\n",
    "plot_results_robustness('noise_scratch.txt', 'Trained from scratch')\n",
    "plt.title('Robustness RCExplainer')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "executionInfo": {
     "elapsed": 617962,
     "status": "ok",
     "timestamp": 1643727642123,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "JESn1ej3wznl",
    "outputId": "bfb96eff-95cb-4c49-d89b-00fda44b5c32"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sys.stdout = open('noise_scratch_noldb.txt', 'w')\n",
    "evaluate_robustness('trained_noldb_ours')\n",
    "sys.stdout = default_stdout\n",
    "plot_results_robustness('noise_scratch_noldb.txt', 'Trained RCExp_NoLDB from scratch')\n",
    "plt.title('Robustness RCExp_NoLDB')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Q__vhidC52Z6"
   },
   "source": [
    "# Code for experiment 6; run robustness experiment on provided pre-trained model and compare with our results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 279
    },
    "executionInfo": {
     "elapsed": 511,
     "status": "ok",
     "timestamp": 1643726866396,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "HV0WVZfx4siA",
    "outputId": "bb17574b-1663-4bc1-9c9e-e5f91db5cb54"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Robustness RCExplainer\n",
    "prog_args = configs3.arg_parse()\n",
    "sys.stdout = open('PT_noise.txt', 'w')\n",
    "\n",
    "prog_args.exp_path = './ckpt/Mutagenicity/RCExplainer/rcexplainer.pth.tar'\n",
    "prog_args.exp_path1 = './ckpt/Mutagenicity/RCExplainer/rcexplainer.pth.tar'\n",
    "prog_args.exp_path2 = './ckpt/Mutagenicity/RCExplainer/rcexplainer.pth.tar'\n",
    "prog_args.noise = True\n",
    "prog_args.explainer_method = 'rcnoiseexplainer'\n",
    "\n",
    "explainer_main3.main(prog_args)\n",
    "sys.stdout = default_stdout\n",
    "plot_results_robustness('PT_noise.txt', 'Pre-trained')\n",
    "plt.title('Robustness RCEXplainer')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Robustness RCExpl_NoLDB\n",
    "prog_args = configs3.arg_parse()\n",
    "sys.stdout = open('pt_robustness_noldb.txt', 'w')\n",
    "\n",
    "prog_args.exp_path = './ckpt/Mutagenicity/RCExplainer/rcexplainer_noldb.pth.tar'\n",
    "prog_args.exp_path1 = './ckpt/Mutagenicity/RCExplainer/rcexplainer_noldb.pth.tar'\n",
    "prog_args.exp_path2 = './ckpt/Mutagenicity/RCExplainer/rcexplainer_noldb.pth.tar'\n",
    "prog_args.noise = True\n",
    "prog_args.explainer_method = 'rcnoiseexplainer'\n",
    "\n",
    "explainer_main3.main(prog_args)\n",
    "sys.stdout = default_stdout\n",
    "\n",
    "plot_results_robustness('pt_robustness_noldb.txt', label='Pre-trained')\n",
    "plt.title('Robustness RCEXplainer_NoLDB')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 279
    },
    "executionInfo": {
     "elapsed": 428,
     "status": "ok",
     "timestamp": 1643726873699,
     "user": {
      "displayName": "Faye Raaijmakers",
      "photoUrl": "https://lh3.googleusercontent.com/a/default-user=s64",
      "userId": "04792850991479815987"
     },
     "user_tz": -60
    },
    "id": "C8fjC0OfsR9U",
    "outputId": "add54e72-f728-44dd-b90c-2b529f20605c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results_robustness('PT_noise.txt', 'Pre-trained RCExplainer')\n",
    "plot_results_robustness('pt_robustness_noldb.txt', 'Pre-trained RCExp_NoLDB')\n",
    "plot_results_robustness('noise_scratch.txt', 'RCExplainer trained from scratch')\n",
    "plot_results_robustness('noise_scratch_noldb.txt', 'RCExp_NoLDB trained from scratch')\n",
    "plt.title('Robustness')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "FACT_our_experiments_tryout.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
