{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fbbacfce",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "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",
      "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",
      "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",
      "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",
      "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",
      "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"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import argparse\n",
    "import pickle\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import shap\n",
    "from scipy.spatial.distance import pdist\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",
    "\n",
    "from utils.explanations import calculate_stability, calculate_robust_astute_sampled"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fbb842f4",
   "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": "6f4041cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "run_times = 5\n",
    "prop_points = 0.05\n",
    "calculate = True\n",
    "epsilon_range = np.arange(0.01, 1.1, 0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba09a537",
   "metadata": {},
   "outputs": [],
   "source": [
    "lambda_dense_list = [float(0.7), float(1), float(\"inf\")]\n",
    "lambda_names = ['Regularized High', 'Regularized Low', 'Not Regularized']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9780888c",
   "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 17:24:29.975073: 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 17:24:29.998028: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2022-05-18 17:24:29.998462: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x5560b4109660 executing computations on platform Host. Devices:\n",
      "2022-05-18 17:24:29.998484: I tensorflow/compiler/xla/service/service.cc:158]   StreamExecutor device (0): <undefined>, <undefined>\n",
      "Using TensorFlow backend.\n",
      "100%|█████████████████████████████████████████████████| 22/22 [09:15<00:00, 25.23s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [09:35<00:00, 26.18s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [09:29<00:00, 25.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:41<00:00, 23.72s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:52<00:00, 21.47s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:02<00:00, 21.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:07<00:00, 22.18s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:12<00:00, 22.38s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:07<00:00, 22.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:56<00:00, 21.65s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:02<00:00, 21.92s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:35<00:00, 23.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [09:17<00:00, 25.35s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:47<00:00, 23.97s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [09:04<00:00, 24.75s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 1 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [09:17<00:00, 25.35s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [09:18<00:00, 25.37s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:34<00:00, 23.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:36<00:00, 20.73s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:29<00:00, 20.41s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:31<00:00, 20.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:48<00:00, 21.30s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:51<00:00, 21.41s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:47<00:00, 21.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:42<00:00, 21.02s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:39<00:00, 20.91s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:36<00:00, 20.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:14<00:00, 19.75s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:27<00:00, 20.35s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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ie89oTCXuDd/3Xzmr5vf02VIF4nOEXonFxU551hZsJJHtjzCyQNOZsmlSxiSFvhlxiIi0SRKR+jt39iixlvDXX+/i8VbFnPZyMtYNXVVc5ivmLKCFVNWdGelIjHNzLjtttuaH+fm5nLfffd1uM/atWspLCxs87X77ruPoUOHMnHiRMaNG8ezzz4bznIBePvttwO+SrOoqIirrroq5M++7777yM3NDfl92hOlge6BvpnQ+9hLfb+o/IJ56+bx2u7X+PkZPyf327mkJIW3+Y2IfC05OZmXXnqJkpISv/fpKNABbr31VvLy8nj55Zf5yU9+Ql1dXThKDZrX62XIkCG88MILPVqHP6J3yqXV/HnegTxu+b+3UO2tZsklS7hkxCU9VJxI93vow4f451f/7HS7pm38mUcfmzmWO87uuDlVYmIiCxYs4JFHHuHBBx885rW9e/dy/fXXc/DgQbKyslixYgUej4dXXnmFd955h3//93/nxRdfZPTo0W2+95gxY0hJSeHQoUMMHjyYhx9+mOeff57a2lpmzJjR3Dr3gQceYPXq1QwfPpxBgwYxadIkbr/9di6++GJyc3PJycmhpKSEnJwcPvvss2M+48MPP+SWW26hurqavn37smLFCk455RRWrlzJa6+9Rk1NDZWVlSxfvpxp06aRn5/PjTfe2HzDjf3797No0SLuvffedut78MEHWbVqFcOHDycrK4tJkyZ1+ncfrOgN9AHZzQ//suMvPPDBAxyfejxPfu9JThpwUs/VJhJnbrrpJsaPH88vf/nLY55ftGgRc+bMYe7cuSxfvpxf/OIXrF27liuvvJJp06Z1OoXx0UcfMWbMGAYPHsz69evZsWMHH374Ic45rrzySjZs2EBKSgovvvgi//jHP/B6vZx55pkBBebYsWPZsGEDiYmJvPnmm9x9993NvWY2btzItm3byMzMPOYHwZNPPgn4fmBdfvnlzJs3r936UlNTWbNmTdD1BSp6Az17Mt4GL7mbc1m9fTXnnnAuud/OJSM5o6erE+l2nY2kmzSNzMN5Lqlfv37MmTOHJUuW0Lfv1/f33bhxIy+99BLga0XbOvDb88gjj/DEE0+we/du1q1bB8D69etZv359c4+XiooKduzYQXl5OdOnT2/+3CuuuCKg2svKypg7dy47duzAzI6Z3rnsssvIzMxsc7+amhquvvpqHnvs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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 1 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:38<00:00, 20.84s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:35<00:00, 20.71s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:41<00:00, 20.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:45<00:00, 21.14s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:38<00:00, 20.82s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:32<00:00, 20.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:16<00:00, 19.83s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:13<00:00, 19.69s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:19<00:00, 19.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:31<00:00, 20.54s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:33<00:00, 20.62s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:31<00:00, 20.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [07:32<00:00, 20.57s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:31<00:00, 20.53s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [07:33<00:00, 20.60s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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jkwWjlrI1P5TGRg/UKoChN/rbCTdouXf8vJpyw07d+/evZk9ezYvv/wyUVE/rODOzc1l1apVgLMV7dkJvyMvvPACr732GocPH2btWueakfXr17N+/frWHi91dXUcPHiQ2tpaZs6c2XreG2+80a3Yq6urufvuuzl48CBKqTOmd6ZOnUpiYvsryRsbG7n11lt55ZVX6N+/P3/+8587jO/mm29u7Xve0i/eUzpN6EopE7AEmAqUANuVUmu01m0nwaYDg5s/xgH/3fzZsxwOOF3oTNZnJ++mmh+2i4yH5KEQk4yOTeFg1YHWkfih04cAGNFnBP8+5t+5rv91ZPbK9HjoQgSTBx98kNGjRzN3bseDH1fb0j700EM88sgjrFq1itmzZ1NQUIDWmt/+9rfcd999Z2z7wgsvdHicti1522vHC/D73/+eq6++mv/93//l6NGjTJkypfW9jtrxAixYsICf/vSnrY+56yi+F1980fB2vOfjygh9LHBIa30YQCm1EpgJtE3oM4G3tLPT19dKqXilVF+t9TGjA87b/z5//24pNFY7P7T9hzdDoyCyNwy4xNnnPLK3M5mHRoICx8FqdmOmcM3/QaEYfcFoFo1dxLX9riU1puOnkxg5mhEiGCUmJnLbbbfxxhtvMG/ePMD5YIeVK1dy11138e677zJ58mQAevXqRW1tbafH/OlPf8qbb77Jm2++yfXXX8/vf/977rzzTmJjYyktLSUsLIzJkydz33338dvf/habzcbHH3/MvffeCzi7HO7cuZOxY8d2eEOzurqa9HRn5dqKFStcutYlS5ZQW1vLokWLWr/WUXxXXnklc+bMYdGiRdhsNv7xj3+ck/SN5EpCTweK27wu4dzRd3vbpANnJHSl1HxgPkC/fv3cjRWAitpjfN1UDqGh0DsRTKEQEub8rFqKduxgq4S6Sqhru3cjAwhj9vjfck2/a2TFpxAGevjhh3nllVdaX7/88svMmzeP5557rvWmKMCsWbO49957efnll/nggw86vCkK8Nhjj3HHHXeQn59Pfn4+EyY4eznFxsbyzjvvcPnll3PTTTcxcuRI+vfvT3Z2dmtL3kceeYTbbruNt99+m2uuab9C7Te/+Q133303zz//fIfbnG3x4sWEhYW1tuJdsGABCxYsaDe+0aNHc/vttzNq1Cj69+/vkacUtdVp+1yl1K3A9Vrre5pf3wWM1Vr/os02HwN/0lpvaX69EfiN1npnR8ftavtcIYRTILbP9YS6ujpiY2Opr6/nyiuv5NVXX2X06NG+DssQnmifWwK0nVTOAMq6sI0QQhhu/vz57N+/n8bGRu6+++6gSeZd4UpC3w4MVkoNAEqBWcAdZ22zBljYPL8+Dqj2xPy5EEKc7W9/+5uvQ/AbnSZ0rbVNKbUQWIezbHGZ1nqfUmpB8/tLgU9wliwewlm2KHV+QniB1tqrVRTCe7ryNDmX6tC11p/gTNptv7a0zX9r4AG3zy6E6LLIyEgqKipISkqSpB5ktNZUVFQQGeneg+h71kpRIYJIRkYGJSUllJeX+zoU4QGRkZFkZGS4tY8kdCECVFhYGAMGDPB1GMKP9Kxui0IIEcQkoQshRJCQhC6EEEGi05WiHjuxUuVAoZu79QFc76QfmHrCNYJcZ7CR6/Se/lrr5Pbe8FlC7wql1I6OlrwGi55wjSDXGWzkOv2DTLkIIUSQkIQuhBBBItAS+qu+DsALesI1glxnsJHr9AMBNYcuhBCiY4E2QhdCCNEBSehCCBEk/C6hK6WmKaW+V0odUkotaud9pZR6ufn9PUqpgOxm78J13tl8fXuUUluVUiN9EWd3dXadbba7XCllV0rd4s34jOLKdSqlpiildiml9imlvvR2jEZw4d9tnFLqH0qp3c3XGZCttJVSy5RSJ5VSeR287595SGvtNx84+60XAAOBcGA3MOysbW4APgUUMB7Y5uu4PXSdE4GE5v+eHqzX2Wa7z3G2aL7F13F76OcZj/PB6v2aX6f4Om4PXefvgGea/zsZqATCfR17F671SmA0kNfB+36Zh/xthD4WOKS1Pqy1tgArgZlnbTMTeEs7fQ3EK6X6ejvQbur0OrXWW7XWVc0vv8b5WL9A48rPE+AXwIfASW8GZyBXrvMOYJXWughAax2I1+rKdWqgl3I2aI/FmdBt3g2z+7TWm3HG3hG/zEP+ltDTgeI2r0uav+buNv7O3Wv4Gc7RQKDp9DqVUunAzcBSApcrP8+LgASl1Cal1E6l1GyvRWccV67zFeBinM8U3gv8Smvt8E54XuWXecjf+qG399iVs+sqXdnG37l8DUqpq3Em9MkejcgzXLnOF4FHtdb2AH7qjivXGQqMAa4FooBcpdTXWusDng7OQK5c5/XALuAaYBDwmVLqK611jYdj8za/zEP+ltBLgMw2rzNw/qZ3dxt/59I1KKVGAK8D07XWFV6KzUiuXGc2sLI5mfcBblBK2bTWq70SoTFc/Xd7SmttBsxKqc3ASCCQEror1zkXeFo7J5oPKaWOAEOBb7wTotf4ZR7ytymX7cBgpdQApVQ4MAtYc9Y2a4DZzXeZxwPVWutj3g60mzq9TqVUP2AVcFeAjeLa6vQ6tdYDtNZZWuss4APg5wGWzMG1f7cfAVcopUKVUtHAOCDfy3F2lyvXWYTzrxCUUhcAQ4DDXo3SO/wyD/nVCF1rbVNKLQTW4byjvkxrvU8ptaD5/aU4KyFuAA4B9ThHBAHFxet8DEgC/tI8erVpP+7y1h4XrzPguXKdWut8pdRaYA/gAF7XWrdbEuevXPx5/gFYoZTai3Na4lGtta/bzbpNKfUeMAXoo5QqAR4HwsC/85As/RdCiCDhb1MuQgghukgSuhBCBAlJ6EIIESQkoQshRJCQhC6EEEFCEroQQgQJSehCCBEk/j8rv7viAyj8bAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 1 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:09<00:00, 22.23s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:23<00:00, 22.88s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:36<00:00, 23.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:33<00:00, 23.36s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:40<00:00, 23.64s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:37<00:00, 23.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:39<00:00, 23.61s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:33<00:00, 23.34s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:15<00:00, 22.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:14<00:00, 22.48s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:34<00:00, 23.39s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:34<00:00, 23.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████| 22/22 [08:47<00:00, 24.00s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:45<00:00, 23.90s/it]\n",
      "100%|█████████████████████████████████████████████████| 22/22 [08:48<00:00, 24.03s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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a60POL1KVzCgbW7KiRQUisHdBrttm0K4UlBQEOnp6ezevZvIyEgWLlxodEnU1tby17/+leuuu86Q7c+aNYspU6YYsu0WZ7lorS1KqdnA19imLS7RWu9RSs2qe34R8ATQFXizbtzHorU292GoAW1zU/JS6B/Zn84Bnd22TeEdnvpyD3uPnW5xvb3Hbes4Mo4+4PzOPHnjxQ7XMGLECHbu3AlAZmYmDzzwAAUFBQQHB/POO+/Qv39/MjMzueuuu6itrWXcuHG8/PLLlJWV8d133zF//nzWrl0LwOzZs0lKSmLatGlnbeO+++4jOTmZiooKbr31Vp566ikAEhISmDFjBhs3bmT27Nls2LCBCRMmkJCQwD333APYgn737t1orZutLzs7m8mTJ2OxWBg7dqzD+97QvHnzCA0NZc6cOSQnJ/P73/+ekJAQRo0axVdffcXu3bsBOHbsGGPHjiUzM5Obb76ZF198sU3ba8ihC4u01uu11hdorftorZ+te2xRXZijtb5Hax2htR5U92XuMAe3T1msqa1hR8EOGT8XHqm2tpZNmzZx0003ATBz5kxef/11UlNTmT9/Pvfffz8ADz30EA899BDJycmcf/75rd7Os88+S0pKCjt37uT777+3f4CAbd72Dz/8wKRJk+yPJSUlkZ6eTnp6OmPHjmXOnDkt1lf/odG9e/dm66ioqGDQoEH2ryeeeKLJ9aZPn86iRYvYunUrvr5n3wg+PT2df/7zn+zatYt//vOfHDlypMn3aA2HLizySG5um7v71G6qaqtk/Fy4hKNH0vVH5v/8wwinbLc+2HJychg6dChjxoyhrKyMn376idtuu82+XlVVFQBbt25l9erVAEyePNkesI765JNPWLx4MRaLhePHj7N3714SE20tNO64445zvi4tLY2NGzees74ff/yRzz//HIC7776bxx5rcn6Hfaip3rJly341zl9cXExpaSkjR46072/9byAA1157LV26dAFgwIABHDp0iLi4ONrDiwM9x9Y2N6z5T2FnSjlh+2EP6TbELdsTwh3qg62kpIQJEyawcOFCpk2bRnh4+FmB1xI/Pz+sVqt9uan519nZ2cyfP5/k5GQiIiKYNm3aWeuFhDQ9FXjPnj08+eSTbN68GV9fX6xW6znrc9a8fq2bnAxo16lTJ/uffX19sVgs7d6m9/ZycXPb3JS8FPqG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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for datatype in ['orange_skin', 'nonlinear_additive', 'switch']:\n",
    "    save_astuteness_file = 'plots/shap_' + datatype + '_astuteness_lip.pk'\n",
    "    data_dict = pickle.load(open('data/' + datatype + '.pk', 'rb'))\n",
    "\n",
    "    x_train, y_train, x_val, _, _, input_shape = data_dict['x_train'], data_dict['y_train'], \\\n",
    "                                       data_dict['x_val'], data_dict['y_val'], \\\n",
    "                                       data_dict['datatype_val'], data_dict['input_shape']\n",
    "    median_rad = 0.5 * np.median(pdist(x_val))\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/' + datatype + '_l2_' + str(j) + '.pk', 'rb'))\n",
    "                activation = 'selu' if datatype in ['switch'] else 'relu'\n",
    "\n",
    "                model_input = Input(shape=(input_shape,), dtype='float32')\n",
    "\n",
    "                net = Dense(50, activation=activation, name='dense1',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(model_input)\n",
    "                net = Dense(50, activation=activation, name='dense2',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                net = Dense(50, activation=activation, name='dense3',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                net = Dense(50, activation=activation, name='dense4',\n",
    "                            kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                preds = Dense(2, activation='softmax', 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",
    "                background = x_train[np.random.choice(len(x_train), 100, replace=False)]\n",
    "                fname = 'explained_weights/shap/' + 'shap_' + datatype + '_' + str(j) + '_' + str(i) + '_lip.gz'\n",
    "                explanations = np.loadtxt(fname, delimiter=',')\n",
    "                explainer = shap.GradientExplainer(pred_model, background)\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='shap',\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=explanations)\n",
    "        pickle.dump(total_astuteness, open(save_astuteness_file, 'wb'))\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",
    "    image_name = 'plots/shap_' + 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": 7,
   "id": "6d947b4b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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a60POL1KVzCgbW7KiRQUisHdBrttm0K4UlBQEOnp6ezevZvIyEgWLlxodEnU1tby17/+leuuu86Q7c+aNYspU6YYsu0WZ7lorS1KqdnA19imLS7RWu9RSs2qe34R8ATQFXizbtzHorU292GoAW1zU/JS6B/Zn84Bnd22TeEdnvpyD3uPnW5xvb3Hbes4Mo4+4PzOPHnjxQ7XMGLECHbu3AlAZmYmDzzwAAUFBQQHB/POO+/Qv39/MjMzueuuu6itrWXcuHG8/PLLlJWV8d133zF//nzWrl0LwOzZs0lKSmLatGlnbeO+++4jOTmZiooKbr31Vp566ikAEhISmDFjBhs3bmT27Nls2LCBCRMmkJCQwD333APYgn737t1orZutLzs7m8mTJ2OxWBg7dqzD+97QvHnzCA0NZc6cOSQnJ/P73/+ekJAQRo0axVdffcXu3bsBOHbsGGPHjiUzM5Obb76ZF198sU3ba8ihC4u01uu11hdorftorZ+te2xRXZijtb5Hax2htR5U92XuMAe3T1msqa1hR8EOGT8XHqm2tpZNmzZx0003ATBz5kxef/11UlNTmT9/Pvfffz8ADz30EA899BDJycmcf/75rd7Os88+S0pKCjt37uT777+3f4CAbd72Dz/8wKRJk+yPJSUlkZ6eTnp6OmPHjmXOnDkt1lf/odG9e/dm66ioqGDQoEH2ryeeeKLJ9aZPn86iRYvYunUrvr5n3wg+PT2df/7zn+zatYt//vOfHDlypMn3aA2HLizySG5um7v71G6qaqtk/Fy4hKNH0vVH5v/8wwinbLc+2HJychg6dChjxoyhrKyMn376idtuu82+XlVVFQBbt25l9erVAEyePNkesI765JNPWLx4MRaLhePHj7N3714SE20tNO64445zvi4tLY2NGzees74ff/yRzz//HIC7776bxx5rcn6Hfaip3rJly341zl9cXExpaSkjR46072/9byAA1157LV26dAFgwIABHDp0iLi4ONrDiwM9x9Y2N6z5T2FnSjlh+2EP6TbELdsTwh3qg62kpIQJEyawcOFCpk2bRnh4+FmB1xI/Pz+sVqt9uan519nZ2cyfP5/k5GQiIiKYNm3aWeuFhDQ9FXjPnj08+eSTbN68GV9fX6xW6znrc9a8fq2bnAxo16lTJ/uffX19sVgs7d6m9/ZycXPb3JS8FPqG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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/shap_' + 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
}
