{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "34f98c97",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import openml\n",
    "import data_preprocess as dp\n",
    "\n",
    "data_name = 'elevators'\n",
    "\n",
    "data = openml.datasets.get_dataset(846)\n",
    "\n",
    "X, y, categorical_indicator, attribute_names = data.get_data(\n",
    "    target=data.default_target_attribute, dataset_format=\"dataframe\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a854335e",
   "metadata": {},
   "source": [
    "# Data Preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b83124ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "from copy import deepcopy\n",
    "import numpy as np\n",
    "\n",
    "nominal = [b for a, b in zip(categorical_indicator, attribute_names) if a]\n",
    "numerical = [b for a, b in zip(categorical_indicator, attribute_names) if not a]\n",
    "\n",
    "\n",
    "encoded_data = deepcopy(X)\n",
    "\n",
    "for col in nominal:\n",
    "    \n",
    "    mapping = {c: i+1 for i, c in enumerate(encoded_data[col].unique())}\n",
    "    encoded_data[col] = encoded_data[col].replace(mapping)\n",
    "    try:\n",
    "        encoded_data[col] = encoded_data[col].cat.add_categories([0])\n",
    "    except:\n",
    "        continue\n",
    "\n",
    "encoded_data = encoded_data[numerical + nominal]\n",
    "encoded_data.fillna(0, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e5c57b9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mapping = {b: i for i, b in enumerate(y.unique())}\n",
    "\n",
    "\n",
    "y = y.replace(mapping)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "747e1b0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "train_data, left_out, train_label, y_left_out = train_test_split(encoded_data, y, test_size=0.3, \n",
    "                                                                 stratify=y, random_state=42)\n",
    "test_data, dev_data, test_label, dev_label = train_test_split(left_out, y_left_out, test_size=0.5, \n",
    "                                                              stratify=y_left_out, random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4c142192",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import Normalizer, StandardScaler\n",
    "\n",
    "ss = StandardScaler()\n",
    "\n",
    "ss.fit(train_data[numerical])\n",
    "\n",
    "train_data[numerical] = ss.transform(train_data[numerical])\n",
    "dev_data[numerical] = ss.transform(dev_data[numerical])\n",
    "test_data[numerical] = ss.transform(test_data[numerical])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3e6f5635",
   "metadata": {},
   "outputs": [],
   "source": [
    "index_to_name, name_to_index = dp.name_index(data=encoded_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d0875dce-a0f8-4f23-b823-c21aaf035772",
   "metadata": {},
   "outputs": [],
   "source": [
    "from imblearn.over_sampling import RandomOverSampler\n",
    "\n",
    "oversample = RandomOverSampler(sampling_strategy='minority')\n",
    "X_over, y_over = oversample.fit_resample(train_data, train_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "56ddde92",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([16056, 18])\n",
      "torch.Size([16056])\n",
      "torch.Size([2490, 18])\n",
      "torch.Size([2490])\n",
      "torch.Size([2490, 18])\n",
      "torch.Size([2490])\n"
     ]
    }
   ],
   "source": [
    "train = dp.transform_to_tensors(X_over, y_over, len(index_to_name))\n",
    "\n",
    "test = dp.transform_to_tensors(test_data, test_label, len(index_to_name))\n",
    "\n",
    "dev = dp.transform_to_tensors(dev_data, dev_label, len(index_to_name))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "61e49abd-ca26-46ff-b249-2cd68a8db382",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader\n",
    "import torch\n",
    "\n",
    "batch_size = 64\n",
    "\n",
    "train_dataset = dp.Data(data=train)\n",
    "val_dataset = dp.Data(data=dev)\n",
    "test_dataset = dp.Data(data=test)\n",
    "\n",
    "train_dataloader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True, drop_last=False)\n",
    "val_dataloader = DataLoader(val_dataset, batch_size=batch_size, shuffle=False, drop_last=False)\n",
    "test_dataloader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False, drop_last=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fe7b1674",
   "metadata": {},
   "source": [
    "# Train MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fb19766d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading saved model\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import os.path\n",
    "from mlpshap import train_model, MLPSHAP\n",
    "from sklearn.metrics import roc_auc_score, roc_curve, precision_score, recall_score, f1_score\n",
    "torch.manual_seed(5)\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "if os.path.isfile(f'{data_name}/{data_name}_mlp.model'):\n",
    "    \n",
    "    print('Loading saved model')\n",
    "    mlp_model = MLPSHAP(len(index_to_name), 1, index_to_name, dataframe=encoded_data, \n",
    "            categorical=nominal, \n",
    "            numerical=numerical,).to(device)\n",
    "    mlp_model.load_state_dict(torch.load(f'{data_name}/{data_name}_mlp.model'))\n",
    "    \n",
    "else:\n",
    "    mlp_model = train_model(index_to_name=index_to_name,\n",
    "                train_dataloader=train_dataloader,\n",
    "                val_dataloader=val_dataloader,\n",
    "                data_name=data_name,\n",
    "                num_classes=1,\n",
    "                dataframe=encoded_data, \n",
    "                categorical=nominal, \n",
    "                numerical=numerical,\n",
    "                mlp_model=None, \n",
    "                optimizer_train=None, \n",
    "                current_epoch=1,\n",
    "                max_num_epochs=300,\n",
    "                learning_rate=1e-03,\n",
    "                num_samples=32,\n",
    "                alpha=1, beta=10,\n",
    "                patience=10)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f5c0b171",
   "metadata": {},
   "source": [
    "## Evaluate the trained model on the test set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a9323f2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 39/39 [00:00<00:00, 102.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC is : 0.9427016007248565,  prec 0.8267967362466289,  recall 0.8601140138930836, f-score 0.8380899776417114\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "list_prediction = []\n",
    "list_pob_pred = []\n",
    "y_test = []\n",
    "\n",
    "mlp_model.eval()\n",
    "\n",
    "for i, data in tqdm(list(enumerate(test_dataloader))):\n",
    "    inputs, labels = data\n",
    "\n",
    "    inputs = inputs.to(device)\n",
    "    labels = labels.to(device)\n",
    "\n",
    "    outputs = mlp_model(inputs)\n",
    "    list_pob_pred.extend(outputs.tolist())\n",
    "\n",
    "    preds = (outputs.reshape(-1) > 0.5) * 1\n",
    "\n",
    "    list_prediction.extend(preds.tolist())\n",
    "\n",
    "    y_test.extend(labels.tolist())\n",
    "\n",
    "    torch.cuda.empty_cache()\n",
    "\n",
    "\n",
    "roc = roc_auc_score(y_test, list_pob_pred)\n",
    "prec = precision_score(y_test, list_prediction, average='macro')\n",
    "recall = recall_score(y_test, list_prediction, average='macro')\n",
    "f_score = f1_score(y_test, list_prediction, average='macro')\n",
    "\n",
    "print('AUC is : {},  prec {},  recall {}, f-score {}' .format(roc, prec, recall, f_score))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27113d35",
   "metadata": {},
   "source": [
    "# Explain one random example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3d76ff08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tNE5MjQ0ZP369QDU1NSwYcMGQkNDuXLlCubm5vj7+/Pcc89hZmamlGHnzp1kZGSgq6uLs7MzTz31lFLO1toqKiqK3bt3k5KSQnl5OdbW1tx///089thjSlsKIYQQ2rRTncExdX6j91bWJwIwUGVNQX011dRzXJ3Hydp8otVXANhbn4Uxunyi27nFfavVar7//nsAnn/++UbLXnrpJSIiInjvvfeYNm0ac+fOZe3atahUKr755ptrlvkfPRJ+qwQEBDB48GAqKio4ePAgO3bsuN1Fatby5cs5duwY7du3x8/Pj6ioKObNm0dtbW2L28THx2Nra4u5uXmzy9euXcvRo0fR0dFhyJAhVFZWsm/fPn755RcATp48ycqVK8nLyyMgIABjY2O2bdvG7t27lX0cPnwYExMTBgwYgLGxMREREXz22WdUV1cDEBcXx7Jly8jLy6N///7U1dWxceNGDhw4oOwjLi4OZ2dn9PSa71euXLmS0NBQzM3NCQgIoKCggK1bt3LkyBGgIbx+8sknHDp0CEtLS4YMGYKrqytZWVnKPgoKCujWrRtDhw5FR0eH0NDQRlcscnJy8PT0ZOjQodjZ2REbG8uCBQuorKy8rnrExcWxaNEikpOT6du3L7a2tgQFBbF27dom9RkyZAgjR45k5MiRPPTQQ8r7v/zyC/v27aOyspLBgwejo6PD0aNHWbNmDQBZWVksW7aMy5cv4+/vj4eHBxcvXmxUztba6uLFiyQlJeHj48N9991HdnY2mzZtIigoqNm2F0IIIf5uQXoBlOk/Rpn+Y0xQOTNQZa28DtILQA2ogf3qHILU2aTT8H9eEuWEqgsAyFNXkZCQoAw8ahw4cICkpCTatWvH6NGjGy27ePEi0DAibmxsTNeuXQFISEhotcz39Ej4f/7zH86fP09JSQl6enp4eHgwZcqUJpcILl++zJo1a8jOzqZLly68/PLLmJubU1payrfffktMTAyVlZW0adOGrl278uKLLzbafvTo0bi6umJtbc22bduUSfoAxcXFbNq0iaioKMrLy3FycmLs2LF069btpuulCVTN6datW7P7TkpKIioqCjMzMz7++GP09PT48MMPiY2N5fjx441Gt6/20UcfAfD2229TUlLSZHl2djYAjz32GCNGjMDIyIj//ve/5OTkAHDq1CkARo0axdixY0lKSuKdd95h165d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O3akrq6O0NBQpQwAnTp1QqVSceHCBb744guqqqrIzc1FX19fmV8+evRovv76a9atW0dUVBQhISEADB48+LqOUVVVxRtvvIGfn1+j5WPHjlWuwrz++ut07twZBwcHUlNTGz2OEmDUqFEcPnyY33//nerqauLj45UyqFQqUlNTWbBgAbW1tXTq1ImYmBhlCldgYCBmZmat1kMIIYQQ13bXhnB9fX1GjRpFTEwMERERVFdXY2VlxfDhw3nssceAhsCQmZlJXFwciYmJPP744/z4449aLaeVlRVz5sxh8+bNXLp0idjYWGxsbHjooYeU6QOa53Hm5eU1GuF2dXVtNoTfLGNjYz744APWrl1LeHg4BgYGDB06lOeee+6a2/35mdOawDV27Fjatm2Lg4MDZ8+eVcJ33759CQwMVEb6NV8SUFNTw/79+5X9DB48mICAAAoLC5WrE5GRkURGRirraEJ4a21kb29PaWkpR48eRU9PT3mutaZzoaOjw3vvvccPP/xATEwMKpWKPn36NHriy5gxY6iurub333/nxIkTODk58fTTTytXCXr16kVOTg7h4eFUV1djZ2fHAw88oDzqslOnTkyfPp3//ve/REZGolKp6NixI4GBgcq0nKFDh1JWVsa+ffs4duwY9vb2PPfcc8ozwFs7hq6uLu3atSMsLIzq6mocHBwYNWoU999/v1KPhx9+mMjISBISEjAwMKBLly6MGzdOuRzWvn17Zs2axebNmzlx4gRt2rRhzJgxSoeluLhY6XRdvHix0aj5yJEjMTMza7UeQgghhLg2lfpWzM0QQojrlJGRcc3ld/rcvutxL9QBpB53GqnHnaON6yu3uwitKkpa2eo698K5gDu/Hi3NCZdniQkhhBBCCKFlEsKFEEIIIYTQMgnhQgghhBBCaJmEcCGEEEIIIbRMQrgQQgghhBBaJiFcCCGEEEIILZMQLoQQQgghhJZJCBdCCCGEEELLJIQLIYQQQgihZRLChRBCCCGE0DK9210AIYQQQoi7iV7p1jv6a9LF3UFGwoUQQgghhNAyCeFCCCGEEEJomYRwIYQQQgghtExCuBBCCCGEEFomIVwIIYQQQggtkxAuhBBCCCGElkkIF0IIIYQQQsvkOeFCCCGEuOP129b+dhdBEf+v6ttdBHEPkJFwIYQQQgghtExCuBBCCCGEEFomIVwIIYQQQggt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QpiYJOFCCCGEEEKYmCThQgghhBBCmJgk4UIIIYQQQpiYJOFCCCGEEEKYmCThQgghhBBCmJhKr9frb3cjhBBCCCGE+DuRkXAhRJPyxhtv3O4m/GV3QgwgcTQ1EkfTcSfEABLH7SZJuBBCCCGEECYmSbgQQgghhBAmJkm4EKJJGTRo0O1uwl92J8QAEkdTI3E0HXdCDCBx3G4yMVMIIYQQQggTk5FwIYQQQgghTEyScCGEEEIIIUxMc7sbIIT4e9u6dSu7d+8mNTUVvV5PWFgY48aNU9bv37+fX3/9lbS0NCoqKmjVqhXDhw/nvvvuu42trquhOAAiIyNZt24dmZmZODk58eCDDzJq1Kjb1OLGuXDhAqtXryY5OZnKykrc3NwYMmQIgwcPvt1Nu27R0dFs2rSJixcvotFo8PHxYfr06djZ2d3upl23/fv389FHHwEwbNgwwsPDb2+DrtOyZcs4c+YMOTk5mJub0759ex5//HF8fHxud9OuqbKykm+//ZaDBw9SXl6On58fEydOpH379re7aY3WXPv+aprzd0FGwoUQt9W5c+ews7PD1dW13vUxMTFkZ2fTvXt3OnXqRGpqKsuWLePIkSMmbum1NRRHYmIiixcvJicnh9DQUKqrq1m9ejW//fabiVt6fT744ANiYmJo1aoVffr0IT09nRUrVnDq1Knb3bTrsn//fhYuXMjFixcJCgoiJCSE8vJyKisrb3fTrltubi4rVqzAzMzsdjflhu3atQsbGxvuvvturK2tOX78OO+//36Tfz++/vprduzYgYODA0FBQSQmJjJnzhyKiopud9Marbn2fX2a+3dBRsKFELfVSy+9BMCCBQvIzs6us3748OE8//zzqNW1YwazZs3i9OnTnDx5kt69e5u0rdfSUBybN29Gr9czduxYRowYQWxsLLNnz2bz5s088MADpm5uo+h0OnJycgB4/vnn8fHxIS0tjXPnztUbY1Ol1+tZvXo1AG+99RZdunS5zS26cXq9niVLluDk5ISPjw8HDx683U26IREREfj5+QGQlZXFiy++SF5eHpcuXVKWNzWFhYXs3r0blUrFzJkzcXBwwMzMjH379rFjx446d76aqubY9/W5E74LMhIuhGjSfH19lQQcahNDABcXl9vVpBty4cIFANq1a2f0b3Z2NqWlpberWdek0WgYNmwYAEuXLuXjjz/m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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "tensor([[0.2391]], device='cuda:0', grad_fn=<SigmoidBackward0>)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#num of features to use\n",
    "top_n = 10\n",
    "ind = np.random.choice(len(test))\n",
    "\n",
    "mlp_model.plot_bars(test[10][0].reshape(1, len(index_to_name)).to(device), test_data.iloc[0], top_n)\n",
    "mlp_model.predict(test[10][0].reshape(1, len(index_to_name)).to(device))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1ed58d30",
   "metadata": {},
   "source": [
    "# Interpretability Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "152f47a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''function to obtain feature scores from IGNNet model'''\n",
    "\n",
    "def get_local_values(example, index_to_name):\n",
    "    array_to_use = np.array(example)    \n",
    "    array = torch.FloatTensor(array_to_use).reshape(1, len(index_to_name))\n",
    "    local_importance = mlp_model.get_local_importance(array.to(device))\n",
    "\n",
    "    names = []\n",
    "    values = []\n",
    "    for i, v in enumerate(local_importance):\n",
    "        name = index_to_name[i]\n",
    "        names.append(name)\n",
    "        values.append(v)\n",
    "    return names, values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fe711de1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import StandardScaler\n",
    "from data_preprocess import BlackBoxWrapper\n",
    "\n",
    "\n",
    "num_features = len(index_to_name)\n",
    "\n",
    "\n",
    "bb = BlackBoxWrapper(mlp_model, num_features, device)\n",
    "\n",
    "def black_box(x, S):\n",
    "    pred = bb(x, S)\n",
    "    return pred.cpu().data.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "40d93d38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████| 2490/2490 [07:21<00:00,  5.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cosine similarity: 0.9755798604909318 +- 0.024766525912254037,  Spearman rank: 0.8829539002242199 +- 0.06600808547530039\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "import shapreg\n",
    "import pickle\n",
    "import os.path\n",
    "from numpy.linalg import norm\n",
    "from scipy.stats import spearmanr\n",
    "import copy\n",
    "\n",
    "all_cos_sim = []\n",
    "all_spearman_c = []\n",
    "all_krnl = []\n",
    "\n",
    "for x_, _ in tqdm(test_dataset):\n",
    "    _, true_values = get_local_values(x_, index_to_name)\n",
    "\n",
    "    x = x_.reshape((1,x_.shape[0])).numpy()\n",
    "\n",
    "    # Run KernelSHAP to convergence\n",
    "    game_ = shapreg.games.PredictionGame(black_box, x)\n",
    "    try:\n",
    "        shap_values, all_results = shapreg.shapley.ShapleyRegression(\n",
    "            game_, batch_size=256, paired_sampling=True, detect_convergence=True,\n",
    "            bar=False, return_all=True)\n",
    "    except:\n",
    "        print('Singularity exception!')\n",
    "        continue\n",
    "\n",
    "    instance_l2_dis = []\n",
    "    instance_cos_sim = []\n",
    "    spearman_c = []\n",
    "\n",
    "    true_values = np.array(true_values)\n",
    "\n",
    "    knl_shp = shap_values.values.reshape(-1)\n",
    "    all_krnl.append(shap_values)\n",
    "\n",
    "    all_cos_sim.append(np.dot(true_values, knl_shp)/(norm(true_values)*norm(knl_shp)))\n",
    "    coef, p = spearmanr(true_values, knl_shp)\n",
    "    all_spearman_c.append(coef)\n",
    "\n",
    "mean_cos_sim = np.mean(all_cos_sim)\n",
    "mean_spearman_c = np.mean(all_spearman_c)\n",
    "\n",
    "std_cos_sim = np.std(all_cos_sim)\n",
    "std_spearman_c = np.std(all_spearman_c)\n",
    "\n",
    "print('Cosine similarity: {} +- {},  Spearman rank: {} +- {}' .format(mean_cos_sim, std_cos_sim, \n",
    "                                                                      mean_spearman_c, std_spearman_c))\n",
    "\n",
    "with open(f'{data_name}/{data_name}_krnlshp_mlp.pickle', 'wb') as file:\n",
    "    pickle.dump(all_krnl, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "566247eb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
