{
 "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 106609809.6950071\n",
      "Running iteration  3 error 43471941.13307923\n",
      "Running iteration  4 error 18563893.23971497\n",
      "Running iteration  5 error 9917186.295607945\n",
      "Running iteration  6 error 0.3692921928936151\n",
      "Running iteration  7 error 2979115.515729797\n",
      "Running iteration  8 error 1128999.0264306949\n",
      "Running iteration  9 error 0.14790183778814037\n",
      "Running iteration  10 error 0.18024262881440625\n",
      "Running iteration  11 error 0.10522486390867468\n",
      "Running iteration  12 error 0.09523724895346514\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": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\matplotlib\\collections.py:1003: RuntimeWarning: invalid value encountered in sqrt\n",
      "  scale = np.sqrt(self._sizes) * dpi / 72.0 * self._factor\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": [
    "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.002238805970149254\n",
      "0.002231530879373289\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": 15,
   "id": "8b8994f1-8770-4d34-be12-f8ecd63be419",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 10.606976167040795\n",
      "Running iteration  3 error 1.7619405668284827\n",
      "Running iteration  4 error 1.0350160281751566\n",
      "Running iteration  5 error 0.8299449276066444\n",
      "Running iteration  6 error 0.6631200159607661\n",
      "Running iteration  7 error 2.856617189361608\n",
      "Running iteration  8 error 0.8196018905239544\n",
      "Running iteration  9 error 0.419815880557795\n",
      "Running iteration  10 error 0.6965677971683341\n",
      "Running iteration  11 error 0.3399714395699574\n",
      "Running iteration  12 error 0.4438811284889295\n",
      "Running iteration  13 error 0.5773510231559951\n",
      "Running iteration  14 error 0.3444224548315154\n",
      "Running iteration  15 error 0.6284220097959866\n",
      "Running iteration  16 error 0.4439036606861584\n",
      "Running iteration  17 error 0.2769909085211597\n",
      "Running iteration  18 error 1.0395562953018562\n",
      "Running iteration  19 error 0.3498943957803678\n",
      "Running iteration  20 error 0.1897375577306921\n",
      "Running iteration  21 error 0.16519957271330513\n",
      "Running iteration  22 error 0.13234604510086326\n",
      "Running iteration  23 error 0.23894937592762436\n",
      "Running iteration  24 error 0.18538645562817427\n",
      "Running iteration  25 error 0.17476725298542584\n",
      "Running iteration  26 error 0.12300532592397116\n",
      "Running iteration  27 error 0.14695364624585305\n",
      "Running iteration  28 error 0.2629910788459751\n",
      "Running iteration  29 error 0.2238011374058598\n",
      "Running iteration  30 error 0.3665295918882856\n",
      "Running iteration  31 error 0.11246171377408697\n",
      "Running iteration  32 error 0.37750847723670655\n",
      "Running iteration  33 error 0.12816109534923045\n",
      "Running iteration  34 error 0.19036908831557228\n",
      "Running iteration  35 error 0.1633367059314873\n",
      "Running iteration  36 error 0.10785015610802016\n",
      "Running iteration  37 error 0.09753514473854247\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": 16,
   "id": "b2b30327-cb57-423f-9a05-5ce6935d77ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(134,)\n"
     ]
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "dv[dv < 0] = 0\n",
    "print(dv.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "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": "code",
   "execution_count": 19,
   "id": "21063023-1a3c-4172-8ce7-1140f042c12d",
   "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*9000+1)\n",
    "sct.show(scatter=False, title=\"TMC on train data with db change as metric\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "84c43883-3084-45d3-b75d-3d467058bd53",
   "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
}
