{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f06af750",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:526: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:527: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:528: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:529: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:530: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "/home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/framework/dtypes.py:535: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import argparse\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import pandas as pd\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "from scipy.spatial.distance import pdist\n",
    "\n",
    "import cxplain\n",
    "from cxplain import MLPModelBuilder, ZeroMasking, CXPlain\n",
    "from tensorflow.python.keras.losses import binary_crossentropy, categorical_crossentropy\n",
    "\n",
    "from tensorflow.python.keras.layers import Dense, Input, Flatten, Add, Multiply, Lambda\n",
    "from tensorflow.python.keras.layers.normalization import BatchNormalization\n",
    "from tensorflow.python.keras import regularizers\n",
    "from tensorflow.python.keras.models import Model, Sequential\n",
    "from tensorflow.python.keras import optimizers\n",
    "from tensorflow.python.keras.callbacks import ModelCheckpoint\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "from tqdm import tqdm\n",
    "\n",
    "from utils.explanations import calculate_robust_astute_sampled\n",
    "import shap\n",
    "import pickle\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4a79cae1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_all_weights(model, all_layer_weights):\n",
    "    count = 0\n",
    "    for layer in model.layers:\n",
    "        if type(layer) is Dense:\n",
    "            count += 1\n",
    "    if count == len(all_layer_weights):\n",
    "        c = 0\n",
    "        for layer in model.layers:\n",
    "            if type(layer) is Dense:\n",
    "                layer.set_weights(all_layer_weights[c])\n",
    "                c += 1\n",
    "        return model\n",
    "    else:\n",
    "        print(\"models don't match\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1c8fff0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "datatype = 'telescope'\n",
    "run_times = 5\n",
    "prop_points = 1\n",
    "calculate = True\n",
    "epsilon_range = np.arange(0.01, 1.1, 0.05)\n",
    "masking_operation = ZeroMasking()\n",
    "loss = binary_crossentropy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6afce5d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_dict = pd.read_csv('data/magic04.data').values\n",
    "data = data_dict[:, :-1]\n",
    "labels = data_dict[:, -1]\n",
    "labels[labels == 'h'] = 0\n",
    "labels[labels == 'g'] = 1\n",
    "x_train, x_val, y_train, y_val = train_test_split(data, labels, test_size=0.05, stratify=labels, random_state=42)\n",
    "x_train = StandardScaler().fit_transform(x_train)\n",
    "x_val = StandardScaler().fit_transform(x_val)\n",
    "input_shape = x_train.shape[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e129900f",
   "metadata": {},
   "outputs": [],
   "source": [
    "median_rad = np.median(pdist(x_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "004d077d",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_astuteness_file = 'plots/cxplain_' + datatype + '_astuteness_classifiers_lip.pk'\n",
    "lambda_dense_list =[float(0.7), float(1), float(\"inf\")]\n",
    "lambda_names = ['Regularized High', 'Regularized Low', 'Not Regularized']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8e860a39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 1 of 5\n",
      "WARNING:tensorflow:From /home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/ops/resource_variable_ops.py:435: colocate_with (from tensorflow.python.framework.ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Colocations handled automatically by placer.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2022-05-18 11:45:26.532436: I tensorflow/core/platform/cpu_feature_guard.cc:141] Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA\n",
      "2022-05-18 11:45:26.554131: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2022-05-18 11:45:26.554451: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x556ecb6ca580 executing computations on platform Host. Devices:\n",
      "2022-05-18 11:45:26.554465: I tensorflow/compiler/xla/service/service.cc:158]   StreamExecutor device (0): <undefined>, <undefined>\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/keras/utils/losses_utils.py:170: to_float (from tensorflow.python.ops.math_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Use tf.cast instead.\n",
      "WARNING:tensorflow:From /home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/keras/engine/network.py:1436: update_checkpoint_state (from tensorflow.python.training.checkpoint_management) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Use tf.train.CheckpointManager to manage checkpoints rather than manually editing the Checkpoint proto.\n",
      "Train on 16261 samples, validate on 1807 samples\n",
      "WARNING:tensorflow:From /home/zulqarnain/anaconda3/envs/old_tf/lib/python3.7/site-packages/tensorflow/python/ops/math_ops.py:3066: to_int32 (from tensorflow.python.ops.math_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Use tf.cast instead.\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 1s 62us/sample - loss: 1.0306 - dense_4_loss: 0.5874 - all_loss: 0.2205 - lambda_1_loss: 0.2222 - val_loss: 0.9291 - val_dense_4_loss: 0.4988 - val_all_loss: 0.2166 - val_lambda_1_loss: 0.2181\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 35us/sample - loss: 0.9108 - dense_4_loss: 0.4678 - all_loss: 0.2204 - lambda_1_loss: 0.2221 - val_loss: 0.8867 - val_dense_4_loss: 0.4528 - val_all_loss: 0.2171 - val_lambda_1_loss: 0.2186\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 38us/sample - loss: 0.8774 - dense_4_loss: 0.4343 - all_loss: 0.2206 - lambda_1_loss: 0.2223 - val_loss: 0.8553 - val_dense_4_loss: 0.4196 - val_all_loss: 0.2161 - val_lambda_1_loss: 0.2176\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 40us/sample - loss: 0.8559 - dense_4_loss: 0.4133 - all_loss: 0.2205 - lambda_1_loss: 0.2222 - val_loss: 0.8431 - val_dense_4_loss: 0.4101 - val_all_loss: 0.2163 - val_lambda_1_loss: 0.2178\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 35us/sample - loss: 0.8426 - dense_4_loss: 0.3999 - all_loss: 0.2204 - lambda_1_loss: 0.2221 - val_loss: 0.8397 - val_dense_4_loss: 0.4056 - val_all_loss: 0.2169 - val_lambda_1_loss: 0.2184\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:15<00:00,  1.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 1s 64us/sample - loss: 0.9142 - dense_9_loss: 0.5745 - all_loss: 0.1633 - lambda_3_loss: 0.1757 - val_loss: 0.7826 - val_dense_9_loss: 0.4538 - val_all_loss: 0.1586 - val_lambda_3_loss: 0.1688\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 37us/sample - loss: 0.7786 - dense_9_loss: 0.4393 - all_loss: 0.1634 - lambda_3_loss: 0.1758 - val_loss: 0.7626 - val_dense_9_loss: 0.4372 - val_all_loss: 0.1599 - val_lambda_3_loss: 0.1699\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 40us/sample - loss: 0.7533 - dense_9_loss: 0.4141 - all_loss: 0.1635 - lambda_3_loss: 0.1758 - val_loss: 0.7422 - val_dense_9_loss: 0.4140 - val_all_loss: 0.1589 - val_lambda_3_loss: 0.1687\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 37us/sample - loss: 0.7406 - dense_9_loss: 0.4011 - all_loss: 0.1632 - lambda_3_loss: 0.1757 - val_loss: 0.7245 - val_dense_9_loss: 0.3957 - val_all_loss: 0.1591 - val_lambda_3_loss: 0.1691\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 36us/sample - loss: 0.7294 - dense_9_loss: 0.3903 - all_loss: 0.1636 - lambda_3_loss: 0.1761 - val_loss: 0.7198 - val_dense_9_loss: 0.3917 - val_all_loss: 0.1583 - val_lambda_3_loss: 0.1684\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:16<00:00,  1.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 1s 68us/sample - loss: 1.3054 - dense_14_loss: 1.0260 - all_loss: 0.0587 - lambda_5_loss: 0.2211 - val_loss: 1.1691 - val_dense_14_loss: 0.8757 - val_all_loss: 0.0590 - val_lambda_5_loss: 0.2325\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 38us/sample - loss: 1.1417 - dense_14_loss: 0.8619 - all_loss: 0.0585 - lambda_5_loss: 0.2208 - val_loss: 1.1144 - val_dense_14_loss: 0.8234 - val_all_loss: 0.0587 - val_lambda_5_loss: 0.2324\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 38us/sample - loss: 1.0862 - dense_14_loss: 0.8079 - all_loss: 0.0588 - lambda_5_loss: 0.2204 - val_loss: 1.0633 - val_dense_14_loss: 0.7717 - val_all_loss: 0.0594 - val_lambda_5_loss: 0.2304\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 38us/sample - loss: 1.0522 - dense_14_loss: 0.7728 - all_loss: 0.0584 - lambda_5_loss: 0.2207 - val_loss: 1.0441 - val_dense_14_loss: 0.7535 - val_all_loss: 0.0589 - val_lambda_5_loss: 0.2311\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 39us/sample - loss: 1.0301 - dense_14_loss: 0.7509 - all_loss: 0.0584 - lambda_5_loss: 0.2203 - val_loss: 1.0236 - val_dense_14_loss: 0.7336 - val_all_loss: 0.0593 - val_lambda_5_loss: 0.2322\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:17<00:00,  1.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n",
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 102us/sample - loss: 1.0166 - dense_19_loss: 0.5733 - all_loss: 0.2203 - lambda_7_loss: 0.2220 - val_loss: 0.9141 - val_dense_19_loss: 0.4801 - val_all_loss: 0.2165 - val_lambda_7_loss: 0.2181\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 60us/sample - loss: 0.9013 - dense_19_loss: 0.4580 - all_loss: 0.2203 - lambda_7_loss: 0.2220 - val_loss: 0.8720 - val_dense_19_loss: 0.4379 - val_all_loss: 0.2165 - val_lambda_7_loss: 0.2181\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 60us/sample - loss: 0.8697 - dense_19_loss: 0.4269 - all_loss: 0.2203 - lambda_7_loss: 0.2220 - val_loss: 0.8522 - val_dense_19_loss: 0.4181 - val_all_loss: 0.2161 - val_lambda_7_loss: 0.2176\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 50us/sample - loss: 0.8531 - dense_19_loss: 0.4102 - all_loss: 0.2204 - lambda_7_loss: 0.2221 - val_loss: 0.8506 - val_dense_19_loss: 0.4172 - val_all_loss: 0.2163 - val_lambda_7_loss: 0.2179\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 57us/sample - loss: 0.8399 - dense_19_loss: 0.3970 - all_loss: 0.2204 - lambda_7_loss: 0.2221 - val_loss: 0.8321 - val_dense_19_loss: 0.3999 - val_all_loss: 0.2166 - val_lambda_7_loss: 0.2181\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:20<00:00,  1.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 1s 84us/sample - loss: 0.9074 - dense_24_loss: 0.5686 - all_loss: 0.1634 - lambda_9_loss: 0.1758 - val_loss: 0.7818 - val_dense_24_loss: 0.4521 - val_all_loss: 0.1588 - val_lambda_9_loss: 0.1691\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 43us/sample - loss: 0.7774 - dense_24_loss: 0.4385 - all_loss: 0.1636 - lambda_9_loss: 0.1759 - val_loss: 0.7490 - val_dense_24_loss: 0.4219 - val_all_loss: 0.1594 - val_lambda_9_loss: 0.1694\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 54us/sample - loss: 0.7546 - dense_24_loss: 0.4153 - all_loss: 0.1634 - lambda_9_loss: 0.1759 - val_loss: 0.7409 - val_dense_24_loss: 0.4127 - val_all_loss: 0.1594 - val_lambda_9_loss: 0.1693\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.7405 - dense_24_loss: 0.4010 - all_loss: 0.1635 - lambda_9_loss: 0.1758 - val_loss: 0.7294 - val_dense_24_loss: 0.4006 - val_all_loss: 0.1591 - val_lambda_9_loss: 0.1690\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.7310 - dense_24_loss: 0.3916 - all_loss: 0.1633 - lambda_9_loss: 0.1757 - val_loss: 0.7227 - val_dense_24_loss: 0.3957 - val_all_loss: 0.1596 - val_lambda_9_loss: 0.1696\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:20<00:00,  1.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 96us/sample - loss: 1.3045 - dense_29_loss: 1.0257 - all_loss: 0.0584 - lambda_11_loss: 0.2203 - val_loss: 1.1639 - val_dense_29_loss: 0.8724 - val_all_loss: 0.0596 - val_lambda_11_loss: 0.2324\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 47us/sample - loss: 1.1336 - dense_29_loss: 0.8540 - all_loss: 0.0584 - lambda_11_loss: 0.2209 - val_loss: 1.0954 - val_dense_29_loss: 0.8076 - val_all_loss: 0.0603 - val_lambda_11_loss: 0.2322\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 48us/sample - loss: 1.0752 - dense_29_loss: 0.7963 - all_loss: 0.0584 - lambda_11_loss: 0.2203 - val_loss: 1.0539 - val_dense_29_loss: 0.7638 - val_all_loss: 0.0587 - val_lambda_11_loss: 0.2313\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 48us/sample - loss: 1.0423 - dense_29_loss: 0.7632 - all_loss: 0.0584 - lambda_11_loss: 0.2207 - val_loss: 1.0378 - val_dense_29_loss: 0.7444 - val_all_loss: 0.0589 - val_lambda_11_loss: 0.2310\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 49us/sample - loss: 1.0209 - dense_29_loss: 0.7413 - all_loss: 0.0585 - lambda_11_loss: 0.2209 - val_loss: 1.0206 - val_dense_29_loss: 0.7300 - val_all_loss: 0.0590 - val_lambda_11_loss: 0.2320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:23<00:00,  1.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n",
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 110us/sample - loss: 1.0057 - dense_34_loss: 0.5628 - all_loss: 0.2205 - lambda_13_loss: 0.2222 - val_loss: 0.9111 - val_dense_34_loss: 0.4753 - val_all_loss: 0.2171 - val_lambda_13_loss: 0.2186\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 49us/sample - loss: 0.9025 - dense_34_loss: 0.4601 - all_loss: 0.2205 - lambda_13_loss: 0.2222 - val_loss: 0.8852 - val_dense_34_loss: 0.4509 - val_all_loss: 0.2160 - val_lambda_13_loss: 0.2175\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 49us/sample - loss: 0.8739 - dense_34_loss: 0.4308 - all_loss: 0.2205 - lambda_13_loss: 0.2222 - val_loss: 0.8585 - val_dense_34_loss: 0.4247 - val_all_loss: 0.2163 - val_lambda_13_loss: 0.2178\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 67us/sample - loss: 0.8547 - dense_34_loss: 0.4119 - all_loss: 0.2204 - lambda_13_loss: 0.2221 - val_loss: 0.8436 - val_dense_34_loss: 0.4092 - val_all_loss: 0.2165 - val_lambda_13_loss: 0.2181\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 64us/sample - loss: 0.8445 - dense_34_loss: 0.4021 - all_loss: 0.2206 - lambda_13_loss: 0.2223 - val_loss: 0.8373 - val_dense_34_loss: 0.4016 - val_all_loss: 0.2161 - val_lambda_13_loss: 0.2177\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:24<00:00,  1.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 121us/sample - loss: 0.8970 - dense_39_loss: 0.5574 - all_loss: 0.1635 - lambda_15_loss: 0.1758 - val_loss: 0.7780 - val_dense_39_loss: 0.4518 - val_all_loss: 0.1590 - val_lambda_15_loss: 0.1688\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.7718 - dense_39_loss: 0.4323 - all_loss: 0.1633 - lambda_15_loss: 0.1757 - val_loss: 0.7444 - val_dense_39_loss: 0.4163 - val_all_loss: 0.1591 - val_lambda_15_loss: 0.1691\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 2s 93us/sample - loss: 0.7473 - dense_39_loss: 0.4076 - all_loss: 0.1632 - lambda_15_loss: 0.1757 - val_loss: 0.7419 - val_dense_39_loss: 0.4145 - val_all_loss: 0.1587 - val_lambda_15_loss: 0.1687\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 2s 98us/sample - loss: 0.7333 - dense_39_loss: 0.3941 - all_loss: 0.1634 - lambda_15_loss: 0.1758 - val_loss: 0.7208 - val_dense_39_loss: 0.3955 - val_all_loss: 0.1601 - val_lambda_15_loss: 0.1697\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 2s 93us/sample - loss: 0.7237 - dense_39_loss: 0.3845 - all_loss: 0.1636 - lambda_15_loss: 0.1761 - val_loss: 0.7169 - val_dense_39_loss: 0.3882 - val_all_loss: 0.1586 - val_lambda_15_loss: 0.1685\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:27<00:00,  1.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 126us/sample - loss: 1.2909 - dense_44_loss: 1.0110 - all_loss: 0.0584 - lambda_17_loss: 0.2206 - val_loss: 1.1519 - val_dense_44_loss: 0.8592 - val_all_loss: 0.0589 - val_lambda_17_loss: 0.2308\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 64us/sample - loss: 1.1244 - dense_44_loss: 0.8450 - all_loss: 0.0584 - lambda_17_loss: 0.2206 - val_loss: 1.0897 - val_dense_44_loss: 0.7982 - val_all_loss: 0.0593 - val_lambda_17_loss: 0.2319\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 64us/sample - loss: 1.0756 - dense_44_loss: 0.7962 - all_loss: 0.0584 - lambda_17_loss: 0.2208 - val_loss: 1.0633 - val_dense_44_loss: 0.7727 - val_all_loss: 0.0596 - val_lambda_17_loss: 0.2330\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 64us/sample - loss: 1.0451 - dense_44_loss: 0.7657 - all_loss: 0.0586 - lambda_17_loss: 0.2212 - val_loss: 1.0349 - val_dense_44_loss: 0.7440 - val_all_loss: 0.0596 - val_lambda_17_loss: 0.2314\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 2s 106us/sample - loss: 1.0259 - dense_44_loss: 0.7471 - all_loss: 0.0584 - lambda_17_loss: 0.2209 - val_loss: 1.0085 - val_dense_44_loss: 0.7175 - val_all_loss: 0.0594 - val_lambda_17_loss: 0.2306\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:22<00:00,  1.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n",
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 128us/sample - loss: 1.0144 - dense_49_loss: 0.5710 - all_loss: 0.2204 - lambda_19_loss: 0.2221 - val_loss: 0.9140 - val_dense_49_loss: 0.4795 - val_all_loss: 0.2164 - val_lambda_19_loss: 0.2179\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 50us/sample - loss: 0.8995 - dense_49_loss: 0.4568 - all_loss: 0.2206 - lambda_19_loss: 0.2223 - val_loss: 0.8743 - val_dense_49_loss: 0.4389 - val_all_loss: 0.2164 - val_lambda_19_loss: 0.2179\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 51us/sample - loss: 0.8678 - dense_49_loss: 0.4252 - all_loss: 0.2204 - lambda_19_loss: 0.2221 - val_loss: 0.8500 - val_dense_49_loss: 0.4157 - val_all_loss: 0.2162 - val_lambda_19_loss: 0.2178\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 50us/sample - loss: 0.8523 - dense_49_loss: 0.4093 - all_loss: 0.2205 - lambda_19_loss: 0.2222 - val_loss: 0.8412 - val_dense_49_loss: 0.4056 - val_all_loss: 0.2159 - val_lambda_19_loss: 0.2175\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 50us/sample - loss: 0.8402 - dense_49_loss: 0.3977 - all_loss: 0.2205 - lambda_19_loss: 0.2222 - val_loss: 0.8394 - val_dense_49_loss: 0.4039 - val_all_loss: 0.2158 - val_lambda_19_loss: 0.2173\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:24<00:00,  1.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 135us/sample - loss: 0.9173 - dense_54_loss: 0.5782 - all_loss: 0.1638 - lambda_21_loss: 0.1762 - val_loss: 0.7886 - val_dense_54_loss: 0.4595 - val_all_loss: 0.1587 - val_lambda_21_loss: 0.1687\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.7791 - dense_54_loss: 0.4400 - all_loss: 0.1636 - lambda_21_loss: 0.1759 - val_loss: 0.7539 - val_dense_54_loss: 0.4279 - val_all_loss: 0.1594 - val_lambda_21_loss: 0.1691\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 54us/sample - loss: 0.7510 - dense_54_loss: 0.4115 - all_loss: 0.1632 - lambda_21_loss: 0.1756 - val_loss: 0.7319 - val_dense_54_loss: 0.4021 - val_all_loss: 0.1586 - val_lambda_21_loss: 0.1685\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 54us/sample - loss: 0.7353 - dense_54_loss: 0.3964 - all_loss: 0.1636 - lambda_21_loss: 0.1759 - val_loss: 0.7236 - val_dense_54_loss: 0.3943 - val_all_loss: 0.1585 - val_lambda_21_loss: 0.1686\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 55us/sample - loss: 0.7277 - dense_54_loss: 0.3888 - all_loss: 0.1636 - lambda_21_loss: 0.1759 - val_loss: 0.7147 - val_dense_54_loss: 0.3875 - val_all_loss: 0.1595 - val_lambda_21_loss: 0.1694\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:25<00:00,  1.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 2s 145us/sample - loss: 1.3045 - dense_59_loss: 1.0247 - all_loss: 0.0584 - lambda_23_loss: 0.2205 - val_loss: 1.1724 - val_dense_59_loss: 0.8801 - val_all_loss: 0.0591 - val_lambda_23_loss: 0.2315\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 51us/sample - loss: 1.1260 - dense_59_loss: 0.8465 - all_loss: 0.0584 - lambda_23_loss: 0.2205 - val_loss: 1.0827 - val_dense_59_loss: 0.7930 - val_all_loss: 0.0588 - val_lambda_23_loss: 0.2309\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 52us/sample - loss: 1.0649 - dense_59_loss: 0.7852 - all_loss: 0.0587 - lambda_23_loss: 0.2203 - val_loss: 1.0455 - val_dense_59_loss: 0.7548 - val_all_loss: 0.0590 - val_lambda_23_loss: 0.2312\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 1.0370 - dense_59_loss: 0.7576 - all_loss: 0.0584 - lambda_23_loss: 0.2205 - val_loss: 1.0290 - val_dense_59_loss: 0.7414 - val_all_loss: 0.0598 - val_lambda_23_loss: 0.2315\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 52us/sample - loss: 1.0187 - dense_59_loss: 0.7393 - all_loss: 0.0584 - lambda_23_loss: 0.2206 - val_loss: 1.0196 - val_dense_59_loss: 0.7255 - val_all_loss: 0.0588 - val_lambda_23_loss: 0.2299\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:25<00:00,  1.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n",
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 3s 159us/sample - loss: 1.0116 - dense_64_loss: 0.5692 - all_loss: 0.2204 - lambda_25_loss: 0.2221 - val_loss: 0.9008 - val_dense_64_loss: 0.4653 - val_all_loss: 0.2159 - val_lambda_25_loss: 0.2175\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 54us/sample - loss: 0.8932 - dense_64_loss: 0.4501 - all_loss: 0.2204 - lambda_25_loss: 0.2221 - val_loss: 0.8697 - val_dense_64_loss: 0.4340 - val_all_loss: 0.2165 - val_lambda_25_loss: 0.2180\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.8682 - dense_64_loss: 0.4249 - all_loss: 0.2204 - lambda_25_loss: 0.2221 - val_loss: 0.8559 - val_dense_64_loss: 0.4210 - val_all_loss: 0.2165 - val_lambda_25_loss: 0.2181\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 53us/sample - loss: 0.8539 - dense_64_loss: 0.4111 - all_loss: 0.2206 - lambda_25_loss: 0.2223 - val_loss: 0.8460 - val_dense_64_loss: 0.4127 - val_all_loss: 0.2166 - val_lambda_25_loss: 0.2181\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 52us/sample - loss: 0.8418 - dense_64_loss: 0.3988 - all_loss: 0.2205 - lambda_25_loss: 0.2222 - val_loss: 0.8371 - val_dense_64_loss: 0.4029 - val_all_loss: 0.2166 - val_lambda_25_loss: 0.2181\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:27<00:00,  1.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 3s 163us/sample - loss: 0.9181 - dense_69_loss: 0.5783 - all_loss: 0.1632 - lambda_27_loss: 0.1756 - val_loss: 0.7900 - val_dense_69_loss: 0.4618 - val_all_loss: 0.1587 - val_lambda_27_loss: 0.1689\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 56us/sample - loss: 0.7787 - dense_69_loss: 0.4395 - all_loss: 0.1634 - lambda_27_loss: 0.1757 - val_loss: 0.7500 - val_dense_69_loss: 0.4197 - val_all_loss: 0.1585 - val_lambda_27_loss: 0.1683\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 57us/sample - loss: 0.7538 - dense_69_loss: 0.4142 - all_loss: 0.1633 - lambda_27_loss: 0.1758 - val_loss: 0.7345 - val_dense_69_loss: 0.4087 - val_all_loss: 0.1593 - val_lambda_27_loss: 0.1694\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 57us/sample - loss: 0.7365 - dense_69_loss: 0.3971 - all_loss: 0.1636 - lambda_27_loss: 0.1760 - val_loss: 0.7234 - val_dense_69_loss: 0.3970 - val_all_loss: 0.1598 - val_lambda_27_loss: 0.1697\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 57us/sample - loss: 0.7268 - dense_69_loss: 0.3881 - all_loss: 0.1636 - lambda_27_loss: 0.1760 - val_loss: 0.7153 - val_dense_69_loss: 0.3848 - val_all_loss: 0.1582 - val_lambda_27_loss: 0.1682\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:27<00:00,  1.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 16261 samples, validate on 1807 samples\n",
      "Epoch 1/5\n",
      "16261/16261 [==============================] - 3s 162us/sample - loss: 1.2902 - dense_74_loss: 1.0110 - all_loss: 0.0584 - lambda_29_loss: 0.2205 - val_loss: 1.1692 - val_dense_74_loss: 0.8798 - val_all_loss: 0.0596 - val_lambda_29_loss: 0.2307\n",
      "Epoch 2/5\n",
      "16261/16261 [==============================] - 1s 50us/sample - loss: 1.1335 - dense_74_loss: 0.8550 - all_loss: 0.0584 - lambda_29_loss: 0.2206 - val_loss: 1.0922 - val_dense_74_loss: 0.8012 - val_all_loss: 0.0587 - val_lambda_29_loss: 0.2311\n",
      "Epoch 3/5\n",
      "16261/16261 [==============================] - 1s 51us/sample - loss: 1.0745 - dense_74_loss: 0.7955 - all_loss: 0.0584 - lambda_29_loss: 0.2208 - val_loss: 1.0568 - val_dense_74_loss: 0.7681 - val_all_loss: 0.0590 - val_lambda_29_loss: 0.2315\n",
      "Epoch 4/5\n",
      "16261/16261 [==============================] - 1s 51us/sample - loss: 1.0430 - dense_74_loss: 0.7648 - all_loss: 0.0586 - lambda_29_loss: 0.2207 - val_loss: 1.0327 - val_dense_74_loss: 0.7409 - val_all_loss: 0.0589 - val_lambda_29_loss: 0.2312\n",
      "Epoch 5/5\n",
      "16261/16261 [==============================] - 1s 52us/sample - loss: 1.0211 - dense_74_loss: 0.7429 - all_loss: 0.0586 - lambda_29_loss: 0.2205 - val_loss: 1.0219 - val_dense_74_loss: 0.7291 - val_all_loss: 0.0587 - val_lambda_29_loss: 0.2314\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:25<00:00,  1.14s/it]\n"
     ]
    }
   ],
   "source": [
    "median_rad = 1 * np.median(pdist(x_train))\n",
    "if calculate:\n",
    "    total_astuteness = np.zeros(shape=(run_times, len(lambda_dense_list), len(epsilon_range)))\n",
    "    for i in range(run_times):\n",
    "        print('Completing Run ' + str(i + 1) + ' of ' + str(run_times))\n",
    "        for (j, lambda_dense) in enumerate(lambda_dense_list):\n",
    "                all_layer_weights = pickle.load(open('extracted_weights/telescope_l2_' + str(j) + '.pk', 'rb'))\n",
    "                activation = 'relu'\n",
    "\n",
    "                model_input = Input(shape=(input_shape,), dtype='float32')\n",
    "\n",
    "                net = Dense(32, activation=activation, name='dense1',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(model_input)\n",
    "                net = Dense(32, activation=activation, name='dense2',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                net = Dense(32, activation=activation, name='dense3',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                net = Dense(32, activation=activation, name='dense4',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                preds = Dense(1, activation='sigmoid', name='dense5',\n",
    "                              kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                bbox_model = Model(model_input, preds)\n",
    "                bbox_model = set_all_weights(bbox_model, all_layer_weights)\n",
    "                pred_model = Model(model_input, preds)\n",
    "                model_builder = MLPModelBuilder(num_layers=4, num_units=32, activation=activation, verbose=1,\n",
    "                                batch_size=32, learning_rate=0.001, num_epochs=5, early_stopping_patience=15,\n",
    "                                with_bn=False)\n",
    "                explainer = CXPlain(pred_model, model_builder, masking_operation, loss, num_models=1)\n",
    "                explainer.fit(x_train, y_train)\n",
    "                for k in tqdm(range(len(epsilon_range))):\n",
    "                    _, total_astuteness[i, j, k], _ = calculate_robust_astute_sampled(data=x_val,\n",
    "                                                                                      explainer=explainer,\n",
    "                                                                                      explainer_type='cxplain',\n",
    "                                                                                      explanation_type='attribution',\n",
    "                                                                                      ball_r=median_rad,\n",
    "                                                                                      epsilon=epsilon_range[k],\n",
    "                                                                                      num_points=int(\n",
    "                                                                                          prop_points * len(\n",
    "                                                                                              x_val)),\n",
    "                                                                                      NN=True,\n",
    "                                                                                      data_explanation=None)     \n",
    "    pickle.dump(total_astuteness, open(save_astuteness_file, 'wb'))\n",
    "else:\n",
    "    total_astuteness = pickle.load(open(save_astuteness_file, 'rb'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3c83d3c1",
   "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": [
    "astuteness_mean = total_astuteness.mean(axis=0)\n",
    "astuteness_std = total_astuteness.std(axis=0)\n",
    "image_name = 'plots/cxplain_' + datatype + '_astuteness_classifiers.PNG'\n",
    "fig, ax = plt.subplots()\n",
    "for i in range(len(lambda_names)):\n",
    "    ax.errorbar(x=epsilon_range, y=astuteness_mean[i, :], yerr=astuteness_std[i, :],\n",
    "                label=lambda_names[i])\n",
    "plt.legend()\n",
    "plt.savefig(image_name)\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "04584e14",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(951, 10)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_val.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80cdd360",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
