{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a14be877",
   "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 matplotlib.pyplot as plt\n",
    "\n",
    "import pickle\n",
    "import numpy as np\n",
    "import argparse\n",
    "\n",
    "import pandas as pd\n",
    "import pickle\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "from scipy.spatial.distance import pdist\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": "d59adf0a",
   "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": "4c1973f3",
   "metadata": {},
   "outputs": [],
   "source": [
    "datatype = 'rice'\n",
    "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": "d397c000",
   "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": "c15a2797",
   "metadata": {},
   "outputs": [],
   "source": [
    "median_rad = 1 * np.median(pdist(x_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "174b19b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_astuteness_file = 'plots/shap_' + 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": "755a1b35",
   "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 16:15:32.516109: 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 16:15:32.519411: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2022-05-18 16:15:32.519855: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x55f211f67fa0 executing computations on platform Host. Devices:\n",
      "2022-05-18 16:15:32.519872: I tensorflow/compiler/xla/service/service.cc:158]   StreamExecutor device (0): <undefined>, <undefined>\n",
      "Using TensorFlow backend.\n",
      "100%|█████████████████████████████████████| 22/22 [04:14<00:00, 11.56s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:25<00:00, 12.07s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:25<00:00, 12.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [04:27<00:00, 12.14s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:29<00:00, 12.25s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:27<00:00, 12.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [04:25<00:00, 12.09s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:26<00:00, 12.13s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:24<00:00, 12.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [04:26<00:00, 12.13s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:13<00:00, 11.54s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:59<00:00, 10.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [03:41<00:00, 10.08s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:40<00:00, 10.04s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:51<00:00, 10.54s/it]\n"
     ]
    }
   ],
   "source": [
    "if calculate:\n",
    "    total_astuteness = np.zeros(shape=(run_times, len(lambda_names), 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",
    "            background = x_train[np.random.choice(len(x_train), 100, replace=False)]\n",
    "            explainer = shap.GradientExplainer(pred_model, background)\n",
    "            fname = 'explained_weights/shap/' + 'shap_' + datatype + '_' + str(j) + '_' + str(i) + '_lip.gz'\n",
    "            explanations = np.loadtxt(fname, delimiter=',')\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'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e61b829a",
   "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/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": null,
   "id": "14c97d00",
   "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
}
