{
 "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\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",
    "\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e2de30e6",
   "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 = 'rice'\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\n",
    "sd_dense = 0\n",
    "num_classes = 1\n",
    "lcc_norm = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6afce5d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "rice_pd = pd.read_excel('data/Rice_Osmancik_Cammeo_Dataset.xlsx')\n",
    "data = rice_pd.values[:, :-1]\n",
    "labels = rice_pd.values[:, -1]\n",
    "labels[labels == 'Cammeo'] = 0\n",
    "labels[labels == 'Osmancik'] = 1\n",
    "x_train, x_val, y_train, y_val = train_test_split(data, labels, test_size=0.33, 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": "004d077d",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_astuteness_file = 'plots/cxplain_' + datatype + '_astuteness_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": 7,
   "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 14:00:27.032672: 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 14:00:27.054072: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2022-05-18 14:00:27.054758: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x55a64da9e360 executing computations on platform Host. Devices:\n",
      "2022-05-18 14:00:27.054784: 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 2296 samples, validate on 256 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",
      "2296/2296 [==============================] - 1s 420us/sample - loss: 0.8231 - dense_4_loss: 0.3588 - all_loss: 0.2309 - lambda_1_loss: 0.2331 - val_loss: 0.8153 - val_dense_4_loss: 0.3507 - val_all_loss: 0.2313 - val_lambda_1_loss: 0.2333\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 115us/sample - loss: 0.7221 - dense_4_loss: 0.2579 - all_loss: 0.2309 - lambda_1_loss: 0.2331 - val_loss: 0.7542 - val_dense_4_loss: 0.2896 - val_all_loss: 0.2313 - val_lambda_1_loss: 0.2333\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 115us/sample - loss: 0.6856 - dense_4_loss: 0.2214 - all_loss: 0.2309 - lambda_1_loss: 0.2331 - val_loss: 0.7338 - val_dense_4_loss: 0.2691 - val_all_loss: 0.2313 - val_lambda_1_loss: 0.2333\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 110us/sample - loss: 0.6736 - dense_4_loss: 0.2096 - all_loss: 0.2309 - lambda_1_loss: 0.2331 - val_loss: 0.7171 - val_dense_4_loss: 0.2525 - val_all_loss: 0.2313 - val_lambda_1_loss: 0.2333\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 125us/sample - loss: 0.6666 - dense_4_loss: 0.2031 - all_loss: 0.2309 - lambda_1_loss: 0.2331 - val_loss: 0.7128 - val_dense_4_loss: 0.2481 - val_all_loss: 0.2313 - val_lambda_1_loss: 0.2333\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:48<00:00,  2.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 1s 441us/sample - loss: 0.5302 - dense_9_loss: 0.3196 - all_loss: 0.0982 - lambda_3_loss: 0.1115 - val_loss: 0.5502 - val_dense_9_loss: 0.3169 - val_all_loss: 0.1115 - val_lambda_3_loss: 0.1217\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 105us/sample - loss: 0.4430 - dense_9_loss: 0.2337 - all_loss: 0.0983 - lambda_3_loss: 0.1115 - val_loss: 0.5088 - val_dense_9_loss: 0.2756 - val_all_loss: 0.1115 - val_lambda_3_loss: 0.1217\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 95us/sample - loss: 0.4226 - dense_9_loss: 0.2124 - all_loss: 0.0982 - lambda_3_loss: 0.1115 - val_loss: 0.4965 - val_dense_9_loss: 0.2633 - val_all_loss: 0.1115 - val_lambda_3_loss: 0.1217\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 101us/sample - loss: 0.4133 - dense_9_loss: 0.2030 - all_loss: 0.0982 - lambda_3_loss: 0.1115 - val_loss: 0.4856 - val_dense_9_loss: 0.2524 - val_all_loss: 0.1115 - val_lambda_3_loss: 0.1217\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 98us/sample - loss: 0.4085 - dense_9_loss: 0.1986 - all_loss: 0.0983 - lambda_3_loss: 0.1115 - val_loss: 0.4842 - val_dense_9_loss: 0.2509 - val_all_loss: 0.1115 - val_lambda_3_loss: 0.1217\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:49<00:00,  2.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 674us/sample - loss: 0.8910 - dense_14_loss: 0.7648 - all_loss: 0.0456 - lambda_5_loss: 0.0794 - val_loss: 0.6735 - val_dense_14_loss: 0.5251 - val_all_loss: 0.0557 - val_lambda_5_loss: 0.0928\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 122us/sample - loss: 0.5032 - dense_14_loss: 0.3777 - all_loss: 0.0455 - lambda_5_loss: 0.0792 - val_loss: 0.5715 - val_dense_14_loss: 0.4231 - val_all_loss: 0.0557 - val_lambda_5_loss: 0.0928\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 135us/sample - loss: 0.4424 - dense_14_loss: 0.3175 - all_loss: 0.0456 - lambda_5_loss: 0.0794 - val_loss: 0.5381 - val_dense_14_loss: 0.3897 - val_all_loss: 0.0557 - val_lambda_5_loss: 0.0928\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 132us/sample - loss: 0.4223 - dense_14_loss: 0.2979 - all_loss: 0.0458 - lambda_5_loss: 0.0796 - val_loss: 0.5173 - val_dense_14_loss: 0.3689 - val_all_loss: 0.0557 - val_lambda_5_loss: 0.0928\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 118us/sample - loss: 0.4109 - dense_14_loss: 0.2857 - all_loss: 0.0455 - lambda_5_loss: 0.0793 - val_loss: 0.5066 - val_dense_14_loss: 0.3582 - val_all_loss: 0.0557 - val_lambda_5_loss: 0.0928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:55<00:00,  2.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n",
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 1s 609us/sample - loss: 0.7942 - dense_19_loss: 0.3303 - all_loss: 0.2310 - lambda_7_loss: 0.2331 - val_loss: 0.7918 - val_dense_19_loss: 0.3272 - val_all_loss: 0.2313 - val_lambda_7_loss: 0.2333\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 99us/sample - loss: 0.7037 - dense_19_loss: 0.2406 - all_loss: 0.2310 - lambda_7_loss: 0.2331 - val_loss: 0.7433 - val_dense_19_loss: 0.2787 - val_all_loss: 0.2313 - val_lambda_7_loss: 0.2333\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 105us/sample - loss: 0.6774 - dense_19_loss: 0.2133 - all_loss: 0.2309 - lambda_7_loss: 0.2330 - val_loss: 0.7203 - val_dense_19_loss: 0.2557 - val_all_loss: 0.2313 - val_lambda_7_loss: 0.2333\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 149us/sample - loss: 0.6663 - dense_19_loss: 0.2019 - all_loss: 0.2309 - lambda_7_loss: 0.2331 - val_loss: 0.7106 - val_dense_19_loss: 0.2460 - val_all_loss: 0.2313 - val_lambda_7_loss: 0.2333\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 122us/sample - loss: 0.6606 - dense_19_loss: 0.1966 - all_loss: 0.2310 - lambda_7_loss: 0.2332 - val_loss: 0.7041 - val_dense_19_loss: 0.2395 - val_all_loss: 0.2313 - val_lambda_7_loss: 0.2333\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:52<00:00,  2.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 1s 584us/sample - loss: 0.5287 - dense_24_loss: 0.3187 - all_loss: 0.0983 - lambda_9_loss: 0.1115 - val_loss: 0.5360 - val_dense_24_loss: 0.3028 - val_all_loss: 0.1115 - val_lambda_9_loss: 0.1217\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 102us/sample - loss: 0.4380 - dense_24_loss: 0.2284 - all_loss: 0.0984 - lambda_9_loss: 0.1116 - val_loss: 0.5085 - val_dense_24_loss: 0.2753 - val_all_loss: 0.1115 - val_lambda_9_loss: 0.1217\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 90us/sample - loss: 0.4217 - dense_24_loss: 0.2125 - all_loss: 0.0984 - lambda_9_loss: 0.1117 - val_loss: 0.4901 - val_dense_24_loss: 0.2568 - val_all_loss: 0.1115 - val_lambda_9_loss: 0.1217\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 113us/sample - loss: 0.4130 - dense_24_loss: 0.2038 - all_loss: 0.0985 - lambda_9_loss: 0.1117 - val_loss: 0.4873 - val_dense_24_loss: 0.2540 - val_all_loss: 0.1115 - val_lambda_9_loss: 0.1217\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 121us/sample - loss: 0.4080 - dense_24_loss: 0.1979 - all_loss: 0.0983 - lambda_9_loss: 0.1116 - val_loss: 0.4848 - val_dense_24_loss: 0.2516 - val_all_loss: 0.1115 - val_lambda_9_loss: 0.1217\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:45<00:00,  2.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 1s 472us/sample - loss: 0.9408 - dense_29_loss: 0.8150 - all_loss: 0.0456 - lambda_11_loss: 0.0795 - val_loss: 0.7420 - val_dense_29_loss: 0.5936 - val_all_loss: 0.0557 - val_lambda_11_loss: 0.0928\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 85us/sample - loss: 0.5410 - dense_29_loss: 0.4154 - all_loss: 0.0456 - lambda_11_loss: 0.0793 - val_loss: 0.6149 - val_dense_29_loss: 0.4665 - val_all_loss: 0.0557 - val_lambda_11_loss: 0.0928\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 70us/sample - loss: 0.4640 - dense_29_loss: 0.3388 - all_loss: 0.0455 - lambda_11_loss: 0.0794 - val_loss: 0.5681 - val_dense_29_loss: 0.4197 - val_all_loss: 0.0557 - val_lambda_11_loss: 0.0928\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 76us/sample - loss: 0.4358 - dense_29_loss: 0.3105 - all_loss: 0.0455 - lambda_11_loss: 0.0792 - val_loss: 0.5376 - val_dense_29_loss: 0.3892 - val_all_loss: 0.0557 - val_lambda_11_loss: 0.0928\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 78us/sample - loss: 0.4189 - dense_29_loss: 0.2937 - all_loss: 0.0456 - lambda_11_loss: 0.0794 - val_loss: 0.5157 - val_dense_29_loss: 0.3673 - val_all_loss: 0.0557 - val_lambda_11_loss: 0.0928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:46<00:00,  2.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n",
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 675us/sample - loss: 0.7994 - dense_34_loss: 0.3352 - all_loss: 0.2309 - lambda_13_loss: 0.2331 - val_loss: 0.7826 - val_dense_34_loss: 0.3179 - val_all_loss: 0.2313 - val_lambda_13_loss: 0.2333\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 69us/sample - loss: 0.7002 - dense_34_loss: 0.2356 - all_loss: 0.2310 - lambda_13_loss: 0.2331 - val_loss: 0.7443 - val_dense_34_loss: 0.2796 - val_all_loss: 0.2313 - val_lambda_13_loss: 0.2333\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 82us/sample - loss: 0.6793 - dense_34_loss: 0.2156 - all_loss: 0.2310 - lambda_13_loss: 0.2332 - val_loss: 0.7299 - val_dense_34_loss: 0.2652 - val_all_loss: 0.2313 - val_lambda_13_loss: 0.2333\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 91us/sample - loss: 0.6711 - dense_34_loss: 0.2071 - all_loss: 0.2309 - lambda_13_loss: 0.2330 - val_loss: 0.7186 - val_dense_34_loss: 0.2540 - val_all_loss: 0.2313 - val_lambda_13_loss: 0.2333\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 83us/sample - loss: 0.6638 - dense_34_loss: 0.1998 - all_loss: 0.2309 - lambda_13_loss: 0.2331 - val_loss: 0.7087 - val_dense_34_loss: 0.2441 - val_all_loss: 0.2313 - val_lambda_13_loss: 0.2333\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:46<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 723us/sample - loss: 0.5369 - dense_39_loss: 0.3267 - all_loss: 0.0983 - lambda_15_loss: 0.1116 - val_loss: 0.5472 - val_dense_39_loss: 0.3139 - val_all_loss: 0.1115 - val_lambda_15_loss: 0.1217\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 95us/sample - loss: 0.4433 - dense_39_loss: 0.2334 - all_loss: 0.0984 - lambda_15_loss: 0.1116 - val_loss: 0.5083 - val_dense_39_loss: 0.2750 - val_all_loss: 0.1115 - val_lambda_15_loss: 0.1217\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 83us/sample - loss: 0.4240 - dense_39_loss: 0.2142 - all_loss: 0.0983 - lambda_15_loss: 0.1116 - val_loss: 0.4962 - val_dense_39_loss: 0.2630 - val_all_loss: 0.1115 - val_lambda_15_loss: 0.1217\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 93us/sample - loss: 0.4152 - dense_39_loss: 0.2053 - all_loss: 0.0983 - lambda_15_loss: 0.1116 - val_loss: 0.4975 - val_dense_39_loss: 0.2642 - val_all_loss: 0.1115 - val_lambda_15_loss: 0.1217\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 112us/sample - loss: 0.4108 - dense_39_loss: 0.2013 - all_loss: 0.0984 - lambda_15_loss: 0.1116 - val_loss: 0.4866 - val_dense_39_loss: 0.2533 - val_all_loss: 0.1115 - val_lambda_15_loss: 0.1217\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:48<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 744us/sample - loss: 0.9642 - dense_44_loss: 0.8387 - all_loss: 0.0458 - lambda_17_loss: 0.0796 - val_loss: 0.7009 - val_dense_44_loss: 0.5524 - val_all_loss: 0.0557 - val_lambda_17_loss: 0.0928\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 101us/sample - loss: 0.5317 - dense_44_loss: 0.4067 - all_loss: 0.0456 - lambda_17_loss: 0.0793 - val_loss: 0.5912 - val_dense_44_loss: 0.4428 - val_all_loss: 0.0557 - val_lambda_17_loss: 0.0928\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 111us/sample - loss: 0.4590 - dense_44_loss: 0.3345 - all_loss: 0.0458 - lambda_17_loss: 0.0794 - val_loss: 0.5426 - val_dense_44_loss: 0.3941 - val_all_loss: 0.0557 - val_lambda_17_loss: 0.0928\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 81us/sample - loss: 0.4337 - dense_44_loss: 0.3093 - all_loss: 0.0457 - lambda_17_loss: 0.0793 - val_loss: 0.5167 - val_dense_44_loss: 0.3682 - val_all_loss: 0.0557 - val_lambda_17_loss: 0.0928\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 98us/sample - loss: 0.4167 - dense_44_loss: 0.2921 - all_loss: 0.0456 - lambda_17_loss: 0.0794 - val_loss: 0.5028 - val_dense_44_loss: 0.3544 - val_all_loss: 0.0557 - val_lambda_17_loss: 0.0928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:51<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n",
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 785us/sample - loss: 0.8045 - dense_49_loss: 0.3403 - all_loss: 0.2310 - lambda_19_loss: 0.2332 - val_loss: 0.7920 - val_dense_49_loss: 0.3274 - val_all_loss: 0.2313 - val_lambda_19_loss: 0.2333\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 80us/sample - loss: 0.7000 - dense_49_loss: 0.2356 - all_loss: 0.2309 - lambda_19_loss: 0.2331 - val_loss: 0.7355 - val_dense_49_loss: 0.2709 - val_all_loss: 0.2313 - val_lambda_19_loss: 0.2333\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 109us/sample - loss: 0.6749 - dense_49_loss: 0.2110 - all_loss: 0.2310 - lambda_19_loss: 0.2331 - val_loss: 0.7224 - val_dense_49_loss: 0.2577 - val_all_loss: 0.2313 - val_lambda_19_loss: 0.2333\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 119us/sample - loss: 0.6659 - dense_49_loss: 0.2017 - all_loss: 0.2310 - lambda_19_loss: 0.2332 - val_loss: 0.7140 - val_dense_49_loss: 0.2494 - val_all_loss: 0.2313 - val_lambda_19_loss: 0.2333\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 96us/sample - loss: 0.6598 - dense_49_loss: 0.1958 - all_loss: 0.2310 - lambda_19_loss: 0.2331 - val_loss: 0.7065 - val_dense_49_loss: 0.2419 - val_all_loss: 0.2313 - val_lambda_19_loss: 0.2333\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:50<00:00,  2.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 887us/sample - loss: 0.5181 - dense_54_loss: 0.3077 - all_loss: 0.0982 - lambda_21_loss: 0.1115 - val_loss: 0.5284 - val_dense_54_loss: 0.2952 - val_all_loss: 0.1115 - val_lambda_21_loss: 0.1217\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 102us/sample - loss: 0.4362 - dense_54_loss: 0.2259 - all_loss: 0.0982 - lambda_21_loss: 0.1114 - val_loss: 0.5039 - val_dense_54_loss: 0.2707 - val_all_loss: 0.1115 - val_lambda_21_loss: 0.1217\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 119us/sample - loss: 0.4211 - dense_54_loss: 0.2113 - all_loss: 0.0984 - lambda_21_loss: 0.1117 - val_loss: 0.4996 - val_dense_54_loss: 0.2664 - val_all_loss: 0.1115 - val_lambda_21_loss: 0.1217\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 117us/sample - loss: 0.4150 - dense_54_loss: 0.2050 - all_loss: 0.0983 - lambda_21_loss: 0.1116 - val_loss: 0.4877 - val_dense_54_loss: 0.2544 - val_all_loss: 0.1115 - val_lambda_21_loss: 0.1217\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 87us/sample - loss: 0.4087 - dense_54_loss: 0.1990 - all_loss: 0.0984 - lambda_21_loss: 0.1116 - val_loss: 0.4819 - val_dense_54_loss: 0.2486 - val_all_loss: 0.1115 - val_lambda_21_loss: 0.1217\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:53<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 960us/sample - loss: 0.8350 - dense_59_loss: 0.7096 - all_loss: 0.0456 - lambda_23_loss: 0.0792 - val_loss: 0.6626 - val_dense_59_loss: 0.5142 - val_all_loss: 0.0557 - val_lambda_23_loss: 0.0928\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 104us/sample - loss: 0.4954 - dense_59_loss: 0.3702 - all_loss: 0.0457 - lambda_23_loss: 0.0795 - val_loss: 0.5748 - val_dense_59_loss: 0.4264 - val_all_loss: 0.0557 - val_lambda_23_loss: 0.0928\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 120us/sample - loss: 0.4464 - dense_59_loss: 0.3216 - all_loss: 0.0458 - lambda_23_loss: 0.0795 - val_loss: 0.5371 - val_dense_59_loss: 0.3886 - val_all_loss: 0.0557 - val_lambda_23_loss: 0.0928\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 84us/sample - loss: 0.4271 - dense_59_loss: 0.3027 - all_loss: 0.0458 - lambda_23_loss: 0.0795 - val_loss: 0.5229 - val_dense_59_loss: 0.3745 - val_all_loss: 0.0557 - val_lambda_23_loss: 0.0928\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 118us/sample - loss: 0.4146 - dense_59_loss: 0.2895 - all_loss: 0.0456 - lambda_23_loss: 0.0793 - val_loss: 0.5156 - val_dense_59_loss: 0.3671 - val_all_loss: 0.0557 - val_lambda_23_loss: 0.0928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:53<00:00,  2.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n",
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 2s 1ms/sample - loss: 0.8126 - dense_64_loss: 0.3484 - all_loss: 0.2310 - lambda_25_loss: 0.2331 - val_loss: 0.7959 - val_dense_64_loss: 0.3313 - val_all_loss: 0.2313 - val_lambda_25_loss: 0.2333\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 133us/sample - loss: 0.7005 - dense_64_loss: 0.2367 - all_loss: 0.2310 - lambda_25_loss: 0.2331 - val_loss: 0.7310 - val_dense_64_loss: 0.2664 - val_all_loss: 0.2313 - val_lambda_25_loss: 0.2333\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 108us/sample - loss: 0.6739 - dense_64_loss: 0.2100 - all_loss: 0.2309 - lambda_25_loss: 0.2331 - val_loss: 0.7174 - val_dense_64_loss: 0.2527 - val_all_loss: 0.2313 - val_lambda_25_loss: 0.2333\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 105us/sample - loss: 0.6667 - dense_64_loss: 0.2029 - all_loss: 0.2310 - lambda_25_loss: 0.2331 - val_loss: 0.7159 - val_dense_64_loss: 0.2513 - val_all_loss: 0.2313 - val_lambda_25_loss: 0.2333\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 116us/sample - loss: 0.6602 - dense_64_loss: 0.1957 - all_loss: 0.2310 - lambda_25_loss: 0.2331 - val_loss: 0.7072 - val_dense_64_loss: 0.2426 - val_all_loss: 0.2313 - val_lambda_25_loss: 0.2333\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:58<00:00,  2.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 3s 1ms/sample - loss: 0.5509 - dense_69_loss: 0.3404 - all_loss: 0.0982 - lambda_27_loss: 0.1115 - val_loss: 0.5468 - val_dense_69_loss: 0.3135 - val_all_loss: 0.1115 - val_lambda_27_loss: 0.1217\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 100us/sample - loss: 0.4483 - dense_69_loss: 0.2381 - all_loss: 0.0983 - lambda_27_loss: 0.1115 - val_loss: 0.5100 - val_dense_69_loss: 0.2767 - val_all_loss: 0.1115 - val_lambda_27_loss: 0.1217\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 115us/sample - loss: 0.4263 - dense_69_loss: 0.2163 - all_loss: 0.0982 - lambda_27_loss: 0.1115 - val_loss: 0.5012 - val_dense_69_loss: 0.2679 - val_all_loss: 0.1115 - val_lambda_27_loss: 0.1217\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 103us/sample - loss: 0.4171 - dense_69_loss: 0.2070 - all_loss: 0.0983 - lambda_27_loss: 0.1115 - val_loss: 0.4954 - val_dense_69_loss: 0.2621 - val_all_loss: 0.1115 - val_lambda_27_loss: 0.1217\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 93us/sample - loss: 0.4120 - dense_69_loss: 0.2022 - all_loss: 0.0983 - lambda_27_loss: 0.1116 - val_loss: 0.4854 - val_dense_69_loss: 0.2522 - val_all_loss: 0.1115 - val_lambda_27_loss: 0.1217\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:59<00:00,  2.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train on 2296 samples, validate on 256 samples\n",
      "Epoch 1/5\n",
      "2296/2296 [==============================] - 3s 1ms/sample - loss: 0.9266 - dense_74_loss: 0.8007 - all_loss: 0.0456 - lambda_29_loss: 0.0793 - val_loss: 0.7066 - val_dense_74_loss: 0.5581 - val_all_loss: 0.0557 - val_lambda_29_loss: 0.0928\n",
      "Epoch 2/5\n",
      "2296/2296 [==============================] - 0s 97us/sample - loss: 0.5145 - dense_74_loss: 0.3893 - all_loss: 0.0455 - lambda_29_loss: 0.0791 - val_loss: 0.5749 - val_dense_74_loss: 0.4265 - val_all_loss: 0.0557 - val_lambda_29_loss: 0.0928\n",
      "Epoch 3/5\n",
      "2296/2296 [==============================] - 0s 100us/sample - loss: 0.4482 - dense_74_loss: 0.3226 - all_loss: 0.0456 - lambda_29_loss: 0.0792 - val_loss: 0.5447 - val_dense_74_loss: 0.3963 - val_all_loss: 0.0557 - val_lambda_29_loss: 0.0928\n",
      "Epoch 4/5\n",
      "2296/2296 [==============================] - 0s 125us/sample - loss: 0.4258 - dense_74_loss: 0.3004 - all_loss: 0.0455 - lambda_29_loss: 0.0792 - val_loss: 0.5143 - val_dense_74_loss: 0.3658 - val_all_loss: 0.0557 - val_lambda_29_loss: 0.0928\n",
      "Epoch 5/5\n",
      "2296/2296 [==============================] - 0s 111us/sample - loss: 0.4133 - dense_74_loss: 0.2886 - all_loss: 0.0457 - lambda_29_loss: 0.0796 - val_loss: 0.4973 - val_dense_74_loss: 0.3488 - val_all_loss: 0.0557 - val_lambda_29_loss: 0.0928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [00:54<00:00,  2.48s/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/rice_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",
    "            \n",
    "    pickle.dump(total_astuteness, open(save_astuteness_file, 'wb'))\n",
    "\n",
    "else:\n",
    "    total_astuteness = pickle.load(open(save_astuteness_file, 'rb'))\n",
    "astuteness_mean = total_astuteness.mean(axis=0)\n",
    "astuteness_std = total_astuteness.std(axis=0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "214f3e3e",
   "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": [
    "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()"
   ]
  }
 ],
 "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
}
