{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "CvCx6LjeMytM",
        "outputId": "e1715139-e14f-4696-a2aa-02266f4cdfdc"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting shap\n",
            "  Downloading shap-0.42.1-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (547 kB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m547.9/547.9 kB\u001b[0m \u001b[31m7.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hRequirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from shap) (1.23.5)\n",
            "Requirement already satisfied: scipy in /usr/local/lib/python3.10/dist-packages (from shap) (1.11.2)\n",
            "Requirement already satisfied: scikit-learn in /usr/local/lib/python3.10/dist-packages (from shap) (1.2.2)\n",
            "Requirement already satisfied: pandas in /usr/local/lib/python3.10/dist-packages (from shap) (1.5.3)\n",
            "Requirement already satisfied: tqdm>=4.27.0 in /usr/local/lib/python3.10/dist-packages (from shap) (4.66.1)\n",
            "Requirement already satisfied: packaging>20.9 in /usr/local/lib/python3.10/dist-packages (from shap) (23.1)\n",
            "Collecting slicer==0.0.7 (from shap)\n",
            "  Downloading slicer-0.0.7-py3-none-any.whl (14 kB)\n",
            "Requirement already satisfied: numba in /usr/local/lib/python3.10/dist-packages (from shap) (0.56.4)\n",
            "Requirement already satisfied: cloudpickle in /usr/local/lib/python3.10/dist-packages (from shap) (2.2.1)\n",
            "Requirement already satisfied: llvmlite<0.40,>=0.39.0dev0 in /usr/local/lib/python3.10/dist-packages (from numba->shap) (0.39.1)\n",
            "Requirement already satisfied: setuptools in /usr/local/lib/python3.10/dist-packages (from numba->shap) (67.7.2)\n",
            "Requirement already satisfied: python-dateutil>=2.8.1 in /usr/local/lib/python3.10/dist-packages (from pandas->shap) (2.8.2)\n",
            "Requirement already satisfied: pytz>=2020.1 in /usr/local/lib/python3.10/dist-packages (from pandas->shap) (2023.3.post1)\n",
            "Requirement already satisfied: joblib>=1.1.1 in /usr/local/lib/python3.10/dist-packages (from scikit-learn->shap) (1.3.2)\n",
            "Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.10/dist-packages (from scikit-learn->shap) (3.2.0)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/dist-packages (from python-dateutil>=2.8.1->pandas->shap) (1.16.0)\n",
            "Installing collected packages: slicer, shap\n",
            "Successfully installed shap-0.42.1 slicer-0.0.7\n"
          ]
        }
      ],
      "source": [
        "! pip install shap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "D6VXGqnjE0go",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "c8f5de28-8f2c-486a-9234-c789b29c072a"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "Using `tqdm.autonotebook.tqdm` in notebook mode. Use `tqdm.tqdm` instead to force console mode (e.g. in jupyter console)\n"
          ]
        }
      ],
      "source": [
        "import tensorflow.compat.v2 as tf\n",
        "tf.enable_v2_behavior()\n",
        "import models as nam_models\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import pandas as pd\n",
        "from sklearn.preprocessing import StandardScaler\n",
        "from sklearn import preprocessing\n",
        "from sklearn.model_selection import train_test_split\n",
        "import sklearn\n",
        "import pandas as pd\n",
        "import shap\n",
        "import sklearn"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ojBvN4VtKgft"
      },
      "source": [
        "##Loading the data"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 244
        },
        "id": "OIULWvFkE2bf",
        "outputId": "80fe190e-abf8-4161-aa5e-694ca1a10c95"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "   Unnamed: 0  SeriousDlqin2yrs  RevolvingUtilizationOfUnsecuredLines  age  \\\n",
              "0           1                 1                              0.766127   45   \n",
              "1           2                 0                              0.957151   40   \n",
              "2           3                 0                              0.658180   38   \n",
              "3           4                 0                              0.233810   30   \n",
              "4           5                 0                              0.907239   49   \n",
              "\n",
              "   NumberOfTime30-59DaysPastDueNotWorse  DebtRatio  MonthlyIncome  \\\n",
              "0                                     2   0.802982         9120.0   \n",
              "1                                     0   0.121876         2600.0   \n",
              "2                                     1   0.085113         3042.0   \n",
              "3                                     0   0.036050         3300.0   \n",
              "4                                     1   0.024926        63588.0   \n",
              "\n",
              "   NumberOfOpenCreditLinesAndLoans  NumberOfTimes90DaysLate  \\\n",
              "0                               13                        0   \n",
              "1                                4                        0   \n",
              "2                                2                        1   \n",
              "3                                5                        0   \n",
              "4                                7                        0   \n",
              "\n",
              "   NumberRealEstateLoansOrLines  NumberOfTime60-89DaysPastDueNotWorse  \\\n",
              "0                             6                                     0   \n",
              "1                             0                                     0   \n",
              "2                             0                                     0   \n",
              "3                             0                                     0   \n",
              "4                             1                                     0   \n",
              "\n",
              "   NumberOfDependents  \n",
              "0                 2.0  \n",
              "1                 1.0  \n",
              "2                 0.0  \n",
              "3                 0.0  \n",
              "4                 0.0  "
            ],
            "text/html": [
              "\n",
              "  <div id=\"df-5a2848d7-3163-4a0e-9a27-bbc2929a7dc5\" class=\"colab-df-container\">\n",
              "    <div>\n",
              "<style scoped>\n",
              "    .dataframe tbody tr th:only-of-type {\n",
              "        vertical-align: middle;\n",
              "    }\n",
              "\n",
              "    .dataframe tbody tr th {\n",
              "        vertical-align: top;\n",
              "    }\n",
              "\n",
              "    .dataframe thead th {\n",
              "        text-align: right;\n",
              "    }\n",
              "</style>\n",
              "<table border=\"1\" class=\"dataframe\">\n",
              "  <thead>\n",
              "    <tr style=\"text-align: right;\">\n",
              "      <th></th>\n",
              "      <th>Unnamed: 0</th>\n",
              "      <th>SeriousDlqin2yrs</th>\n",
              "      <th>RevolvingUtilizationOfUnsecuredLines</th>\n",
              "      <th>age</th>\n",
              "      <th>NumberOfTime30-59DaysPastDueNotWorse</th>\n",
              "      <th>DebtRatio</th>\n",
              "      <th>MonthlyIncome</th>\n",
              "      <th>NumberOfOpenCreditLinesAndLoans</th>\n",
              "      <th>NumberOfTimes90DaysLate</th>\n",
              "      <th>NumberRealEstateLoansOrLines</th>\n",
              "      <th>NumberOfTime60-89DaysPastDueNotWorse</th>\n",
              "      <th>NumberOfDependents</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>1</td>\n",
              "      <td>1</td>\n",
              "      <td>0.766127</td>\n",
              "      <td>45</td>\n",
              "      <td>2</td>\n",
              "      <td>0.802982</td>\n",
              "      <td>9120.0</td>\n",
              "      <td>13</td>\n",
              "      <td>0</td>\n",
              "      <td>6</td>\n",
              "      <td>0</td>\n",
              "      <td>2.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>2</td>\n",
              "      <td>0</td>\n",
              "      <td>0.957151</td>\n",
              "      <td>40</td>\n",
              "      <td>0</td>\n",
              "      <td>0.121876</td>\n",
              "      <td>2600.0</td>\n",
              "      <td>4</td>\n",
              "      <td>0</td>\n",
              "      <td>0</td>\n",
              "      <td>0</td>\n",
              "      <td>1.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>3</td>\n",
              "      <td>0</td>\n",
              "      <td>0.658180</td>\n",
              "      <td>38</td>\n",
              "      <td>1</td>\n",
              "      <td>0.085113</td>\n",
              "      <td>3042.0</td>\n",
              "      <td>2</td>\n",
              "      <td>1</td>\n",
              "      <td>0</td>\n",
              "      <td>0</td>\n",
              "      <td>0.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>4</td>\n",
              "      <td>0</td>\n",
              "      <td>0.233810</td>\n",
              "      <td>30</td>\n",
              "      <td>0</td>\n",
              "      <td>0.036050</td>\n",
              "      <td>3300.0</td>\n",
              "      <td>5</td>\n",
              "      <td>0</td>\n",
              "      <td>0</td>\n",
              "      <td>0</td>\n",
              "      <td>0.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>4</th>\n",
              "      <td>5</td>\n",
              "      <td>0</td>\n",
              "      <td>0.907239</td>\n",
              "      <td>49</td>\n",
              "      <td>1</td>\n",
              "      <td>0.024926</td>\n",
              "      <td>63588.0</td>\n",
              "      <td>7</td>\n",
              "      <td>0</td>\n",
              "      <td>1</td>\n",
              "      <td>0</td>\n",
              "      <td>0.0</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>\n",
              "    <div class=\"colab-df-buttons\">\n",
              "\n",
              "  <div class=\"colab-df-container\">\n",
              "    <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-5a2848d7-3163-4a0e-9a27-bbc2929a7dc5')\"\n",
              "            title=\"Convert this dataframe to an interactive table.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
              "    <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "\n",
              "  <style>\n",
              "    .colab-df-container {\n",
              "      display:flex;\n",
              "      gap: 12px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert {\n",
              "      background-color: #E8F0FE;\n",
              "      border: none;\n",
              "      border-radius: 50%;\n",
              "      cursor: pointer;\n",
              "      display: none;\n",
              "      fill: #1967D2;\n",
              "      height: 32px;\n",
              "      padding: 0 0 0 0;\n",
              "      width: 32px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert:hover {\n",
              "      background-color: #E2EBFA;\n",
              "      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "      fill: #174EA6;\n",
              "    }\n",
              "\n",
              "    .colab-df-buttons div {\n",
              "      margin-bottom: 4px;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert {\n",
              "      background-color: #3B4455;\n",
              "      fill: #D2E3FC;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert:hover {\n",
              "      background-color: #434B5C;\n",
              "      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "      fill: #FFFFFF;\n",
              "    }\n",
              "  </style>\n",
              "\n",
              "    <script>\n",
              "      const buttonEl =\n",
              "        document.querySelector('#df-5a2848d7-3163-4a0e-9a27-bbc2929a7dc5 button.colab-df-convert');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      async function convertToInteractive(key) {\n",
              "        const element = document.querySelector('#df-5a2848d7-3163-4a0e-9a27-bbc2929a7dc5');\n",
              "        const dataTable =\n",
              "          await google.colab.kernel.invokeFunction('convertToInteractive',\n",
              "                                                    [key], {});\n",
              "        if (!dataTable) return;\n",
              "\n",
              "        const docLinkHtml = 'Like what you see? Visit the ' +\n",
              "          '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
              "          + ' to learn more about interactive tables.';\n",
              "        element.innerHTML = '';\n",
              "        dataTable['output_type'] = 'display_data';\n",
              "        await google.colab.output.renderOutput(dataTable, element);\n",
              "        const docLink = document.createElement('div');\n",
              "        docLink.innerHTML = docLinkHtml;\n",
              "        element.appendChild(docLink);\n",
              "      }\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "\n",
              "<div id=\"df-1055cfe1-1180-46a2-b42c-a39fcc549439\">\n",
              "  <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-1055cfe1-1180-46a2-b42c-a39fcc549439')\"\n",
              "            title=\"Suggest charts.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "     width=\"24px\">\n",
              "    <g>\n",
              "        <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
              "    </g>\n",
              "</svg>\n",
              "  </button>\n",
              "\n",
              "<style>\n",
              "  .colab-df-quickchart {\n",
              "      --bg-color: #E8F0FE;\n",
              "      --fill-color: #1967D2;\n",
              "      --hover-bg-color: #E2EBFA;\n",
              "      --hover-fill-color: #174EA6;\n",
              "      --disabled-fill-color: #AAA;\n",
              "      --disabled-bg-color: #DDD;\n",
              "  }\n",
              "\n",
              "  [theme=dark] .colab-df-quickchart {\n",
              "      --bg-color: #3B4455;\n",
              "      --fill-color: #D2E3FC;\n",
              "      --hover-bg-color: #434B5C;\n",
              "      --hover-fill-color: #FFFFFF;\n",
              "      --disabled-bg-color: #3B4455;\n",
              "      --disabled-fill-color: #666;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart {\n",
              "    background-color: var(--bg-color);\n",
              "    border: none;\n",
              "    border-radius: 50%;\n",
              "    cursor: pointer;\n",
              "    display: none;\n",
              "    fill: var(--fill-color);\n",
              "    height: 32px;\n",
              "    padding: 0;\n",
              "    width: 32px;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart:hover {\n",
              "    background-color: var(--hover-bg-color);\n",
              "    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "    fill: var(--button-hover-fill-color);\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart-complete:disabled,\n",
              "  .colab-df-quickchart-complete:disabled:hover {\n",
              "    background-color: var(--disabled-bg-color);\n",
              "    fill: var(--disabled-fill-color);\n",
              "    box-shadow: none;\n",
              "  }\n",
              "\n",
              "  .colab-df-spinner {\n",
              "    border: 2px solid var(--fill-color);\n",
              "    border-color: transparent;\n",
              "    border-bottom-color: var(--fill-color);\n",
              "    animation:\n",
              "      spin 1s steps(1) infinite;\n",
              "  }\n",
              "\n",
              "  @keyframes spin {\n",
              "    0% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "      border-left-color: var(--fill-color);\n",
              "    }\n",
              "    20% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    30% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    40% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    60% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    80% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "    90% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "  }\n",
              "</style>\n",
              "\n",
              "  <script>\n",
              "    async function quickchart(key) {\n",
              "      const quickchartButtonEl =\n",
              "        document.querySelector('#' + key + ' button');\n",
              "      quickchartButtonEl.disabled = true;  // To prevent multiple clicks.\n",
              "      quickchartButtonEl.classList.add('colab-df-spinner');\n",
              "      try {\n",
              "        const charts = await google.colab.kernel.invokeFunction(\n",
              "            'suggestCharts', [key], {});\n",
              "      } catch (error) {\n",
              "        console.error('Error during call to suggestCharts:', error);\n",
              "      }\n",
              "      quickchartButtonEl.classList.remove('colab-df-spinner');\n",
              "      quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
              "    }\n",
              "    (() => {\n",
              "      let quickchartButtonEl =\n",
              "        document.querySelector('#df-1055cfe1-1180-46a2-b42c-a39fcc549439 button');\n",
              "      quickchartButtonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "    })();\n",
              "  </script>\n",
              "</div>\n",
              "    </div>\n",
              "  </div>\n"
            ]
          },
          "metadata": {},
          "execution_count": 3
        }
      ],
      "source": [
        "orgdata=pd.read_csv(\"give_me_some_credit.csv\")\n",
        "orgdata=orgdata.dropna(axis=0)\n",
        "orgdata.head()\n",
        "data=orgdata\n",
        "data.head()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "id": "GMbk-wFEE6oB"
      },
      "outputs": [],
      "source": [
        "x=data.iloc[:,2:data.shape[1]]\n",
        "y=data.iloc[:,1]\n",
        "x.insert(data.shape[1]-2, 'label', y)\n",
        "x.head()\n",
        "x=np.array(x)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "pGdFSG7qE9pf"
      },
      "outputs": [],
      "source": [
        "x[:,[0,2]]=x[:,[2,0]]\n",
        "x[:,[1,8]]=x[:,[8,1]]\n",
        "x[:,[2,6]]=x[:,[6,2]]\n",
        "x[:,[3,4]]=x[:,[4,3]]\n",
        "x[:,[4,9]]=x[:,[9,4]]"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "m2EuRlTtMf5M"
      },
      "source": [
        "##Manipulating the data"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "id": "JMVnlc7tE-2D"
      },
      "outputs": [],
      "source": [
        "x1=x"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "FKwseSTgFAiJ"
      },
      "outputs": [],
      "source": [
        "x1 = np.delete(x1, np.where\n",
        "    (x1[:,0] >= 20), axis=0)\n",
        "x1 = np.delete(x1, np.where\n",
        "    (x1[:,1] >= 20), axis=0)\n",
        "x1 = np.delete(x1, np.where\n",
        "    (x1[:,2] >= 20), axis=0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "HLohK4WzFDjW"
      },
      "outputs": [],
      "source": [
        "x1[:,0][x1[:,0]>=5]=5\n",
        "x1[:,1][x1[:,1]>=5]=5\n",
        "x1[:,2][x1[:,2]>=5]=5"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "id": "UE20ivh6FqIa"
      },
      "outputs": [],
      "source": [
        "x1[:,3][(x1[:,3]>=0)&(x1[:,3]<2500)]=5\n",
        "x1[:,3][(x1[:,3]>=2500)&(x1[:,3]<5000)]=4\n",
        "x1[:,3][(x1[:,3]>=5000)&(x1[:,3]<7500)]=3\n",
        "x1[:,3][(x1[:,3]>=7500)&(x1[:,3]<10000)]=2\n",
        "x1[:,3][(x1[:,3]>=10000)&(x1[:,3]<50000)]=1\n",
        "x1[:,3][x1[:,3]>=50000]=0"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "id": "MdqL2cFvFsLX"
      },
      "outputs": [],
      "source": [
        "x1[:,4][x1[:,4]>=5]=5"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "id": "zhWDrmQlDRkH"
      },
      "outputs": [],
      "source": [
        "X=x1[:,0:len(x1[0])-1]\n",
        "Y=x1[:,-1]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 12,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wtIYWNvgFmRM",
        "outputId": "82dff760-5d49-4e81-caf9-ec290b367e73"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "WARNING:tensorflow:5 out of the last 5 calls to <function FeatureNN.call at 0x7d341bc38ee0> triggered tf.function retracing. Tracing is expensive and the excessive number of tracings could be due to (1) creating @tf.function repeatedly in a loop, (2) passing tensors with different shapes, (3) passing Python objects instead of tensors. For (1), please define your @tf.function outside of the loop. For (2), @tf.function has reduce_retracing=True option that can avoid unnecessary retracing. For (3), please refer to https://www.tensorflow.org/guide/function#controlling_retracing and https://www.tensorflow.org/api_docs/python/tf/function for  more details.\n",
            "WARNING:tensorflow:6 out of the last 6 calls to <function FeatureNN.call at 0x7d341bc39000> triggered tf.function retracing. Tracing is expensive and the excessive number of tracings could be due to (1) creating @tf.function repeatedly in a loop, (2) passing tensors with different shapes, (3) passing Python objects instead of tensors. For (1), please define your @tf.function outside of the loop. For (2), @tf.function has reduce_retracing=True option that can avoid unnecessary retracing. For (3), please refer to https://www.tensorflow.org/guide/function#controlling_retracing and https://www.tensorflow.org/api_docs/python/tf/function for  more details.\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<tf.Tensor: shape=(120121,), dtype=float32, numpy=\n",
              "array([0.02300729, 0.02178343, 0.03869245, ..., 0.02297346, 0.03297052,\n",
              "       0.02980166], dtype=float32)>"
            ]
          },
          "metadata": {},
          "execution_count": 12
        }
      ],
      "source": [
        "tf.compat.v1.reset_default_graph()\n",
        "#the change of the structure of NAM is in kwargs)\n",
        "#in this demo, first three feature are strong monotonicity, thereby, they are combined in a DNN.\n",
        "Number_of_DNN=8\n",
        "Number_of_Unit=0\n",
        "Trainable=True\n",
        "Use_Shallow=False\n",
        "Model=nam_models.NAM(Number_of_DNN,Number_of_Unit,Trainable,Use_Shallow,feature_dropout = 0.0,dropout = 0.0,kwargs=[3,1,1,1,1,1,1,1])\n",
        "Model(X)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 13,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "HFObrqLjFwL3",
        "outputId": "b23ce48b-08d2-4a09-c119-049df2479c26"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Model: \"nam\"\n",
            "_________________________________________________________________\n",
            " Layer (type)                Output Shape              Param #   \n",
            "=================================================================\n",
            " feature_nn (FeatureNN)      multiple                  21        \n",
            "                                                                 \n",
            " feature_nn_1 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_2 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_3 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_4 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_5 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_6 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            " feature_nn_7 (FeatureNN)    multiple                  13        \n",
            "                                                                 \n",
            "=================================================================\n",
            "Total params: 113 (452.00 Byte)\n",
            "Trainable params: 113 (452.00 Byte)\n",
            "Non-trainable params: 0 (0.00 Byte)\n",
            "_________________________________________________________________\n"
          ]
        }
      ],
      "source": [
        "Model.summary()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "faUkSRFRNSyh"
      },
      "source": [
        "##Loading the trained-out model"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 14,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "42jkwKWWKvrb",
        "outputId": "04c63a25-d415-49a0-bb95-984372d26668"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<tensorflow.python.checkpoint.checkpoint.CheckpointLoadStatus at 0x7d340bf5eec0>"
            ]
          },
          "metadata": {},
          "execution_count": 14
        }
      ],
      "source": [
        "Model.load_weights(\"my_checkpoint\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "vFIVgt7tIc37"
      },
      "source": [
        "##Calculating GMShap and Shap value"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "TFh6r184PFBg"
      },
      "source": [
        "###Function of calculating GMShap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 15,
      "metadata": {
        "id": "wIOqRCXcO7tM"
      },
      "outputs": [],
      "source": [
        "from itertools import  product\n",
        "from scipy.special import comb\n",
        "import copy\n",
        "import numpy as np\n",
        "def myshap(spli,X,basevalue):\n",
        "\n",
        "  #generating combinations\n",
        "  def create_mask_arrays(k):\n",
        "    mask = np.array(list(product(range(2), repeat=k)))\n",
        "    mask = mask[~np.all(mask == 1, axis=1)]\n",
        "    return mask\n",
        "\n",
        "  mask=create_mask_arrays(len(spli))\n",
        "  mask2=mask\n",
        "  mask2=np.insert(mask2, len(mask), values=np.ones(len(spli)), axis=0)\n",
        "  mask1=np.repeat(mask,spli,1)\n",
        "  mask1 = np.insert(mask1, len(mask), values=np.ones(sum(spli)), axis=0)\n",
        "  masktemp=np.repeat(mask,spli,1)\n",
        "\n",
        "  #calculating the permutation probablity of shap\n",
        "  def calculate_weight(mask_row):\n",
        "    M = no_of_features = len(mask_row)\n",
        "    z = no_of_masked_feature = np.sum(mask_row)\n",
        "    weight = 1 /  (  comb(M,z) * (M-z)   )\n",
        "    return weight\n",
        "\n",
        "  S_with_zero = mask1*X\n",
        "  S_full = (S_with_zero == 0)*basevalue + S_with_zero\n",
        "  weights =np.apply_along_axis(calculate_weight, 1, mask)\n",
        "\n",
        "  all_value=[]\n",
        "  g=[]\n",
        "  phi_3=[]\n",
        "  for i in range(len(spli)):\n",
        "    mmk=[]\n",
        "    mask3=mask\n",
        "    mask3 = np.insert(mask3, len(mask), values=np.ones(len(spli)), axis=0)\n",
        "    mask3[:,i]=1\n",
        "    mask3=np.repeat(mask3,spli,1)\n",
        "    S_with_zero_1 = mask3*X\n",
        "    S_full_1 = (S_with_zero_1 == 0)*basevalue + S_with_zero_1\n",
        "    all_value.append(np.array(Model(S_full_1))-np.array(Model(S_full)))\n",
        "\n",
        "    #Gshap if the pairwise monotonic features are greater than 1\n",
        "    if(i==0 and spli[0]>1):\n",
        "      inner_shap=[]\n",
        "      for k in range(spli[0]-1):\n",
        "        now_modify=k\n",
        "        S_full_phi_inner=copy.deepcopy(S_full_1)\n",
        "        for m in range(now_modify+1,spli[0]):\n",
        "          S_full_phi_inner[:,now_modify]+=S_full_phi_inner[:,m]\n",
        "          S_full_phi_inner[:,m]=0\n",
        "        inner_shap.append(S_full_phi_inner)\n",
        "      for k in range(spli[0]-1):\n",
        "        g0=np.array(Model(inner_shap[k]))-np.array(Model(S_full))\n",
        "        g.append(g0)\n",
        "      g=np.array(g)\n",
        "\n",
        "  shapp=[]\n",
        "  shapp_g=[]\n",
        "  for i in range(len(spli)):\n",
        "    temp=0\n",
        "    temp_g=np.zeros(spli[0]-1)\n",
        "    for j in range(len(weights)):\n",
        "      if (mask[j][i]==0):\n",
        "        temp+=all_value[i][j]*weights[j]\n",
        "        if (i==0 and spli[0]>1):\n",
        "          for k in range(spli[0]-1):\n",
        "            temp_g[k]+=g[k][j]*weights[j]\n",
        "    shapp.append(temp)\n",
        "    if(i==0 and spli[0]>1):\n",
        "      for k in range(spli[0]-1):\n",
        "        shapp_g.append(temp_g[k])\n",
        "\n",
        "  #return the (shap) or (shap and g_shap)\n",
        "  if(spli[0]==1):\n",
        "    return np.array(shapp)\n",
        "  else:\n",
        "    return np.array(shapp),np.array(shapp_g)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "pUJlFdcHNHrC"
      },
      "source": [
        "###Calculating at a single datapoint"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 16,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Qqhn-3VHODUe",
        "outputId": "b1e01ecf-978c-4ba1-fd9e-c977c03e2516"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "GM_shap [0.06046144 0.09464874 0.24209315 0.04726461 0.03028497 0.00755718\n",
            " 0.21881271 0.         0.06912016 0.02821175]\n",
            "Shap [0.03273938 0.08109591 0.18854755 0.05816981 0.03724596 0.00928689\n",
            " 0.27151687 0.         0.08515888 0.03469345]\n",
            "-----------------\n"
          ]
        }
      ],
      "source": [
        "datapoint=np.array([2,2,5,4,4,11,1.00946276,0,30,0.57013026])\n",
        "#this is the datapoint used in paper\n",
        "for i in range(1):\n",
        "  GM_shap=np.zeros(10)\n",
        "  v1=datapoint[0]\n",
        "  v2=datapoint[1]\n",
        "  v3=datapoint[2]\n",
        "  if((v1==0 and v2==0) or (v2==0 and v3==0) or(v1==0 and v3==0) or (v1==v2 and v2==v3)):\n",
        "    continue\n",
        "  shapp,shapp_g=myshap([3,1,1,1,1,1,1,1],datapoint,[0,0,0,0,0,0,0,0,0,0])\n",
        "  ORG_shap=myshap([1,1,1,1,1,1,1,1,1,1],datapoint,[0,0,0,0,0,0,0,0,0,0])\n",
        "  shapp_g3=shapp[0]\n",
        "  if(v2+v3!=0):\n",
        "    matri=[[v1/(v1+v2+v3),0,0],\n",
        "          [v2/(v1+v2+v3)-v2/(v2+v3),v2/(v2+v3),0],\n",
        "          [v3/(v1+v2+v3)-v3/(v2+v3),(v3/(v2+v3))-1,1]]\n",
        "    shp_1_2_3=np.dot(matri,[shapp_g[0],shapp_g[1],shapp_g3])\n",
        "    shapp_1=shp_1_2_3[0]\n",
        "    shapp_2=shp_1_2_3[1]\n",
        "    shapp_3=shp_1_2_3[2]\n",
        "  elif(v2+v3==0 and v1!=0):\n",
        "    matri=[[v1/(v1+v2+v3),0,0]]\n",
        "    shp_1_2_3=np.dot(matri,[shapp_g[0],shapp_g[1],shapp_g3])\n",
        "    shapp_1=shp_1_2_3[0]\n",
        "    shapp_2=0\n",
        "    shapp_3=0\n",
        "  else:\n",
        "    shapp_1=0\n",
        "    shapp_2=0\n",
        "    shapp_3=0\n",
        "  GM_shap[0]=shapp_1\n",
        "  GM_shap[1]=shapp_2\n",
        "  GM_shap[2]=shapp_3\n",
        "  GM_shap[3:]=shapp[1:]\n",
        "\n",
        "  #Please note that:\n",
        "  #the sequence of x_1 to x_3 in the code is pastdue30-60;;pastdue60-90;pastdue90+\n",
        "  #the sequence of x_1 to x_3 in the paper is  pastdue90+;pastdue60-90;pastdue30-60\n",
        "\n",
        "  print(\"GM_shap\",GM_shap)\n",
        "  print(\"Shap\",ORG_shap)\n",
        "  print(\"-----------------\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9TfjU7FGN48c"
      },
      "source": [
        "##A sample visulization"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "b62o-_6xRmQ_"
      },
      "source": [
        "###the single datapoint for GMShap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 17,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 585
        },
        "id": "rYnVBM8JtkbG",
        "outputId": "a00c6e3b-2052-4e85-ffe8-c2933ad4c05f"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 800x650 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvYAAAI4CAYAAAABA63kAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB2/UlEQVR4nO3dd3RU1drH8W866SQkQKihJKDSpQuCIqiAKMJVwYJ6lfeqiBW9VykKXmxXRcWKKAJioYkUC6KIEEJXCKEkIIQQSnpIICFl3j+OKUPaJCSZ5PD7rDUrZJ/dDofRZ/Y8Zx8Hi8ViQURERERE6jRHe09AREREREQungJ7ERERERETUGAvIiIiImICCuxFRERERExAgb2IiIiIiAkosBcRERERMQEF9iIiIiIiJqDA/hJnsVhIS0tDjzMQERERqdsU2F/izpw5g6+vL2fOnLH3VERERETkIiiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAAnsRERERERNQYC8iIiIiYgLO9p6A1BInkiA9x96zEBEREakYTzfw9bT3LGoFBfZimDAHjqXZexYiIiIitmvVEOY+osD+bwrsxXAkAaLj7T0LEREREakk5diLiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiIXSsmA8R9A4L3gOQaumQo7D5XfLi8P5v0CI2ZC8weNth0eg5cWQ+b5sttu3AcOtxqvhIo/X0iBvYiIiIhIUXl5MOwlWPQ7TLgRXrsHTqfCwKkQFVd227NZcN9siE+Df10Ps+6HniEw7Wu48SWwWEof89FPwLNepadtugdUffzxxyWWOzs7c//999fwbKrHhg0beO+999izZw+HDx8mKyuLZ599lldeecXeUxMRERGp/QZOgeCGMO/Rko8v2QxhB2Dx0zC6r1F2W18InWAE6IueKL1vV2fYNBP6ti8se3CwMd60r2Ddbriuc/F2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lypT3Txbl8XFxZGZmVlmHW9vbwIDA2toRiIiIiJSlyiwryWuv/76Yk8fK6nODz/8UEMzEhEREZG6RIF9LfHWW28RHx9fZp3g4OCamYyIiIiI1Dm6efYSp5tnRURERMxBN8+KiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAAnsRERERERNQYC8iIiIiYgIK7EVERERETECBvYiIiIiICSiwFxERERExAQX2IiIiIiImoMBeRERERMQEFNiLiIiIiJiAs70nIPZlsVgASEtLs/NMRERERKQs3t7eODg4lHpcgf0lLjExEYDmzZvbeSYiIiIiUpbU1FR8fHxKPa7A/hLn7+8PQExMDL6+vnaejVystLQ0mjdvzrFjx8p840vdoOtpLrqe5qLraS515Xp6e3uXeVyB/SXO0dG4zcLX17dW/0OWivHx8dH1NBFdT3PR9TQXXU9zqevXUzfPioiIiIiYgAJ7ERERERETUGB/iXNzc2PatGm4ubnZeypSBXQ9zUXX01x0Pc1F19NczHI9HSz5+x2KiIiIiEidpRV7ERERERETUGAvIiIiImICCuxFRERERExAgb1J7N+/n8GDB+Pp6Unjxo155plnOH/+fLntLBYLr7zyCi1atMDd3Z0+ffoQHh5erF5cXByjRo3C29sbf39/HnjgAdLS0qrjVITqvZ7r16/HwcGh2OuOO+6ortO55FX2er7//vsMHz6cwMBAHBwcWLJkSYn19P6sWdV5PfX+rHmVuZ4nTpzgmWeeoUuXLnh7e9OsWTPGjh3L0aNHi9XV+7NmVef1rAvvTz2gygSSk5O59tprCQkJYdmyZRw/fpwnn3ySs2fPMnv27DLbvvrqq0ybNo1XXnmFTp068d577zFkyBD++OMPWrduDUB2djbXX389AIsWLeLs2bM8/fTTjB07llWrVlX7+V1qqvt65vvss89o3759we8BAQHVcj6Xuou5nvPnzwdg6NChBX++kN6fNau6r2c+vT9rRmWv544dO1i2bBn3338/vXv3JiEhgRkzZtCzZ08iIiIIDAwE9P6sadV9PfPV6venReq8mTNnWjw9PS2JiYkFZR999JHFycnJcvz48VLbnTt3zuLj42P5z3/+U1CWlZVladmypeWhhx4qKFu0aJHFwcHBsn///oKyH3/80QJYtmzZUsVnI9V9PX/99VcLYNm2bVv1nIBYqez1tFgsltzcXIvFYrH89ddfFsCyePHiYnX0/qxZ1X099f6sWZW9nsnJyZbs7GyrsmPHjlkcHBws//vf/wrK9P6sWdV9PevC+1OpOCbw/fffc9111+Hv719Qdtttt5GXl8dPP/1UaruwsDDS0tK47bbbCspcXV259dZbWbNmjVX/nTp1ol27dgVlgwcPxt/f36qeVI3qvp5Ssyp7PQEcHcv/T7TenzWruq+n1KzKXs/69evj7Gyd9NCsWTMCAwOJi4uz6l/vz5pT3dezLtB/ZUxg//79Vl8JgfGPNCgoiP3795fZDijW9rLLLiMmJoZz586V2r+DgwPt27cvs3+pnOq+nvmGDh2Kk5MTzZo1Y9KkScWOS9Wo7PW8mP71/qw+1X098+n9WTOq8noePHiQ06dPc9lll5XZv96f1ae6r2e+2vz+VI69CSQnJ1O/fv1i5X5+fiQlJZXZzs3NjXr16hVrZ7FYSE5Oxt3dvdL9S+VU9/X09fXlmWee4eqrr8bd3Z1ffvmF//3vf+zbt085n9Wgut8/en/WrOr++9b7s2ZV1fW0WCxMnDiRJk2aMGbMmCrvX2xT3dezLrw/FdiLXGK6du1K165dC36/9tprCQoKYsKECWzdupWePXvacXYilza9P+umF154gXXr1vHDDz/g6elp7+nIRSrtetaF96dScUzAz8+P1NTUYuXJyclWeWYltcvKyiIzM7NYOwcHB/z8/C6qf6mc6r6eJcnPy9+xY0clZy2lqe73j96fNcsef996f1afqriec+bMYfr06Xz00UcMGjSoyvsX21X39SxJbXt/KrA3gZJy9VJTUzlx4kSxXLML2wEcOHDAqnz//v0F+6CX1r/FYuHAgQNl9i+VU93XU2pWZa/nxfSv92f1qe7rKTXrYq/n8uXLeeihh5g+fTr333+/Tf3r/Vl9qvt61gUK7E3gxhtv5OeffyYlJaWgbPHixTg6OjJkyJBS2/Xt2xcfHx8WL15cUJadnc2yZcsYOnSoVf9//vknUVFRBWXr1q0jMTHRqp5Ujeq+niX56quvAOjRo8fFTV6Kqez1rEj/en/WnOq+niXR+7P6XMz1XL9+PWPGjOHBBx9kypQppfav92fNqe7rWZJa9/6041abUkWSkpIsQUFBlgEDBlh+/PFHy6effmqpX7++5ZFHHrGqd+2111ratGljVfbyyy9b3NzcLLNmzbKsW7fOMmrUKIu3t7fl0KFDBXXOnz9v6dChg6Vjx46WlStXWr7++mtL8+bNLcOGDauR87vUVPf1vPPOOy3Tpk2zrFixwvLjjz9ann32WYurq6vllltuqZHzu9RczPXctm2bZfHixZb333/fAlieeuopy+LFiy3r168vqKP3Z82q7uup92fNquz1jIyMtPj6+lo6dOhg2bRpk2Xz5s0Fr+jo6IJ6en/WrOq+nnXh/anA3iQiIyMtgwYNsri7u1saNmxoefrppy1ZWVlWdQYMGGBp2bKlVVleXp5l5syZlmbNmlnc3NwsvXr1soSFhRXrPzY21nLrrbdavLy8LPXr17fcf//9ltTU1Oo8pUtadV7PmTNnWq644gqLl5eXxcXFxRIaGmp54YUXivUvVaey13PcuHEWoNhrwIABVvX0/qxZ1Xk99f6seZW5np999lmJ1xKwjBs3zqqt3p81qzqvZ114fzpYLBZLzX0/ICIiIiIi1UE59iIiIiIiJqDAXkRERETEBBTYi4iIiIiYgAJ7ERERERETUGAvIiIiImICCuxFRERERExAgb2IiIiIiAkosBcRERERMQEF9iIiIpVw77334uDgYO9piIgUUGAvIiIFDh8+zPjx42nfvj0eHh74+flx2WWXMW7cOH799VerusHBwXTo0KHUvvID34SEhBKP79u3DwcHBxwcHPj9999L7Se/Tv6rXr16hISE8OSTT5KUlFS5ExURMSFne09ARERqh+3btzNgwABcXFy45557uOKKKzh37hxRUVH89NNPeHt7c80111TZeHPnzsXb2xt3d3c+/fRT+vfvX2rdLl268NRTTwGQlJTEmjVreOutt1i7di07duzA1dW1yuYlIlJXKbAXEREAXnzxRc6ePcsff/xB586dix0/efJklY2VnZ3NggUL+Mc//oGvry8ff/wx77zzDt7e3iXWb9q0KXfddVfB7xMnTuSmm25i1apVrFixgn/84x9VNjcRkbpKqTgiIgJAVFQUDRo0KDGoB2jcuHGVjbVy5UpOnz7NuHHjuPfee8nIyODrr7+uUB/XX389ANHR0aXW+eCDD3BwcOC7774rdiwvL49mzZrRpUuXgrKffvqJ22+/ndatW+Pu7k79+vUZMmQIv/32m01zGjhwIMHBwcXKjxw5goODAy+88IJVucVi4YMPPuDKK6/Ew8MDLy8vrrnmmmJpTyIitlBgLyIiALRp04bExESWLVtmc5vc3FwSEhJKfGVlZZXabu7cubRq1Yr+/fvTqVMnunbtyqefflqh+UZFRQEQEBBQap077rgDNzc35s+fX+zYunXrOH78OOPGjSsomzdvHklJSdxzzz28++67PPHEE+zbt49BgwaVeR9AZd19991MmDCBtm3b8tprr/Hiiy+SmprK4MGDS/wwIiJSJouIiIjFYgkLC7O4uLhYAEtISIjlvvvus7z//vuWyMjIEuu3bNnSApT7io+Pt2p3/Phxi5OTk2XatGkFZbNmzbIAJY4FWIYMGWKJj4+3xMfHWw4ePGh58803LS4uLhZfX1/LqVOnyjyv0aNHW9zc3CxJSUlW5XfddZfF2dnZqn16enqx9idPnrQ0aNDAcuONN1qVjxs3znLh/0YHDBhgadmyZbE+/vrrLwtgdc7Lli2zAJaPPvrIqm52drblyiuvtAQHB1vy8vLKPDcRkaK0Yi8iIgD06dOHHTt2MG7cOFJTU/nss894+OGHufzyy7n66qs5fPhwsTbBwcGsXbu2xNeQIUNKHGfevHnk5eVxzz33FJTdeeeduLi4lLpq/9NPPxEYGEhgYCChoaE8+eSTXH755fz00080bNiwzPMaN24cWVlZVqk+6enpLF++nBtuuMGqvaenp1WdxMREnJyc6NWrF1u2bClznIpauHAh3t7e3HLLLVbfdKSkpHDTTTdx5MiRgm8lRERsoZtnRUSkQMeOHZk3bx4AR48e5bfffuOTTz7h999/5+abby62A42npyfXXXddiX0tXLiwWJnFYuHTTz+lU6dO5OXlWeXHX3XVVSxYsICXX34ZZ2fr/z316tWLl156CQA3NzdatmxJixYtbDqn/OB9/vz5/Otf/wJg6dKlZGRkWH24ADh06BDPP/88P/74IykpKVbHqnrP+n379nHmzBkaNWpUap1Tp04RGhpapeOKiHkpsBcRkRK1bNmSe+65h7vvvpv+/fuzadMmtm7dSr9+/Srd52+//cahQ4cACAkJKbHOqlWruOWWW6zKAgICSv0AUR5nZ2fGjh3LrFmziI6Opm3btsyfPx8/Pz9GjBhRUC89PZ2rr76ajIwMHn/8cTp27Ii3tzeOjo68/PLL/PLLL+WOVVrwn5OTU6zMYrEQGBjIokWLSu2vrOcEiIhcSIG9iIiUycHBgV69erFp0yaOHz9+UX19+umnBTezOjoWzwb9v//7P+bOnVsssL9Y48aNY9asWcyfP58HH3yQ9evXM378eNzc3ArqrFu3jri4OD799FPuu+8+q/aTJ0+2aRx/f3927NhRrLykNKaQkBAOHjxI79698fLyquAZiYgUp8BeREQAWLt2Lddcc02xNJhz587x008/AXD55ZdXuv/U1FSWLFnCkCFDuO2220qss3r1ahYsWMCJEycICgqq9FgX6tKlC506dWLhwoXUq1ePvLw8q91wAJycnABjJb2on376yeb8+tDQUJYtW8bWrVvp2bMnYGyr+dZbbxWre88997By5Ur+85//8O677xY7furUqTLTdERELqTAXkREAHjiiSdITExkxIgRdOzYEQ8PD44dO8aiRYs4ePAg99xzDx07dqx0/19++SXnzp1j1KhRpdYZNWoU8+bN4/PPP+ff//53pccqybhx43jqqad49dVXCQ0NpXfv3lbH+/XrR+PGjXnqqac4cuQIzZo1448//mDBggV07NiRPXv2lDvG+PHjeeONNxg5ciSPPfYYrq6uLFmypMRUnNGjR3Pfffcxe/Zsdu7cyfDhwwkICCA2NpbNmzcTHR1d4kq/iEhptCuOiIgA8Oabb3LrrbcSHh7OCy+8wPjx43nnnXdo0qQJc+fO5bPPPruo/ufOnYuzs7NVXvuFBg8ejLe390WPVZI777wTZ2dn0tLSit00C1C/fn1+/PFHevXqxbvvvstTTz1FZGQka9asoVu3bjaN0apVK7799lsCAwOZMmUKr732GldddRWff/55ifU//fTTgrSkl19+mUcffZTPP/8cLy8vXn755Ys6XxG59DhYLvzOUURERERE6hyt2IuIiIiImIACexERERERE1BgLyIiIiJiAgrsRURERERMQIG9iIiIiIgJKLAXERERETEBBfYiIiIiIiagwF5ERERExAQU2IuIiIiImIACexERERERE1BgLyIiIiJiAgrsRURERERM4P8BnX9zAs2EIG8AAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "explainer1 = shap.Explainer(Model,np.array([[0,0,0,0,0,0,0,0,0,0]]))\n",
        "explainer1.feature_names=['x_1', 'x_2', 'x_3','x_4','x_5', 'x_6', 'x_7', 'x_8', 'x_9', 'x_10']\n",
        "\n",
        "shap_values1 = explainer1([datapoint])\n",
        "\n",
        "# visualize the first prediction's explanation\n",
        "# the x_1 to x_3 in paper is pastdue90+;pastdue60-90;pastdue30-60\n",
        "# the x_1 to x_3 in code is pastdue30-60;pastdue60-90;pastdue90+\n",
        "# to fit the sequence in paper, we swap x_1 and x_3 in visulization part.\n",
        "\n",
        "shap_values1.data=np.array([[5,2,2,4,4,11,1.00946276,0,30,0.57013026]])\n",
        "temp=GM_shap[2]\n",
        "GM_shap[2]=GM_shap[0]\n",
        "GM_shap[0]=temp\n",
        "shap_values1.values=[GM_shap]\n",
        "\n",
        "shap.plots.bar(shap_values1[0],show_data=True)\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "5w_vfCW_Rq9h"
      },
      "source": [
        "###the single datapoint for Shap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 18,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 585
        },
        "id": "E-d8vB0FRtDR",
        "outputId": "718ebb95-a4e5-44df-92b7-eeb3c264bcac"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 800x650 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvYAAAI4CAYAAAABA63kAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB3FUlEQVR4nO3dd3hUVeLG8W866RASegklAZEuXRAUQYWIIiyCDXWVXRWxov6UorCLq66CihVRBEVdmkixIIoIIXSFEEoCQgihJKSRQPr8/rikTOokJExyeT/PM08y5557z7m5Dr5z5twzDhaLxYKIiIiIiNRqjvbugIiIiIiIXDoFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEF+yucxWIhJSUFfZ2BiIiISO2mYH+FO3fuHL6+vpw7d87eXRERERGRS6BgLyIiIiJiAgr2IiIiIiImoGAvIiIiImICCvYiIiIiIiagYC8iIiIiYgIK9iIiIiIiJqBgLyIiIiJiAgr2IiIiIiImoGAvIiIiImICCvYiIiIiIiagYC8iIiIiYgIK9iIiIiIiJqBgLyIiIiJiAgr2IiIiIiImoGAvIiIiImICCvYiIiIiIiagYC8iIiIiYgIK9iIiIiIiJqBgLyIiIiJiAgr2IiIiIiImoGAvIiIiImICCvYiIiIiIibgbO8OSA1xMgFSs+3dCxEREZGK8XQDX09796JGULAXw8R5cDzF3r0QERERsV2rBjD/MQX7ixTsxXA0HqLi7N0LEREREakkzbEXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERET0HKXIiIiIiJFJaXBcwthxVY4nwG9guDN8dC9Tdn75ebCwg2wPAx2/wUJqcZ6+2P7w7O3QR3XgroLfoEH5pZ+rC+egLsH2txlBXsRERERkcJyc2H4v+DPYzD5NvD3gfd/gEHTYOcbENSk9H3PZxhhvU8w/PMmaOALWw7C9G9g/V745RVwcDDqXtcBFj1R/BizV8GfR2Fw5wp1u8LBfvfu3cTHxxMfH8+5c+fw8vLirrvuquhhOHToEHv37iUpKQlXV1datGhBr169cHd3L1b3zJkzbN++nTNnzgDQsGFDevXqhb+/f7G6J06c4I8//uDMmTPk5uZS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WbPTun6bRtC3yKyN8GOw5xi8cEfBt9JWQrUG+9TUVLKzs/Hx8clf2rJly5Y4OTmxb98+2rZtm19+7Ngxzp07R48ePfL39/X1JSAggCNHjtCjRw+rG2aPHDlC06ZNyx0xT0lJ4c8//8TX15fWrVuX2+fqmGN/+vRpHn74YTw9Pfn2229xcHCga9eu/P3vf6dv3740aWLDxzklWLVqFdHR0QwaNMjqjYyIiIiIXAInJ1g7BSZ/Du+sMVbB6dnW+Kbadk3L3vfsOThurNrIC18U3z7++uLB/svfjZ93DbikbjtYLBZLRXY4dOgQqampgPENsDk5OXTu3BkALy8vgoOD8+uuWrWKkydPMm7cOLy9vfPLC3/zbNu2bfO/edbLy4uRI0dazYXPW6XG09Mz/waD8PBwLly4wG233Ub9+vXz60ZERBAdHU2jRo2oU6cOSUlJHDhwAEdHR4YPH25V93KxWCzccMMN/PbbbyxZsiR/hP7bb79l9OjRXHPNNYSFhVmt4mOr4cOHs3btWr755hvGjBlTqf6lpKTg6+tLctsJ+ETFVeoYIiIiInbRrin88go08bN3T2qECo/YHzx4kJMnT1qV7dixA4DGjRtbBfvSdO7cGTc3N/bu3UtoaCguLi60bt2a3r17F7vBtVGjRtx6661s376d7du34+DgQMOGDRkyZEixoF6vXj0OHz7Mnj17yMzMxMPDg7Zt29KtW7cSl9e8HGbMmMGGDRt48MEHrabd3H777UyYMIEPPviAl156iVmzZlXouHFxcfz666/4+/szevToqu62iIiIiNQyFR6xF3PRiL2IiIjUWhqxt3LZv3lWRERERESq3mVfFUdKduLEiXKX2fTx8SlxFSAREREREQX7GmLIkCHs37+/zDrDhw+v0FKcIiIiInLlULCvIWbPnk1CQkKZddq0aXOZeiMiIiIitY2CfQ1x00032bsLIiIiIlKL6eZZERERERETULAXERERETEBTcURQ6A/OLnauxciIiIitmvVwN49qFEU7MUw92Hw9rF3L0REREQqxtPN3j2oMRTsxdDYD3wU7EVERERqK82xFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEF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x0Nzf6Ns/R5jNZ2nbjWeN/A1lrcs6p01sOUQfPVUyTfgioiISI1nmmCfnZ1Neno60dHRVvOX8kRFRREVFUXv3r3p0qWUEdOLVqxYQWpqqk3tDhw4kHbt2pVbLywsjJkzZ9KxY0eaNWvGypUrmTt3bpWOrEdERADV84mDXAaj+0KfYHhgLkTEgL+38c2zObnwyljruoOnGz+PflRQ9uIo403A9dPgieHGyPwbK43pOw/cYNTxcIPbexdv+9ttsC2q5G0iIiJSK5gm2Lu4uHDjjTcWK09PT2fTpk00b96cdu3a4edXxrzoi2644YYKzbEvT2pqKqNGjcLDw4NFixbRunVr2rdvz9SpUxk0aBCdO3e2qS0w3sCcPXuWhg0bWpUfPXqUBQsW4OnpSUhIiM3HkxrEycmYXz/5c2ME/UIm9GwLCx435vWXp7k//DYTnl4AL3wBrs4w/Bp48/6yv9hKRERETMF0N88WVZmbZ6vaiBEjWL16NXPmzMkfod+0aRODBg3i6quvJiwsDHd3d5uOlZSURLNmzejXrx/t27fH39+fyMhIli9fTnp6Oi+//DJTp061uW+6ebYSbLl5VkREROQyM82IfU314YcfsmrVKkaOHMnEiRPzy/v378+LL77IzJkzmTRpEvPmzbPpeO7u7gwZMoRdu3axefNm0tPT8fb2pmvXrjz99NOMGjWquk5FRERERGow04/YS9k0Yl8JGrEXERGRGsh0X1AlIiIiInIl0lScGuL06dP5S3OWxsPDQyveiIiIiEiJFOxriGHDhrFr164y6wwYMICNGzdeph6JiIiISG2iYF9DvPXWW8TGxpZZp0mTMr55VERERESuaAr2NcTAgQPt3QURERERqcV086yIiIiIiAloxF4Mgf7g5GrvXtQOrRrYuwciIiIixSjYi2Huw+DtY+9e1B6ebvbugYiIiIgVBXsxNPYDHwV7ERERkdpKc+xFRERERExAwV5ERERExAQU7EVERERETEDBXkRERETEBBTsRURERERMQMFeRERERMQEFOxFRERERExAwV5ERERExAQU7EVERERETEDBXkRERETEBBTsRURERERMQMFeRERERMQEnO3dAakhTiZAara9e1HzeLqBr6e9eyEiIiJSLgV7MUycB8dT7N2LmqVVA5j/mIK9iIiI1AoK9mI4Gg9RcfbuhYiIiIhUkubY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7EVERKQWM+2qOCIiIiIiVxJTTcWpzU6fPk1aWlqZdTw8PKpljX0RERERqf0U7GuIYcOGsWvXrjLrDBgwgI0bN16mHomIiIhIbaJgX0O89dZbxMbGllmnSZMyvp1URERERK5oCvY1xMCBA+3dBRERERGpxXTzrIiIiIiICWjEXgyB/uB0ha9/36pB+XVEREREaigFezHMfRi8fezdC/vzdLN3D0REREQqRcFeDI39wEfBXkRERKS20hx7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAWd7d0BqiJMJkJp96cfxdANfz0s/joiIiIhUiIK9GCbOg+Mpl3aMVg1g/mMK9iIiIiJ2oGAvhqPxEBVn716IiIiISCVpjr2IiIiIiAko2IuIiIiImICCvYiIiIiICSjYi4iIiIiYgIK9iIiIiIgJKNiLiIiIiJiAgr3UDklpMOEDCLgfPMfB9dNg12Hb998fAzfPAK+7wO8+uPdtiEsuXu/fS2HELGj4ADjcAS9/XWWnICIiIlKdFOyl5svNheH/gsW/w8Rb4PX74EwyDJoGkbHl7x8TD9dNgahTMOtueHYErNkJQ16BzCzrulMWw/Yo6Naqes5FREREpJroC6rE/gZNhcAGsODxkrcv3QKhB2HJszC6n1E2ph8ET4Tp38Dip8o+/qxlkJYOO9+AFgFGWa8gI9gv+BUmDC2o+9eHRl/iU4xPB0RERERqiRof7Hfv3k18fDzx8fGcO3cOLy8v7rrrrhLrxsTE8NdffxEfH09CQgI5OTmEhITQpEmTy9zr6peens57773HggULOHLkCNnZ2fj7+zN06FA+++wze3evai3dAg3rwh19CsoCfI1w/8VGyMgCN5fS918WBiE9CkI9wI1dILgJ/C/UOtgHNqjy7ouIiIhcDjU+2G/fvh03Nzf8/f3JzMwss25UVBRRUVHUq1ePunXrcvbs2cvUy8vr3LlzPPDAAyxbtow+ffrw5JNP4uLiwpEjR4iJibF396re7r+ge2twLDJzrFcQfLwODsVCp5Yl73virDFtp0eb4tt6BcHanVXfXxERERE7qPHBfuzYsfj4+ACwZMkSsrKySq3bs2dP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RMQcTBfspWIU7EVERETMwVSr4oiIiIiIXKlMdfNsbRYbG0t6enqZdby9vQkICLhMPRIRERGR2kTBvoa46aabin37WEl1fvjhh8vUIxERERGpTRTsa4jZs2cTFxdXZp3AwMDL0xkRERERqXV08+wVTjfPioiIiJiDbp4VERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBBXsRERERERNQsBcRERERMQEFexERERERE1CwFxERERExAQV7ERERERETULAXERERETEBZ3t3QOzLYrEAkJKSYueeiIiIiEhZvL29cXBwKHW7gv0V7uzZswA0b97czj0RERERkbIkJyfj4+NT6nYF+yucn58fANHR0fj6+tq5N1JYSkoKzZs35/jx42W+iMU+dH1qLl2bmk3Xp+bStan5vL29y9yuYH+Fc3Q0brPw9fXVi7iG8vHx0bWpwXR9ai5dm5pN16fm0rWpvXTzrIiIiIiICSjYi4iIiIiYgIL9Fc7NzY3p06fj5uZm765IEbo2NZuuT82la1Oz6frUXLo2tZ+DJW+9QxERERERqbU0Yi8iIiIiYgIK9iIiIiIiJqBgLyIiIiJiAgr2JnHgwAGGDBmCp6cnjRo14rnnniMzM7Pc/SwWC//5z39o0aIF7u7u9O3bl7CwsGL1YmNjGTVqFN7e3vj5+fHQQw+RkpJSHadiOtV5bTZs2ICDg0Oxx9ixY6vrdEynstfn/fffJyQkhICAABwcHFi6dGmJ9fTaqbzqvDZ67Vy6ylyfkydP8txzz9G1a1e8vb1p1qwZd911F8eOHStWV6+dS1Od10evn5pLX1BlAomJidxwww0EBQWxfPlyTpw4wdNPP8358+eZO3dumfu+9tprTJ8+nf/85z907tyZ9957j6FDh/LHH3/QunVrALKysrjpppsAWLx4MefPn+fZZ5/lrrvuYvXq1dV+frVZdV+bPJ999hnt27fPf+7v718t52M2l3J9Fi5cCMCwYcPyfy9Kr53Kq+5rk0evncqp7PXZuXMny5cv58EHH6RPnz7Ex8czc+ZMevXqRXh4OAEBAYBeO5equq9PHr1+aiCL1HqzZs2yeHp6Ws6ePZtf9tFHH1mcnJwsJ06cKHW/CxcuWHx8fCz/93//l1+WkZFhadmypeWRRx7JL1u8eLHFwcHBcuDAgfyyH3/80QJYtm7dWsVnYy7VfW1+/fVXC2DZvn179ZyAyVX2+lgsFktOTo7FYrFY/vrrLwtgWbJkSbE6eu1UXnVfG712Lk1lr09iYqIlKyvLquz48eMWBwcHy3//+9/8Mr12Lk11Xx+9fmouTcUxge+//54bb7wRPz+//LIxY8aQm5vLTz/9VOp+oaGhpKSkMGbMmPwyV1dX7rjjDtauXWt1/M6dO9OuXbv8siFDhuDn52dVT4qr7msjl6ay1wfA0bH8fz712qm86r42cmkqe33q1q2Ls7P1ZIFmzZoREBBAbGys1fH12qm86r4+UnPpXz8TOHDggNVHYWC8OBs3bsyBAwfK3A8otu9VV11FdHQ0Fy5cKPX4Dg4OtG/fvszjS/VfmzzDhg3DycmJZs2aMXny5GLbpWSVvT6Xcny9dmxT3dcmj147lVOV1+fQoUOcOXOGq666qszj67Vju+q+Pnn0+ql5NMfeBBITE6lbt26x8nr16pGQkFDmfm5ubtSpU6fYfhaLhcTERNzd3St9fKn+a+Pr68tzzz3Hddddh7u7O7/88gv//e9/2b9/v+ah2qC6/9vWa6fyqvtvp9fOpamq62OxWJg0aRJNmjRh3LhxVX78K1V1Xx+9fmouBXuRWqxbt25069Yt//kNN9xA48aNmThxItu2baNXr1527J1IzaXXTs3w8ssvs379en744Qc8PT3t3R0porTro9dPzaWpOCZQr149kpOTi5UnJiZaza8rab+MjAzS09OL7efg4EC9evUu6fhS/demJHnz8nfu3FnJXl85qvu/bb12Ks8efzu9dmxXFddn3rx5zJgxg48++ojBgwdX+fGvZNV9fUqi10/NoGBvAiXNOUxOTubkyZPF5tgV3Q/g4MGDVuUHDhzIXzu9tONbLBYOHjxY5vGl+q+NXJrKXp9LOb5eO7ap7msjl+ZSr8+KFSt45JFHmDFjBg8++KBNx9drx3bVfX2k5lKwN4FbbrmFn3/+maSkpPyyJUuW4OjoyNChQ0vdr1+/fvj4+LBkyZL8sqysLJYvX86wYcOsjv/nn38SGRmZX7Z+/XrOnj1rVU+Kq+5rU5Kvv/4agJ49e15a568Alb0+FTm+XjuVU93XpiR67djuUq7Phg0bGDduHA8//DBTp04t9fh67VRedV+fkuj1U0PYcalNqSIJCQmWxo0bWwYOHGj58ccfLZ9++qmlbt26lscee8yq3g033GBp06aNVdmrr75qcXNzs8yZM8eyfv16y6hRoyze3t6Ww4cP59fJzMy0dOzY0dKpUyfLqlWrLN98842lefPmluHDh1+W86vNqvva3H333Zbp06dbVq5cafnxxx8tzz//vMXV1dVy++23X5bzq+0u5fps377dsmTJEsv7779vASzPPPOMZcmSJZYNGzbk19Frp/Kq+9rotXNpKnt9IiIiLL6+vpaOHTtaNm/ebNmyZUv+IyoqKr+eXjuXprqvj14/NZeCvUlERERYBg8ebHF3d7c0aNDA8uyzz1oyMjKs6gwcONDSsmVLq7Lc3FzLrFmzLM2aNbO4ublZevfubQkNDS12/JiYGMsdd9xh8fLystStW9fy4IMPWpKTk6vzlEyjOq/NrFmzLFdffbXFy8vL4uLiYgkODra8/PLLxY4vpavs9Rk/frwFKPYYOHCgVT29diqvOq+NXjuXrjLX57PPPivx2gCW8ePHW+2r186lqc7ro9dPzeVgsVgsl+/zARERERERqQ6aYy8iIiIiYgIK9iIiIiIiJqBgLyIiIiJiAgr2IiIiIiImoGAvIiIiImICCvYiIiIiIiagYC8iIiIiYgIK9iIiIiIiJqBgLyIiUgn3338/Dg4O9u6GiEg+BXsREcl35MgRJkyYQPv27fHw8KBevXpcddVVjB8/nl9//dWqbmBgIB07diz1WHnBNz4+vsTt+/fvx8HBAQcHB37//fdSj5NXJ+9Rp04dgoKCePrpp0lISKjciYqImJCzvTsgIiI1w44dOxg4cCAuLi7cd999XH311Vy4cIHIyEh++uknvL29uf7666usvfnz5+Pt7Y27uzuffvopAwYMKLVu165deeaZZwBISEhg7dq1zJ49m3Xr1rFz505cXV2rrF8iIrWVgr2IiADwyiuvcP78ef744w+6dOlSbPupU6eqrK2srCwWLVrE3/72N3x9ffn4449555138Pb2LrF+06ZNueeee/KfT5o0iVtvvZXVq1ezcuVK/va3v1VZ30REaitNxREREQAiIyOpX79+iaEeoFGjRlXW1qpVqzhz5gzjx4/n/vvvJy0tjW+++aZCx7jpppsAiIqKKrXOBx98gIODA999912xbbm5uTRr1oyuXbvml/3000/ceeedtG7dGnd3d+rWrcvQoUP57bffbOrToEGDCAwMLFZ+9OhRHBwcePnll63KLRYLH3zwAddccw0eHh54eXlx/fXXF5v2JCJiCwV7EREBoE2bNpw9e5bly5fbvE9OTg7x8fElPjIyMkrdb/78+bRq1YoBAwbQuXNnunXrxqefflqh/kZGRgLg7+9fap2xY8fi5ubGwoULi21bv349J06cYPz48fllCxYsICEhgfvuu493332Xp556iv379zN48OAy7wOorHvvvZeJEyfStm1bXn/9dV555RWSk5MZMmRIiW9GRETKZBEREbFYLKGhoRYXFxcLYAkKCrI88MADlvfff98SERFRYv2WLVtagHIfcXFxVvudOHHC4uTkZJk+fXp+2Zw5cyxAiW0BlqFDh1ri4uIscXFxlkOHDlneeusti4uLi8XX19dy+vTpMs9r9OjRFjc3N0tCQoJV+T333GNxdna22j81NbXY/qdOnbLUr1/fcsstt1iVjx8/3lL0f6MDBw60tGzZstgx/vrrLwtgdc7Lly+3AJaPPvrIqm5WVpblmmuusQQGBlpyc3PLPDcRkcI0Yi8iIgD07duXnTt3Mn78eJKTk/nss8949NFH6dChA9dddx1Hjhwptk9gYCDr1q0r8TF06NAS21mwYAG5ubncd999+WV33303Li4upY7a//TTTwQEBBAQEEBwcDBPP/00HTp04KeffqJBgwZlntf48ePJyMiwmuqTmprKihUruPnmm6329/T0tKpz9uxZnJyc6N27N1u3bi2znYr64osv8Pb25vbbb7f6pCMpKYlbb72Vo0eP5n8qISJiC908KyIi+Tp16sSCBQsAOHbsGL/99huffPIJv//+O7fddluxFWg8PT258cYbSzzWF198UazMYrHw6aef0rlzZ3Jzc63mx1977bUsWrSIV199FWdn6/899e7dm3/9618AuLm50bJlS1q0aGHTOeWF94ULF/LPf/4TgGXLlpGWlmb15gLg8OHDvPTSS/z4448kJSVZbavqNev379/PuXPnaNiwYal1Tp8+TXBwcJW2KyLmpWAvIiIlatmyJffddx/33nsvAwYMYPPmzWzbto3+/ftX+pi//fYbhw8fBiAoKKjEOqtXr+b222+3KvP39y/1DUR5nJ2dueuuu5gzZw5RUVG0bduWhQsXUq9ePUaMGJFfLzU1leuuu460tDSefPJJOnXqhLe3N46Ojrz66qv88ssv5bZVWvjPzs4uVmaxWAgICGDx4sWlHq+s7wkQESlKwV5ERMrk4OBA79692bx5MydOnLikY3366af5N7M6OhafDfqPf/yD+fPnFwv2l2r8+PHMmTOHhQsX8vDDD7NhwwYmTJiAm5tbfp3169cTGxvLp59+ygMPPGC1/5QpU2xqx8/Pj507dxYrL2kaU1BQEIcOHaJPnz54eXlV8IxERIpTsBcREQDWrVvH9ddfX2wazIULF/jpp58A6NChQ6WPn5yczNKlSxk6dChjxowpsc6aNWtYtGgRJ0+epHHjxpVuq6iuXbvSuXNnvvjiC+rUqUNubq7VajgATk5OgDGSXthPP/1k8/z64OBgli9fzrZt2+jVqxdgLKs5e/bsYnXvu+8+Vq1axf/93//x7rvvFtt++vTpMqfpiIgUpWAvIiIAPPXUU5w9e5YRI0bQqVMnPDw8OH78OIsXL+bQoUPcd999dOrUqdLH/+qrr7hw4QKjRo0qtc6oUaNYsGABn3/+OS+88EKl2yrJ+PHjeeaZZ3jttdcIDg6mT58+Vtv79+9Po0aNeOaZZzh69CjNmjXjjz/+YNGiRXTq1Im9e/eW28aECRN48803GTlyJE888QSurq4sXbq0xKk4o0eP5oEHHmDu3Lns2rWLkJAQ/P39iYmJYcuWLURFRZU40i8iUhqtiiMiIgC89dZb3HHHHYSFhfHyyy8zYcIE3nnnHZo0acL8+fP57LPPLun48+fPx9nZ2Wpee1FDhgzB29v7ktsqyd13342zszMpKSnFbpoFqFu3Lj/++CO9e/fm3Xff5ZlnniEiIoK1a9fSvXt3m9po1aoV3377LQEBAUydOpXXX3+da6+9ls8//7zE+p9++mn+tKRXX32Vxx9/nM8//xwvLy9effXVSzpfEbnyOFiKfuYoIiIiIiK1jkbsRURERERMQMFeRERERMQEFOxFRERERExAwV5ERERExAQU7EVERERETEDBXkRERETEBBTsRURERERMQMFeRERERMQEFOxFRERERExAwV5ERERExAQU7EVERERETEDBXkRERETEBP4fGHpcvwEgt60AAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "explainer2= shap.Explainer(Model,np.array([[0,0,0,0,0,0,0,0,0,0]]))\n",
        "explainer2.feature_names=['x_1', 'x_2', 'x_3','x_4','x_5', 'x_6', 'x_7', 'x_8', 'x_9', 'x_10']\n",
        "shap_values2 = explainer2([datapoint])\n",
        "\n",
        "# the x_1 to x_3 in paper is pastdue90+;pastdue60-90;pastdue30-60\n",
        "# the x_1 to x_3 in code is pastdue30-60;pastdue60-90;pastdue90+\n",
        "# to fit the sequence in paper, we swap x_1 and x_3 in visulization part.\n",
        "\n",
        "shap_values2.data=np.array([[5,2,2,4,4,11,1.00946276,0,30,0.57013026]])\n",
        "temp=ORG_shap[2]\n",
        "ORG_shap[2]=ORG_shap[0]\n",
        "ORG_shap[0]=temp\n",
        "shap_values2.values=[ORG_shap]\n",
        "\n",
        "shap.plots.bar(shap_values2[0],show_data=True)"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}