{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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",
    "\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",
    "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",
    "\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "datatype = 'rice'\n",
    "run_times = 1\n",
    "prop_points = 1\n",
    "calculate = True\n",
    "epsilon_range = np.arange(0.01, 1.1, 0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "median_rad = 0.25 * np.median(pdist(x_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_astuteness_file = 'plots/rise_' + datatype + '_astuteness_classifiers.pk'\n",
    "classifiers = ['2layer', '4layer', 'linear', 'svm']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 1 of 1\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": [
      "2021-09-30 21:04:59.995065: 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",
      "2021-09-30 21:05:00.017907: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2021-09-30 21:05:00.018372: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x564cb1bc5110 executing computations on platform Host. Devices:\n",
      "2021-09-30 21:05:00.018386: I tensorflow/compiler/xla/service/service.cc:158]   StreamExecutor device (0): <undefined>, <undefined>\n",
      "100%|█████████████████████████████████████| 22/22 [1:27:37<00:00, 238.99s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [1:59:22<00:00, 325.59s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [1:17:17<00:00, 210.79s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [2:21:47<00:00, 386.70s/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"
    }
   ],
   "source": [
    "if calculate:\n",
    "    total_astuteness = np.zeros(shape=(run_times, len(classifiers), len(epsilon_range)))\n",
    "    for i in range(run_times):\n",
    "        print('Completing Run ' + str(i + 1) + ' of ' + str(run_times))\n",
    "        for j in range(len(classifiers)):\n",
    "            if classifiers[j] == '2layer':\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",
    "\n",
    "                preds = Dense(1, activation='sigmoid', name='dense3',\n",
    "                              kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                bbox_model = Model(model_input, preds)\n",
    "                bbox_model.load_weights('models/' + datatype + '_blackbox.hdf5',\n",
    "                                        by_name=True)\n",
    "                pred_model = Model(model_input, preds)\n",
    "\n",
    "            elif classifiers[j] == '4layer':\n",
    "                activation = 'relu' if datatype in ['orange_skin', 'XOR'] else 'selu'\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.load_weights('models/' + datatype + '_blackbox_extra.hdf5',\n",
    "                                        by_name=True)\n",
    "                pred_model = Model(model_input, preds)\n",
    "\n",
    "\n",
    "            elif classifiers[j] == 'linear':\n",
    "                activation = None\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",
    "\n",
    "                preds = Dense(1, activation='sigmoid', name='dense3',\n",
    "                              kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "                bbox_model = Model(model_input, preds)\n",
    "                bbox_model.load_weights('models/' + datatype + '_blackbox_linear.hdf5',\n",
    "                                        by_name=True)\n",
    "                pred_model = Model(model_input, preds)\n",
    "            elif classifiers[j] == 'svm':\n",
    "                pred_model = pickle.load(open('models/' + datatype + '_svm.pk', 'rb'))\n",
    "            fname = 'explained_weights/rise/' + 'rise_' + datatype + '_' + classifiers[j] + '_' + str(\n",
    "                i) + '.gz'\n",
    "            explanations = np.loadtxt(fname, delimiter=',')\n",
    "            if classifiers[j] == 'svm':\n",
    "                for k in tqdm(range(len(epsilon_range))):\n",
    "                    _, total_astuteness[i, j, k], _ = calculate_robust_astute_sampled(data=x_val,\n",
    "                                                                                      explainer=pred_model,\n",
    "                                                                                      explainer_type='rise',\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=False,\n",
    "                                                                                      data_explanation=explanations)\n",
    "            else:\n",
    "                for k in tqdm(range(len(epsilon_range))):\n",
    "                    _, total_astuteness[i, j, k], _ = calculate_robust_astute_sampled(data=x_val,\n",
    "                                                                                      explainer=pred_model,\n",
    "                                                                                      explainer_type='rise',\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/rise_' + datatype + '_astuteness_classifiers.PNG'\n",
    "fig, ax = plt.subplots()\n",
    "for i in range(len(classifiers)):\n",
    "    ax.errorbar(x=epsilon_range, y=astuteness_mean[i, :], yerr=astuteness_std[i, :],\n",
    "                label=classifiers[i])\n",
    "plt.legend()\n",
    "plt.savefig(image_name)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
