{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "oriental-clerk",
   "metadata": {},
   "source": [
    "# Experiments with Data Shapley\n",
    "https://blog.acolyer.org/2019/07/15/data-shapley/\n",
    "\n",
    "This notebook contains six experiments:\n",
    "- On the train data using both the accuracy and the decision_boundary change as metric\n",
    "- On train and mesh data using both the accuracy and the decision_boundary change as metric\n",
    "- On mesh data only using both the accuracy and the decision_boundary change as metric\n",
    "\n",
    "**MESH_SIZE for db difference is smaller than in LOO experiments (100 vs 500)**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "supposed-beast",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\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 sys\n",
    "sys.path.append(\"./../\")\n",
    "\n",
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.neural_network import MLPClassifier as MLP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils import decision_boundary\n",
    "from utils.synthetic_data import SyntheticData\n",
    "from utils.metrics import DecisionBoundaryDifference\n",
    "from utils.data_shap import DShap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "adaptive-paintball",
   "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": [
    "syn = SyntheticData()\n",
    "data, labels = syn.sample_initial_data()\n",
    "\n",
    "sct = decision_boundary.Scatter2D(data, labels)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "organizational-western",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train, X_test, y_train, y_test = train_test_split(data, labels, \n",
    "                                                    test_size=0.33, \n",
    "                                                    random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "other-thinking",
   "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": [
    "sct = decision_boundary.Scatter2D(X_train, y_train, \n",
    "                                  X_test, y_test, \n",
    "                                  x_lim=(-10, 20), y_lim=(-10, 20),)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "periodic-transsexual",
   "metadata": {},
   "source": [
    "# Meshgrid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "rising-commissioner",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(144, 2)\n"
     ]
    }
   ],
   "source": [
    "step = 3\n",
    "xx, yy = np.meshgrid(np.arange(-10, 25, step),\n",
    "                     np.arange(-10, 25, step))\n",
    "\n",
    "X_mesh = np.c_[xx.ravel(), yy.ravel()]\n",
    "y_mesh = syn.get_labels(X_mesh)\n",
    "print(X_mesh.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47cf06b4-8702-4b51-b3fe-b05a44f1ed8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_train = y_train.astype(int)\n",
    "y_test = y_test.astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4241fee5-080d-45e5-bb2b-cef562266a94",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLPClassifier(hidden_layer_sizes=1000, max_iter=1000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "baseline_model = MLP(hidden_layer_sizes=1000, activation='relu', max_iter=1000)\n",
    "baseline_model.fit(X_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f4aac0d2-2a77-4100-a33a-0a9074862c68",
   "metadata": {},
   "outputs": [],
   "source": [
    "db_difference = DecisionBoundaryDifference(x_lim=(-10, 25), \n",
    "                                           y_lim=(-10, 25),\n",
    "                                           baseline_model=baseline_model.predict, \n",
    "                                           mesh_size=70)\n",
    "\n",
    "metric = lambda model, X, y: db_difference.compute_difference(model.predict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "261151a1-de46-458d-b58a-264af56c7a5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = 'NN'\n",
    "problem = 'classification'\n",
    "num_test = 10\n",
    "directory = './temp'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cac9f226-345b-4547-8fc3-a28e9ead2233",
   "metadata": {},
   "source": [
    "# 1. Data Shapley on training data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ecd4f1a0-6b68-40d0-abf9-e71d5f359f69",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting LOO score calculations!\n",
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 39277298.61255923\n",
      "Running iteration  3 error 59110389.257477365\n",
      "Running iteration  4 error 0.28528136498433626\n",
      "Running iteration  5 error 0.20880668176546338\n",
      "Running iteration  6 error 0.29181144847075324\n",
      "Running iteration  7 error 0.14161369458431194\n",
      "Running iteration  8 error 0.11384050993136716\n",
      "Running iteration  9 error 0.08780950472182726\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_train, y_train, X_test, y_test, num_test, \n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "trying-paintball",
   "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": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "sct.scatter(X_train, y_train, scatter_size=dv*5000+1)\n",
    "sct.show(scatter=False, title=\"TMC on train data only\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9cbdb108-b0b1-490e-b859-ced8b2728423",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.005970149253731343\n",
      "0.002089094099562728\n"
     ]
    }
   ],
   "source": [
    "print(dv.mean())\n",
    "print(dv.std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8bbe08d3-3f42-41b7-8922-419018705471",
   "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": [
    "dv_loo = dshap.vals_loo\n",
    "\n",
    "sct.scatter(X_train, y_train, scatter_size=dv_loo*5000+1)\n",
    "sct.show(scatter=False, title=\"LOO on train data\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "66d838bc-d742-4998-9c1f-ec09711c31c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "print(dv_loo.mean())\n",
    "print(dv_loo.std())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd3ba606-9973-45e2-ac50-9b7faf119b87",
   "metadata": {},
   "source": [
    "## 1.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8b8994f1-8770-4d34-be12-f8ecd63be419",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (2000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 25.75955007317922\n",
      "Running iteration  3 error 0.8569900431861256\n",
      "Running iteration  4 error 1.8599269917948746\n",
      "Running iteration  5 error 0.3813665118203905\n",
      "Running iteration  6 error 0.37894075153917856\n",
      "Running iteration  7 error 0.2862535874275031\n",
      "Running iteration  8 error 0.24529041498278753\n",
      "Running iteration  9 error 0.22168071088121455\n",
      "Running iteration  10 error 0.22229801763585802\n",
      "Running iteration  11 error 0.198318087687286\n",
      "Running iteration  12 error 0.13179248586582498\n",
      "Running iteration  13 error 0.12177475187721003\n",
      "Running iteration  14 error 0.08886055765707049\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_train, y_train, X_test, y_test, num_test, \n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=2000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b2b30327-cb57-423f-9a05-5ce6935d77ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(67,)\n"
     ]
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "dv[dv < 0] = 0\n",
    "print(dv.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "290c1d51-1436-47a0-ab82-0347f6c7e0d1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.]\n"
     ]
    }
   ],
   "source": [
    "print(dv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "3bc244ae-3d19-49db-adc4-0097955dd3c6",
   "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": [
    "sct.scatter(X_train, y_train, scatter_size=dv*5000+1)\n",
    "sct.show(scatter=False, title=\"TMC on train data with db change as metric\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b0eca893-8d07-470e-85c6-f5b68500f31d",
   "metadata": {},
   "source": [
    "# 2. Data Shapley on Mesh Data AND Training Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "70458d0f-c490-46f9-af6a-30c4f4189b91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 1.229166666375868\n",
      "Running iteration  3 error 0.47701228437147136\n",
      "Running iteration  4 error 0.38066611368071496\n",
      "Running iteration  5 error 0.31013919532792583\n",
      "Running iteration  6 error 0.23072650702762854\n",
      "Running iteration  7 error 0.210215151575806\n",
      "Running iteration  8 error 0.16485378597383202\n",
      "Running iteration  9 error 0.13099735317152625\n",
      "Running iteration  10 error 0.12898036859259554\n",
      "Running iteration  11 error 0.11366440075209233\n",
      "Running iteration  12 error 0.0977305618594738\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              X_base=X_train, y_base=y_train,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "cf47072d-1277-4d69-ba34-f4c80d0ff898",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(yy, xx, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.show(scatter=False, title=\"TMC Shapely on mesh and train data\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3bad2bfc-0155-463e-bf1a-2947aab19d64",
   "metadata": {},
   "source": [
    "## 2.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a1b546e6-2b7c-4d7e-9b0e-86ef81ed23ff",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 5.849003827908679\n",
      "Running iteration  3 error 1.4238128677116688\n",
      "Running iteration  4 error 1.120910196273114\n",
      "Running iteration  5 error 1.223585759468256\n",
      "Running iteration  6 error 0.5099475013236324\n",
      "Running iteration  7 error 0.309739568848152\n",
      "Running iteration  8 error 0.3066418705918128\n",
      "Running iteration  9 error 0.20537361083045325\n",
      "Running iteration  10 error 0.21061379146211945\n",
      "Running iteration  11 error 0.2295174272299588\n",
      "Running iteration  12 error 0.23725368553611156\n",
      "Running iteration  13 error 0.1646635678621067\n",
      "Running iteration  14 error 0.2631206823796339\n",
      "Running iteration  15 error 0.21670886874535467\n",
      "Running iteration  16 error 0.20215197547207234\n",
      "Running iteration  17 error 0.1435918254639099\n",
      "Running iteration  18 error 0.11614940735262709\n",
      "Running iteration  19 error 0.13711435762430135\n",
      "Running iteration  20 error 0.09266644463848156\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              X_base=X_train, y_base=y_train,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e49135a2-d4e6-4d6f-ba10-d03a61ab1f21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "sct.show(scatter=False, title=\"TMC Shapely on mesh and train data with db difference as metric\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d872c002-fe61-4260-892b-155463b39ecc",
   "metadata": {},
   "source": [
    "# 3. Data Shapley on Mesh Data only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "12cb0740-682d-4beb-8250-74ae6e8f659c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 416666516.89375234\n",
      "Running iteration  3 error 116886630.48610722\n",
      "Running iteration  4 error 27639569.085600343\n",
      "Running iteration  5 error 39221108.916968375\n",
      "Running iteration  6 error 12122469.481108401\n",
      "Running iteration  7 error 7716046.842332821\n",
      "Running iteration  8 error 9455370.528195338\n",
      "Running iteration  9 error 9906477.959036468\n",
      "Running iteration  10 error 1733943.3984594883\n",
      "Running iteration  11 error 3774153.621551452\n",
      "Running iteration  12 error 4162503.3867636537\n",
      "Running iteration  13 error 5045917.522970539\n",
      "Running iteration  14 error 6120903.965809155\n",
      "Running iteration  15 error 3200204.433530108\n",
      "Running iteration  16 error 3834061.2382591474\n",
      "Running iteration  17 error 1850618.215075628\n",
      "Running iteration  18 error 4332152.9331499105\n",
      "Running iteration  19 error 1633026.4367047485\n",
      "Running iteration  20 error 1527930.575250376\n",
      "Running iteration  21 error 1809390.982322519\n",
      "Running iteration  22 error 3123438.268069699\n",
      "Running iteration  23 error 990647.9146005961\n",
      "Running iteration  24 error 0.16003452584666267\n",
      "Running iteration  25 error 1810806.3234709154\n",
      "Running iteration  26 error 0.17746550117166077\n",
      "Running iteration  27 error 1936697.501609111\n",
      "Running iteration  28 error 0.12418738705488269\n",
      "Running iteration  29 error 1777370.689847801\n",
      "Running iteration  30 error 2959279.872029967\n",
      "Running iteration  31 error 0.09042143245233542\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b161d78c-710b-4213-873a-1bdbcb868763",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.show(scatter=False, title=\"TMC Shapely on mesh data only\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "855a4437-c937-438a-98ba-53f7f5dceb50",
   "metadata": {},
   "source": [
    "## 3.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "12610f57-b3be-4351-a084-f42302d25575",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 27.617912984362388\n",
      "Running iteration  3 error 2.1789751589902604\n",
      "Running iteration  4 error 0.6928711789078916\n",
      "Running iteration  5 error 0.39603022536278826\n",
      "Running iteration  6 error 0.4246517585325504\n",
      "Running iteration  7 error 0.4568639344760121\n",
      "Running iteration  8 error 0.31321617577541033\n",
      "Running iteration  9 error 0.6257828342011098\n",
      "Running iteration  10 error 0.3418960021470396\n",
      "Running iteration  11 error 0.3140532997041293\n",
      "Running iteration  12 error 0.20448197358613238\n",
      "Running iteration  13 error 0.09670003830779167\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "7c38f3db-a811-4044-a5f1-c4558bb1db46",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "sct.show(scatter=False, title=\"TMC Shapely on mesh data only with db difference as metric\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21063023-1a3c-4172-8ce7-1140f042c12d",
   "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.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
