{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d92126f6",
   "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,
   "id": "0cb31a94",
   "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": "67d1408d",
   "metadata": {},
   "outputs": [],
   "source": [
    "datatype = 'telescope'\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": "c89119f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_dict = pd.read_csv('data/magic04.data').values\n",
    "data = data_dict[:, :-1]\n",
    "labels = data_dict[:, -1]\n",
    "labels[labels == 'h'] = 0\n",
    "labels[labels == 'g'] = 1\n",
    "x_train, x_val, y_train, y_val = train_test_split(data, labels, test_size=0.05, stratify=labels, random_state=42)\n",
    "x_train = StandardScaler().fit_transform(x_train)\n",
    "x_val = StandardScaler().fit_transform(x_val)\n",
    "input_shape = x_train.shape[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c1688da4",
   "metadata": {},
   "outputs": [],
   "source": [
    "median_rad = np.median(pdist(x_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a0b9789b",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_astuteness_file = 'plots/rise_' + 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": "5e5a9c34",
   "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 10:47:59.362809: 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 10:47:59.386133: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 3600000000 Hz\n",
      "2022-05-18 10:47:59.386407: I tensorflow/compiler/xla/service/service.cc:150] XLA service 0x55767fed7bb0 executing computations on platform Host. Devices:\n",
      "2022-05-18 10:47:59.386416: I tensorflow/compiler/xla/service/service.cc:158]   StreamExecutor device (0): <undefined>, <undefined>\n",
      "100%|█████████████████████████████████████| 22/22 [03:12<00:00,  8.75s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:25<00:00,  9.35s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:35<00:00,  9.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 2 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [03:39<00:00,  9.99s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:45<00:00, 10.25s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:46<00:00, 10.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 3 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [03:50<00:00, 10.48s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:50<00:00, 10.47s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:50<00:00, 10.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 4 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [03:52<00:00, 10.59s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:55<00:00, 10.70s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:56<00:00, 10.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completing Run 5 of 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 22/22 [03:59<00:00, 10.89s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [03:59<00:00, 10.88s/it]\n",
      "100%|█████████████████████████████████████| 22/22 [04:01<00:00, 10.97s/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/telescope_l2_' + str(j) + '.pk', 'rb'))\n",
    "            activation = 'relu'\n",
    "\n",
    "            model_input = Input(shape=(input_shape,), dtype='float32')\n",
    "\n",
    "            net = Dense(32, activation=activation, name='dense1',\n",
    "                        kernel_regularizer=regularizers.l2(1e-3))(model_input)\n",
    "            net = Dense(32, activation=activation, name='dense2',\n",
    "                        kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "            net = Dense(32, activation=activation, name='dense3',\n",
    "                        kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "            net = Dense(32, activation=activation, name='dense4',\n",
    "                        kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "            preds = Dense(1, activation='sigmoid', name='dense5',\n",
    "                          kernel_regularizer=regularizers.l2(1e-3))(net)\n",
    "            bbox_model = Model(model_input, preds)\n",
    "            bbox_model = set_all_weights(bbox_model, all_layer_weights)\n",
    "            pred_model = Model(model_input, preds)\n",
    "            fname = 'explained_weights/rise/' + 'rise_' + 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=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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d459a987",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fPAB4F2K9tzAr8rcuXP5xz/+wcGDB1m9ejUAa9asYc2aNeVrvNjtdvbt20dBQQEjR44sP+9NN91Uo9rz8vK4++672bdvH0qps7p3hgwZQkJC5VlQXFzM7bffzuuvv067du147bXXqqzvlltuKV/3/Mx68fWl2kBXStmA+cAQIB3YrJT6RGtdsRNsONCl7M9lwN/LHhuU0+3E7rJjd9opcBVgd3o/tru8f/6ZupjGuelsb9sa9r5N96bdmZo8laHth9IyuurF7GWIlxDn9/DDD9OnTx/Gj6/6t1lfl6V95JFHmDp1Kh988AFjx47lwIEDaK154oknuP/++886du7cuVW+T8UleStbjhfgqaee4pprruHDDz/k8OHDDB48uPy1qpbjBZg0aRK33npr+TZ3VdX3yiuv+H053vPxpYXeH9ivtT4IoJRaAYwEKgb6SGC59q709b1SqolSqpXWOtPfBW/f8Q5vpvwdO27s2oMdNwXajR03TqpfaKxjSAgPXjSG4d3upF3jdv4uT4iglJCQwB133MHixYuZMGEC4N3YYcWKFYwZM4Z33nmHK6+8EoDY2FgKCgqqfc9bb72VN998kzfffJOhQ4fy1FNPMXr0aGJiYjh27BhhYWFceeWV3H///TzxxBOUlpby2Wefcd993vWT2rdvz9atW+nfv3+VNzTz8vJo08a7TMeyZct8utb58+dTUFDA9OnTyz9XVX1XXXUV48aNY/r06ZSWlvLvf//7V6HvT74EehsgrcLzdH7d+q7smDbAWYGulJoITARo27ZtTWsFoKg4hyOufGJRxGtoqxUxKGK0jRitiAFitSJGU/Z578exWpFnz+C/LTsz7jLZpFkIf3v00Ud5/fXXy5/PmzePCRMm8PLLL5ffFAUYNWoU9913H/PmzeNf//pXlTdFAZ5++mnuuusu9uzZw549e7j8cu+Q5ZiYGN5++2369evHzTffTK9evWjXrh3JycnlS/JOnTqVO+64g7feeotrr7220vefNm0ad999N3PmzKnymHPNnj2bsLCw8qV4J02axKRJkyqtr0+fPtx555307t2bdu3a1csuRRVVu3yuUup2YKjW+t6y52OA/lrrhyoc8xnwotb627LnXwPTtNZbq3rf2i6fK4TwMuPyufXBbrcTExNDYWEhV111FQsXLqRPnz5Gl+UX9bF8bjqQVOF5IpBRi2OEEMLvJk6cyO7duykuLubuu++2TJjXhi+BvhnoopTqABwDRgHnDsj+BJhc1r9+GZBXH/3nQghxrv/7v/8zuoSAUW2ga61LlVKTgS/wDltcorXepZSaVPb6AmAV3iGL+/EOW5SB20I0AK11g46iEA2nNrvJ+TQOXWu9Cm9oV/zcggofa+DBGp9dCFFrkZGRZGVl0bRpUwl1i9Fak5WVRWRkzdaLCr6ZokJYRGJiIunp6Zw6dcroUkQ9iIyMJDGxZpvLS6ALYVJhYWF06NDB6DJEAAnO1RaFEMKCJNCFEMIiJNCFEMIiqp0pWm8nVuoUcKSGX9YM8H0lfXMKhmsEuU6rketsOO201s0re8GwQK8NpdSWqqa8WkUwXCPIdVqNXGdgkC4XIYSwCAl0IYSwCLMF+kKjC2gAwXCNINdpNXKdAcBUfehCCCGqZrYWuhBCiCpIoAshhEUEXKArpYYppfYqpfYrpaZX8rpSSs0rez1VKWXK1ex9uM7RZdeXqpT6TinVy4g666q666xwXD+llFspdVtD1ucvvlynUmqwUipFKbVLKfVNQ9foDz5838Yppf6tlPqx7DpNuZS2UmqJUuqkUmpnFa8HZg5prQPmD9711g8AHYFw4Eeg+znH3Ah8DihgAPCD0XXX03UOBOLLPh5u1euscNx/8C7RfJvRddfTv2cTvBurty173sLouuvpOp8EZpV93BzIBsKNrr0W13oV0AfYWcXrAZlDgdZC7w/s11of1Fo7gRXAyHOOGQks117fA02UUq0autA6qvY6tdbfaa1zyp5+j3dbP7Px5d8T4CFgJXCyIYvzI1+u8y7gA631UQCttRmv1Zfr1ECs8i7QHoM30Esbtsy601qvw1t7VQIyhwIt0NsAaRWep5d9rqbHBLqaXsM9eFsDZlPtdSql2gC3AAswL1/+PS8E4pVSa5VSW5VSYxusOv/x5TpfB7rh3VN4BzBFa+1pmPIaVEDmUKCth17Ztivnjqv05ZhA5/M1KKWuwRvoV9ZrRfXDl+t8BXhca+028a47vlxnKNAXuA5oBGxUSn2vtf65vovzI1+ucyiQAlwLdAK+VEqt11rn13NtDS0gcyjQAj0dSKrwPBHvT/qaHhPofLoGpVRPYBEwXGud1UC1+ZMv15kMrCgL82bAjUqpUq31Rw1SoX/4+n17WmvtABxKqXVAL8BMge7LdY4HZmpvR/N+pdQh4CJgU8OU2GACMocCrctlM9BFKdVBKRUOjAI+OeeYT4CxZXeZBwB5WuvMhi60jqq9TqVUW+ADYIzJWnEVVXudWusOWuv2Wuv2wL+AB0wW5uDb9+3HwCClVKhSKgq4DNjTwHXWlS/XeRTvbyEopS4AugIHG7TKhhGQORRQLXStdalSajLwBd476ku01ruUUpPKXl+AdyTEjcB+oBBvi8BUfLzOp4GmwN/KWq+lOoBXeauMj9dper5cp9Z6j1JqNZAKeIBFWutKh8QFKh//Pf8CLFNK7cDbLfG41tro5WZrTCn1LjAYaKaUSgeeAcIgsHNIpv4LIYRFBFqXixBCiFqSQBdCCIuQQBdCCIuQQBdCCIuQQBdCCIuQQBdCCIuQQBdCCIv4/xyZuWQTpTf0AAAAAElFTkSuQmCC\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/rise_' + 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": 11,
   "id": "68fc7e0c",
   "metadata": {},
   "outputs": [],
   "source": [
    "pickle.dump(total_astuteness, open(save_astuteness_file, 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a113e070",
   "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
}
