{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_credit = pd.read_csv(\"./german_credit/german_credit_data.csv\",index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<class 'pandas.core.frame.DataFrame'>\n",
      "Index: 1000 entries, 0 to 999\n",
      "Data columns (total 10 columns):\n",
      " #   Column            Non-Null Count  Dtype \n",
      "---  ------            --------------  ----- \n",
      " 0   Age               1000 non-null   int64 \n",
      " 1   Sex               1000 non-null   object\n",
      " 2   Job               1000 non-null   int64 \n",
      " 3   Housing           1000 non-null   object\n",
      " 4   Saving accounts   817 non-null    object\n",
      " 5   Checking account  606 non-null    object\n",
      " 6   Credit amount     1000 non-null   int64 \n",
      " 7   Duration          1000 non-null   int64 \n",
      " 8   Purpose           1000 non-null   object\n",
      " 9   Risk              1000 non-null   object\n",
      "dtypes: int64(4), object(6)\n",
      "memory usage: 85.9+ KB\n"
     ]
    }
   ],
   "source": [
    "df_credit.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Subset dataset info:\n",
      "<class 'pandas.core.frame.DataFrame'>\n",
      "Index: 1000 entries, 0 to 999\n",
      "Data columns (total 5 columns):\n",
      " #   Column           Non-Null Count  Dtype \n",
      "---  ------           --------------  ----- \n",
      " 0   Age              1000 non-null   int64 \n",
      " 1   Sex              1000 non-null   object\n",
      " 2   Saving accounts  817 non-null    object\n",
      " 3   Credit amount    1000 non-null   int64 \n",
      " 4   Risk             1000 non-null   object\n",
      "dtypes: int64(2), object(3)\n",
      "memory usage: 46.9+ KB\n",
      "None\n",
      "\n",
      "First few rows:\n",
      "   Age     Sex Saving accounts  Credit amount  Risk\n",
      "0   67    male             NaN           1169  good\n",
      "1   22  female          little           5951   bad\n",
      "2   49    male          little           2096  good\n",
      "3   45    male          little           7882  good\n",
      "4   53    male          little           4870   bad\n",
      "\n",
      "Value counts for categorical variables:\n",
      "Sex: Sex\n",
      "male      690\n",
      "female    310\n",
      "Name: count, dtype: int64\n",
      "Saving accounts: Saving accounts\n",
      "little        603\n",
      "moderate      103\n",
      "quite rich     63\n",
      "rich           48\n",
      "Name: count, dtype: int64\n",
      "Risk: Risk\n",
      "good    700\n",
      "bad     300\n",
      "Name: count, dtype: int64\n"
     ]
    }
   ],
   "source": [
    "# Create subset with only specified features\n",
    "selected_features = ['Age', 'Sex', 'Saving accounts', 'Credit amount', 'Risk']\n",
    "df_subset = df_credit[selected_features].copy()\n",
    "\n",
    "print(\"Subset dataset info:\")\n",
    "print(df_subset.info())\n",
    "print(\"\\nFirst few rows:\")\n",
    "print(df_subset.head())\n",
    "print(\"\\nValue counts for categorical variables:\")\n",
    "print(\"Sex:\", df_subset['Sex'].value_counts())\n",
    "print(\"Saving accounts:\", df_subset['Saving accounts'].value_counts())\n",
    "print(\"Risk:\", df_subset['Risk'].value_counts())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Missing values before handling:\n",
      "Age                  0\n",
      "Sex                  0\n",
      "Saving accounts    183\n",
      "Credit amount        0\n",
      "Risk                 0\n",
      "dtype: int64\n",
      "\n",
      "Missing values after handling:\n",
      "Age                0\n",
      "Sex                0\n",
      "Saving accounts    0\n",
      "Credit amount      0\n",
      "Risk               0\n",
      "dtype: int64\n",
      "\n",
      "Encoded values:\n",
      "Sex mapping: {'female': np.int64(0), 'male': np.int64(1)}\n",
      "Saving accounts mapping: {'little': np.int64(0), 'moderate': np.int64(1), 'quite rich': np.int64(2), 'rich': np.int64(3), 'unknown': np.int64(4)}\n",
      "Risk mapping: {'bad': np.int64(0), 'good': np.int64(1)}\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from sklearn.preprocessing import LabelEncoder, StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.neural_network import MLPClassifier\n",
    "from sklearn.metrics import classification_report, confusion_matrix, accuracy_score\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# Handle missing values in 'Saving accounts' column\n",
    "print(\"Missing values before handling:\")\n",
    "print(df_subset.isnull().sum())\n",
    "\n",
    "# Fill missing values in 'Saving accounts' with 'unknown'\n",
    "df_subset['Saving accounts'] = df_subset['Saving accounts'].fillna('unknown')\n",
    "\n",
    "print(\"\\nMissing values after handling:\")\n",
    "print(df_subset.isnull().sum())\n",
    "\n",
    "# Encode categorical variables\n",
    "le_sex = LabelEncoder()\n",
    "le_saving = LabelEncoder()\n",
    "le_risk = LabelEncoder()\n",
    "\n",
    "df_subset['Sex_encoded'] = le_sex.fit_transform(df_subset['Sex'])\n",
    "df_subset['Saving_accounts_encoded'] = le_saving.fit_transform(df_subset['Saving accounts'])\n",
    "df_subset['Risk_encoded'] = le_risk.fit_transform(df_subset['Risk'])\n",
    "\n",
    "print(\"\\nEncoded values:\")\n",
    "print(\"Sex mapping:\", dict(zip(le_sex.classes_, le_sex.transform(le_sex.classes_))))\n",
    "print(\"Saving accounts mapping:\", dict(zip(le_saving.classes_, le_saving.transform(le_saving.classes_))))\n",
    "print(\"Risk mapping:\", dict(zip(le_risk.classes_, le_risk.transform(le_risk.classes_))))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Feature matrix X shape: (1000, 4)\n",
      "Target vector y shape: (1000,)\n",
      "\n",
      "Feature matrix X (first 5 rows):\n",
      "[[  67    1    4 1169]\n",
      " [  22    0    0 5951]\n",
      " [  49    1    0 2096]\n",
      " [  45    1    0 7882]\n",
      " [  53    1    0 4870]]\n",
      "\n",
      "Target vector y (first 10 values):\n",
      "[1 0 1 1 0 1 1 1 1 0]\n",
      "\n",
      "Training set: X_train shape (500, 4), y_train shape (500,)\n",
      "Testing set: X_test shape (500, 4), y_test shape (500,)\n",
      "\n",
      "Scaled training features (first 5 rows):\n",
      "[[ 0.83938936  0.66089455 -0.70297094 -0.61395242]\n",
      " [ 1.48493161  0.66089455 -0.70297094 -0.75061503]\n",
      " [-0.91279674  0.66089455 -0.70297094 -0.40913415]\n",
      " [-0.08281385  0.66089455 -0.70297094 -0.50609786]\n",
      " [-0.63613578 -1.51310069 -0.70297094 -0.24401479]]\n"
     ]
    }
   ],
   "source": [
    "# Create feature matrix X and target vector y\n",
    "feature_columns = ['Age', 'Sex_encoded', 'Saving_accounts_encoded', 'Credit amount']\n",
    "X = df_subset[feature_columns].values\n",
    "y = df_subset['Risk_encoded'].values\n",
    "\n",
    "print(\"Feature matrix X shape:\", X.shape)\n",
    "print(\"Target vector y shape:\", y.shape)\n",
    "print(\"\\nFeature matrix X (first 5 rows):\")\n",
    "print(X[:5])\n",
    "print(\"\\nTarget vector y (first 10 values):\")\n",
    "print(y[:10])\n",
    "\n",
    "# Split the data into training and testing sets\n",
    "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.5, random_state=0, stratify=y)\n",
    "\n",
    "print(f\"\\nTraining set: X_train shape {X_train.shape}, y_train shape {y_train.shape}\")\n",
    "print(f\"Testing set: X_test shape {X_test.shape}, y_test shape {y_test.shape}\")\n",
    "\n",
    "# Scale the features\n",
    "scaler = StandardScaler()\n",
    "X_train_scaled = scaler.fit_transform(X_train)\n",
    "X_test_scaled = scaler.transform(X_test)\n",
    "\n",
    "print(\"\\nScaled training features (first 5 rows):\")\n",
    "print(X_train_scaled[:5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training MLP Classifier...\n",
      "==================================================\n",
      "Training completed!\n",
      "Number of iterations: 900\n",
      "Number of layers: 4\n",
      "Number of outputs: 1\n",
      "Loss: 0.3998\n"
     ]
    }
   ],
   "source": [
    "# Train MLP model\n",
    "print(\"Training MLP Classifier...\")\n",
    "print(\"=\"*50)\n",
    "\n",
    "# Create and train MLP classifier\n",
    "mlp = MLPClassifier(\n",
    "    hidden_layer_sizes=(100, 50),  # Two hidden layers with 100 and 50 neurons\n",
    "    activation='relu',              # ReLU activation function\n",
    "    solver='adam',                  # Adam optimizer\n",
    "    alpha=0.001,                    # L2 regularization\n",
    "    learning_rate='adaptive',       # Adaptive learning rate\n",
    "    max_iter=1000,                  # Maximum iterations\n",
    "    random_state=42\n",
    ")\n",
    "\n",
    "# Train the model\n",
    "mlp.fit(X_train_scaled, y_train)\n",
    "\n",
    "print(\"Training completed!\")\n",
    "print(f\"Number of iterations: {mlp.n_iter_}\")\n",
    "print(f\"Number of layers: {mlp.n_layers_}\")\n",
    "print(f\"Number of outputs: {mlp.n_outputs_}\")\n",
    "print(f\"Loss: {mlp.loss_:.4f}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model Evaluation\n",
      "==================================================\n",
      "Training Accuracy: 0.7960\n",
      "Testing Accuracy: 0.6780\n",
      "\n",
      "Classification Report (Test Set):\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "         bad       0.43      0.24      0.31       150\n",
      "        good       0.73      0.87      0.79       350\n",
      "\n",
      "    accuracy                           0.68       500\n",
      "   macro avg       0.58      0.55      0.55       500\n",
      "weighted avg       0.64      0.68      0.65       500\n",
      "\n",
      "\n",
      "Confusion Matrix (Test Set):\n",
      "[[ 36 114]\n",
      " [ 47 303]]\n"
     ]
    }
   ],
   "source": [
    "# Evaluate the model\n",
    "print(\"Model Evaluation\")\n",
    "print(\"=\"*50)\n",
    "\n",
    "# Make predictions\n",
    "y_train_pred = mlp.predict(X_train_scaled)\n",
    "y_test_pred = mlp.predict(X_test_scaled)\n",
    "\n",
    "# Calculate accuracies\n",
    "train_accuracy = accuracy_score(y_train, y_train_pred)\n",
    "test_accuracy = accuracy_score(y_test, y_test_pred)\n",
    "\n",
    "print(f\"Training Accuracy: {train_accuracy:.4f}\")\n",
    "print(f\"Testing Accuracy: {test_accuracy:.4f}\")\n",
    "\n",
    "# Detailed classification report\n",
    "print(\"\\nClassification Report (Test Set):\")\n",
    "print(classification_report(y_test, y_test_pred, \n",
    "                          target_names=le_risk.classes_))\n",
    "\n",
    "# Confusion matrix\n",
    "print(\"\\nConfusion Matrix (Test Set):\")\n",
    "cm = confusion_matrix(y_test, y_test_pred)\n",
    "print(cm)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "COMPARATIVE PREDICTION ANALYSIS\n",
      "============================================================\n",
      "\n",
      "MIDDLE-AGED WOMAN\n",
      "----------------------------------------\n",
      "Age: 34\n",
      "Sex: 1\n",
      "Saving accounts: 1\n",
      "Credit amount: 1,569\n",
      "\n",
      "Model Prediction:\n",
      "Risk Assessment: HIGH RISK\n",
      "Confidence: 0.561\n",
      "Probability of HIGH RISK: 0.561\n",
      "Probability of LOW RISK: 0.439\n",
      "\n",
      "MIDDLE-AGED MAN\n",
      "----------------------------------------\n",
      "Age: 34\n",
      "Sex: 0\n",
      "Saving accounts: 1\n",
      "Credit amount: 1,569\n",
      "\n",
      "Model Prediction:\n",
      "Risk Assessment: LOW RISK\n",
      "Confidence: 0.622\n",
      "Probability of HIGH RISK: 0.378\n",
      "Probability of LOW RISK: 0.622\n"
     ]
    }
   ],
   "source": [
    "# Comparative Prediction: Middle-aged with Little Savings and High Credit\n",
    "print(\"COMPARATIVE PREDICTION ANALYSIS\")\n",
    "print(\"=\"*60)\n",
    "# Define both cases\n",
    "\n",
    "case_woman = {\n",
    "    'Age': 34,\n",
    "    'Sex': 1,\n",
    "    'Saving accounts': 1,\n",
    "    'Credit amount': 1569\n",
    "}\n",
    "\n",
    "case_man = {\n",
    "    'Age': 34,\n",
    "    'Sex': 0,\n",
    "    'Saving accounts': 1,\n",
    "    'Credit amount': 1569\n",
    "}\n",
    "\n",
    "def predict_case(case_data, case_name):\n",
    "    print(f\"\\n{case_name.upper()}\")\n",
    "    print(\"-\" * 40)\n",
    "    print(f\"Age: {case_data['Age']}\")\n",
    "    print(f\"Sex: {case_data['Sex']}\")\n",
    "    print(f\"Saving accounts: {case_data['Saving accounts']}\")\n",
    "    print(f\"Credit amount: {case_data['Credit amount']:,}\")\n",
    "    \n",
    "    # Encode categorical variables\n",
    "    features = np.array([[case_data['Age'], case_data['Sex'], case_data['Saving accounts'], case_data['Credit amount']]])\n",
    "    features_scaled = scaler.transform(features)\n",
    "    \n",
    "    # Make prediction\n",
    "    prediction = mlp.predict(features_scaled)[0]\n",
    "    prediction_proba = mlp.predict_proba(features_scaled)[0]\n",
    "    \n",
    "    print(f\"\\nModel Prediction:\")\n",
    "    print(f\"Risk Assessment: {'HIGH RISK' if prediction == 1 else 'LOW RISK'}\")\n",
    "    print(f\"Confidence: {max(prediction_proba):.3f}\")\n",
    "    print(f\"Probability of HIGH RISK: {prediction_proba[1]:.3f}\")\n",
    "    print(f\"Probability of LOW RISK: {prediction_proba[0]:.3f}\")\n",
    "    \n",
    "    return prediction, prediction_proba\n",
    "\n",
    "# Predict both cases\n",
    "woman_pred, woman_proba = predict_case(case_woman, \"Middle-aged Woman\")\n",
    "man_pred, man_proba = predict_case(case_man, \"Middle-aged Man\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "features_male = np.array([[case_man['Age'], case_man['Sex'], case_man['Saving accounts'], case_man['Credit amount']]])\n",
    "features_male = scaler.transform(features_male)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "features_woman = np.array([[case_woman['Age'], case_woman['Sex'], case_woman['Saving accounts'], case_woman['Credit amount']]])\n",
    "features_woman = scaler.transform(features_woman)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.True_"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.any(np.all(X_test_scaled == features_woman, axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import shap\n",
    "from shapley_values.causal_shap_paper import CausalExplainer, EffectType\n",
    "from shapley_values.utils import get_baseline\n",
    "import numpy as np\n",
    "\n",
    "np.random.seed(0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "feature_names = ['Age', 'Sex', 'Saving accounts', 'Credit amount']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "class ModelWrapper:\n",
    "    def predict(self, X):\n",
    "        return mlp.predict_proba(X)[:, 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.616\n"
     ]
    }
   ],
   "source": [
    "explainer = CausalExplainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(features_woman[0], effect_type= EffectType.TOTAL, causal_model=[[1], [0, 2, 3]], confounding=[False, True], is_asymmetric=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Causal Total Shapley value: 0.04010515860658051\n"
     ]
    }
   ],
   "source": [
    "print(f\"Causal Total Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TPr5+ObNm6VDhw5y9OhRueWWW6R27drmD+jSpUtl27Ztfvv++eefZl/9w/rUU0+ZbW+88Yb5Yzxnzhxp1KiR303SBRdcILt375b77rvPrLL8+eefyzXXXCMffvih3HzzzRJtbag3ebfddptpF92vQoUKsmHDBnNz8s0338gPP/xgbiQDaVxXXXWV37ZixYpJtL4OLZ9++mmabS1atEizrU+fPjJx4kQZMGCAtG7dWv744w954oknZN26dfLRRx9JtLWhJizB2k4NGjRITpw4IV26dInI12FW21Gfn94kB9I2HDlypFxxxRV+29evXy9t2rSRuLg4eeihh8yq0/oBhLbf1KlTzQc5llOnTknnzp1NHJqg1KtXz+xz1113ya5du8zNVLS1oX5wcMMNN0jTpk1NgqIfIOzYsUPeeecd81795JNP5Prrr09zLv2bo79LfQVLHKPldWjRG/lSpUr5bWvevHm2xubWNvw0xO9EfV/q+zxYm2fr61CnEgbcYNmyZV6Px+O96qqr/La/9tpr+jGc97PPPsvwHBdccIG3UqVK3u3bt2e47/nnn+8tXLiwd+vWranb9N+6rXPnzn77PvjggyaG7777LnVbYmKiOUeJEiW8R44c8UZbG+7du9e7aNGiNNuXL1/uzZMnj7d58+Z+2zdu3GhiGDp0qNfJcvt1eNNNN5nzhmPKlClm3/vuu89vu/6s22fPnu2NxjYMZs6cOeZaV199dUS+DrOrHYO57bbbzPGTJ0/22967d29vTEyM3/taf7dVqVLFW7t2bW9ycnLq9jfffNOcQ2PxpbHGx8d7N23a5I22Njx9+rR35syZafbduXOnt2TJkt4yZcp4k5KS/B7Tc+jvACfL7dehvjd1u75X7Yot0tswmC1btpj393nnnZfmsex+HZKcwDUee+wx8wb59ddf/bafOHHCW6BAAe+ll16a7vGzZs3y+2N56tQp77Fjx4Luu3btWrPvgAED0jym2/SXyI4dO1K3VaxY0XvOOeek2feTTz4x5xk7dqw32towPeeee643b968IW8KNZ6zOa8b29BKTvTG79ChQ2luXnz169fP7PvPP//4bdefdfudd97pdQInvA71fazn+OGHHyLydZgd7RjM0aNHvUWKFDGJn37A4rtd37MdO3ZMc8xTTz1l4pg7d27qtrZt25oYNBZfGqvu+/zzz3uj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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.616\n"
     ]
    }
   ],
   "source": [
    "explainer = CausalExplainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(features_woman[0], effect_type= EffectType.TOTAL, causal_model=[[1], [0, 2, 3]], confounding=[False, True], is_asymmetric=True, asymmetric_causal_model={\"Age\": [\"Saving accounts\", \"Credit amount\"], \"Sex\": [\"Saving accounts\", \"Credit amount\"]})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Causal Total Asymmetric Shapley value: 0.04010515860658051\n"
     ]
    }
   ],
   "source": [
    "print(f\"Causal Total Asymmetric Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TPr5+ObNm6VDhw5y9OhRueWWW6R27drmD+jSpUtl27Ztfvv++eefZl/9w/rUU0+ZbW+88Yb5Yzxnzhxp1KiR303SBRdcILt375b77rvPrLL8+eefyzXXXCMffvih3HzzzRJtbag3ebfddptpF92vQoUKsmHDBnNz8s0338gPP/xgbiQDaVxXXXWV37ZixYpJtL4OLZ9++mmabS1atEizrU+fPjJx4kQZMGCAtG7dWv744w954oknZN26dfLRRx9JtLWhJizB2k4NGjRITpw4IV26dInI12FW21Gfn94kB9I2HDlypFxxxRV+29evXy9t2rSRuLg4eeihh8yq0/oBhLbf1KlTzQc5llOnTknnzp1NHJqg1KtXz+xz1113ya5du8zNVLS1oX5wcMMNN0jTpk1NgqIfIOzYsUPeeecd81795JNP5Prrr09zLv2bo79LfQVLHKPldWjRG/lSpUr5bWvevHm2xubWNvw0xO9EfV/q+zxYm2fr61CnEgbcYNmyZV6Px+O96qqr/La/9tpr+jGc97PPPsvwHBdccIG3UqVK3u3bt2e47/nnn+8tXLiwd+vWranb9N+6rXPnzn77PvjggyaG7777LnVbYmKiOUeJEiW8R44c8UZbG+7du9e7aNGiNNuXL1/uzZMnj7d58+Z+2zdu3GhiGDp0qNfJcvt1eNNNN5nzhmPKlClm3/vuu89vu/6s22fPnu2NxjYMZs6cOeZaV199dUS+DrOrHYO57bbbzPGTJ0/22967d29vTEyM3/taf7dVqVLFW7t2bW9ycnLq9jfffNOcQ2PxpbHGx8d7N23a5I22Njx9+rR35syZafbduXOnt2TJkt4yZcp4k5KS/B7Tc+jvACfL7dehvjd1u75X7Yot0tswmC1btpj393nnnZfmsex+HZKcwDUee+wx8wb59ddf/bafOHHCW6BAAe+ll16a7vGzZs3y+2N56tQp77Fjx4Luu3btWrPvgAED0jym2/SXyI4dO1K3VaxY0XvOOeek2feTTz4x5xk7dqw32towPeeee643b968IW8KNZ6zOa8b29BKTvTG79ChQ2luXnz169fP7PvPP//4bdefdfudd97pdQInvA71fazn+OGHHyLydZgd7RjM0aNHvUWKFDGJn37A4rtd37MdO3ZMc8xTTz1l4pg7d27qtrZt25oYNBZfGqvu+/zzz3uj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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.613\n"
     ]
    }
   ],
   "source": [
    "explainer = CausalExplainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(features_woman[0], effect_type= EffectType.DIRECT, causal_model=[[1], [0, 2, 3]], confounding=[False, True], is_asymmetric=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Direct Shapley value: 0.03731548941415195\n"
     ]
    }
   ],
   "source": [
    "print(f\"Direct Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.704\n"
     ]
    }
   ],
   "source": [
    "explainer = CausalExplainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(features_woman[0], effect_type= EffectType.INDIRECT, causal_model=[[1], [0, 2, 3]], confounding=[False, True], is_asymmetric=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Causal Indirect Shapley value: 0.002789670247082284\n"
     ]
    }
   ],
   "source": [
    "print(f\"Causal Indirect Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Marginal Shapley values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from shapley_values.causal_shap import Explainer, ShapleyValuesType"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.616\n"
     ]
    }
   ],
   "source": [
    "explainer = Explainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = [])\n",
    "phis = explainer.compute_shapley_values(features_woman[0], type = ShapleyValuesType.CONDITIONAL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Conditional Shapley value: -0.0010570663345666846\n"
     ]
    }
   ],
   "source": [
    "print(f\"Conditional Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Itmn+saF/v63atXKBNh6sz137lx57bXXzO//kiVLzLb82p+XX365uWkOpn05cuRIueSSS1JtX7dunZx99tkSHR0tDzzwgFntXPu4e/fuJkjUN93cIFJ9mpCQINddd520aNHCBDA1a9aUHTt2yLvvvisdOnSQTz/91LwOuMGwCP6cBtq+fbs89NBD5u+TvmZkm5ZKBpxi6dKllsfjsS6//PJU29944w29S7O++OKLM56jU6dOVpUqVazt27efcd82bdpYRYsWtbZu3ZqyTb/Wbd26dbPcIJJ9unfvXmvhwoVpti9btswqUKCA1apVK8sNIv1z6peYmGi1bt3auuSSS6zOnTtbRYoUsdwi0n36wQcfmPN++umnlltFuk/r1atnVaxY0Tp+/Hiq7Y888oi53rfffmvl9/4MZciQIeb4SZMmpdrer18/y+v1pnpNPXLkiFWtWjXT1z6fz3K6SPbpqVOnrOnTp6fZd+fOnVbp0qWtcuXKWUlJSZbTLY3wz2mgyy67zGrZsqU1YMAAs++ePXuydS2CFziK/4/c77//nmq7/jEsXLiwddFFF2V4/IwZM8zx+kuqTp48aR09ejTkvmvWrDH7Dho0KM1juk1/+Xfs2GE5XST7NCNnnXWWFRsba7mBXX36yiuvmPNv3LjRdcFLJPtUb/pq165tfib9Dh8+7IqbQTt/TitUqGA1atQozfa3337bnOenn36y8nN/hhIfH28VK1bMBIj65kTgdn297Nq1a5pjnn76adOOv//+23K6SPZpRvRGX9vB3/zs9+k333xjgm39ubzhhhtyFLww5wWOokMMNJ3Ztm3bVNt1zKamevXxjPzwww/ms45j1dSmzrnQYQo61EHHugZfS2m6OFj79u3NkJz58+eL00WyTzMaf6vp+fLly4sb2NGnOnznscceMyseV69eXdwmkn2q8wj8Q3J0fkvp0qXNnJcSJUrIrbfemrPhDvn451SHMy1fvjxlmMqWLVvMcDHtY11pvmvXrpKf+zOUsWPHyuHDh2XgwIESFRWVaoiODnNK7++Tvz1OF8k+zcjWrVulQIEC5jXA6eba0Kf62NChQ+WWW25Jc93sIHiBo+h4yTJlykhsbGyax3Reik7+OnnyZLrH602JGjx4sJlkquPZP/roI/OipGNdR48enepa/vOGupbKaO6BU0SyT9OjY4o1eLnhhhvEDezo09tuu80UP7jnnnvEjSLZp/59x4wZIy+//LI8/PDDMm7cODPW+7333jM36m6YTxTpn9PXX39d+vXrZz43atTIBD06n+iiiy6Sn3/+OdM3km7tz1A+/PBDM7FZ518FX8t/3lDXUvx9ylqfZhSkz5kzR6688kpzg+90223oU53jpm9SPv/88xIOTNiHoxw7dizkL5zyv6joPvrHM5QjR46Yz1o57LfffkvZT6u16I3f8OHDzQ20viuh51Ghrhd4LaeLZJ+GooUP9Ia7efPmZl83iHSffvXVV6bYwR9//GEm77pRJPvUv++ePXvMTbV/4rPeaGvQojfp2t960+1kkf451SpEGrDoJGENALWa09SpU03Ao4GLTjbPz/0ZKjjU32mtzqaTx4Ovpfj7FL4+DWXNmjUmENeben0jww2ORbhPZ82aZd70+eKLL0xRiXAg8wJH0T92mioPRcvw+vdJjw5rUFqaN/AXU8tMajnEnTt3pryb6D9PqOtl5lpOEck+DabD7nr16mWqjk2ePNkV72pFuk/1He+7777bVHrSYU5uFck+9e+rNyzBFZv82cHp06eL00WyT/VdVy0zr29WfP3113L99dfLFVdcYQKW+++/Xz744ANT5Sg/92eod7PVzTffHPJair9P4evTYFpZUG/INaOg1du0BLgbFI5gn2oGRysM6uuovk6EC8ELHEVvcjWlGeoXT1PkmgrN6N2CKlWqmM+6xkCwihUrms8HDhxIuZb/vKGulV7K3mki2aeBFixYIN26dTPvxOi7tm7oSzv69KmnnjK1+XXoztq1a1M+jh8/brIE+rXOLXC6SPZpdn+mnSaSfarvzOq6L5q90pvBQDqUTM2YMUPyc38GSkxMNKV5db6VZqpCXct/3lDXUm54TY1knwbSsv5atl/nt2n21S3LIkS6T99++21ZuXKlGV0R+PfJn7XVAFGXS8gqghc4Sps2bcw7eDr+NPjdAl3fonXr1hke758oppPvgvm3lStXLuVa6s8//0yzr67/on+Adb0Cp4tknwYGLv6FPzVwcdsE80j2qU7U1+ClXbt2Urdu3ZQPvbam/vVrpw9vinSf6o2KZgFD3Rim9zPtRJHsU39fJiUlhbwBCvycX/sz0MSJE83CnbquSKghPvozqtvT+/uksnK9vCqSfRoYuOjaRbpekQYuLVu2FDdpE8E+1b9P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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.616\n"
     ]
    }
   ],
   "source": [
    "explainer = Explainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = [])\n",
    "phis = explainer.compute_shapley_values(features_woman[0], type = ShapleyValuesType.MARGINAL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Marginal Shapley value: 0.03731548842164562\n"
     ]
    }
   ],
   "source": [
    "print(f\"Marginal Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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bU8++aRUqFDB7F+lShX5+OOPzT6atGkb5M+f3yRPffv2lYSEBL/rfvfdd9KsWTPTVvpca9SoIcOGDfPbz2pbX56xWPTfuu2bb76R+++/35QPaXzly5eXF154wa/trETTaitrGwAAyEbli4vsOOC/3dqmCUhax3ru63t8ycLePS+arFzYROT+UeIIsTEiEyntiuqek0mTJpnvDzzwQIaO056WHj16SJcuXeTSSy9NXWju119/NT/rTfgVV1whlSpVkiVLlpgb6AULFph/W2UuU6dOlcsvv9zc2GsJmSYzmqxce+216V5fE4KHHnrIlKK1b99eevXqZbYXKZL2TBbr1683pU0ad+/evc3N/KxZs2T06NGyfPlyE6Ovjz76SI4ePWqej65Z8cknn5jSNy15e/DBB03ypr1P06ZNM0mEJhjaC+V5vCZVmnxpEqRJkT5PTXg0nlGjsvaGoufRhKh///6mbfW5PPLIIybp0/8X+v9A20nbS8vjbrjhhixdDxmjiTAAIELFxabMvOVJB6XnjU9JFDztP5rSW5I/j0hCov+5Tv43flcfD8Z6LCHArFUnT5/Z51RiShwjbxB592eRlVvFEXRczrg5Is9cZXcksCs52bRpk0kOmjRpkqHjdLzH0KFDzY2xp5tuukmKFy8uS5cu9Srzevfdd03PzCuvvCKPPvqo2XbfffeJ2+02PTAtW7Y024YMGSKNGzdO9/rVq1c3N/p606033JokhEJ7JTSx8h0HcOONN5rekB9//FG6devm9dj+/ftl9erVqb0ymoh06tRJbr31VnnrrbdSe5w09rPOOku+/PLL1OTk9OnT8r///c9cb968eVKzZko3pbZd8+bN5dNPP5W77rrL/DuzdLKClStXmv+P1v8DbZNXX33VJCea9Gn7aHJSuXLlkNsK2WPnzp2mpwwAEIF0YPvMZwJv79/Re1u1W0Q27xE5cUokb4Dbunz/JR76eDDWY5r8+B0f772PjjMpVVhk8NfiKKu2iWzdK1KplN2RRD1byrpOnDiRqRWsCxYsaD6d96QlTps3bzY9KnrerVu3pn5dfPHF5gb9l19+MfvqfnrD365du9TEROkN9u233y45Rc9vJSZ6U683jlZ86rfffvM7pmfPnl7lYuecc445j970+5bCaY+OlqUdOJDSHau9KVpKpkmClZhYcVjJmfZ0ZIX2hFiJ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b5frrrvOnC9//vzSsmVLGTt2rERrG548eVI++OAD6dmzp1SrVs20SY0aNaR///6ycuVKv3Nu2rRJXC5XwK+GDRtKNL8WBwwYELRtxo0b53fehIQEeeqpp6R69epmdpazzjpLhg0bJqdPn5ZobMO0XlvW1xdffBGRr8WstOHTTz+dZpvEx8f7HbN69Wrp1auXFC9eXAoWLCgdO3Y0q8oHogu+3XXXXVKxYkUTW4MGDeSdd96RcJunJ7faUJ/36NGj5corrzSv1wIFCkiVKlXk0ksvNX9rAgl23nBbKT03X4dp7f/SSy9la2xObUNXOu+Hzz77bI6+DuMydRQQpu677z55/fXXpXfv3uaXVm9y9edFixbJr7/+KjExaefjmzdvls6dO8vRo0flxhtvlNq1a5s/oEuXLpVt27Z57fvXX3+ZffUP69ChQ822N9980/wxnj17tjRq1MjrBqlDhw6ye/duuf/++80Ky19++aVcccUV8vHHH8sNN9wg0daGeoN38803m3bR/SpUqCAbNmwwNyfffvut/Pjjj+Ym0pfGddlll3ltK1asmETza9Hy+eef+21r1aqV37Z+/frJxIkTZeDAgdK2bVuZM2eOPPnkk7Ju3Tr55JNPJNraUBOWQG2n7rzzTjlx4oR07do1Il+LWWlDfW56k+xL22/EiBHSo0cPr+3r16+Xdu3aSVxcnDz88MNmxWn9AELbburUqeaDHMupU6fkggsuMHFoglKvXj2zz+233y67du0yN1PR1ob6ocG1114rTZs2NQmKfniwY8cOeffdd83v6WeffSbXXHON37n0b46+l3oKlDhGy+vQojfypUqV8trWokWLbI3NqW34eZD3Q/291N/zQG2era9DnUoYcIJly5a5XS6X+7LLLvPa/vrrr+vHcO4vvvgi3XN06NDBXalSJff27dvT3ffss892Fy5c2L1169bUbfpv3XbBBRd47fvQQw+ZGL7//vvUbYmJieYcJUqUcB85csQdbW24d+9e96JFi/y2L1++3J0nTx53ixYtvLZv3LjRxDB48GB3uMvt1+L1119vzhuKKVOmmH3vv/9+r+36s27/888/3dHYhoHMnj3bXOvyyy+PyNdidrRhIDfffLM5fvLkyV7b+/bt646JifH6vdb3tipVqrhr167tTk5OTt3+1ltvmXNoLJ401vj4ePemTZvc0daG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Fixo5un3pHN96/7btm1L3ab/1m2+dZwPPvhg0HVOtAb28OHD7mhsw4ULF5p6aq2l1br09GqGfemYgX79+oXVdMy53Y46HWSg8TnatrpeTL169by263z2aa1zkpGaYie9Fi1jx44N2D6R+FrMaht66t69uzlGzxmMrgej43QWL17st85JrVq1vNY5efPNN4OucxIXFxfSGhVObENd36VatWpm7Ne8efPSjC3Q69Dz7024TMecm22o0wYfPHjQb7uOc9K/NbpezPHjxzMVWzS9Di1///232df3ujn9OiQ5gaPceeed5pehd+/e7g8++MDcYOgfuk6dOnkNfq1atWrARevee+89s71Bgwbul19+2f3cc8+ZP6y6KNhPP/3kN3hbb/50oJoOftcv/bfe+Hj+cbZ+efWahQoVcj/11FPmOp07dzbX+vDDD93R2Ib6R1j/UOgb7tNPP23eXH2/9MbbovFo0qcTC7z//vvu4cOHm4UarQkF0hsg7tR21AXvdKDnrbfeavbTOeh1rRKdWCB//vwBk41LLrnEnPvGG280rz/9rj9fc8017mj9fbZ069bNHLNixYqgcUXSazGrbWh96BIbG+tu1apVmtfS9Z+KFy9uFgvUttaFFps2bWqO9V0rRicp0DbTWDQmjU1j1BieeOIJdzjJrTbUD6mqV69uznHXXXcFfE/UBRkt9957r5m44dFHH3W/88477hEjRrjPPfdcc3zr1q29bsKjpQ11ULh+4DdgwABzU6y/nw888IBJ9vTYb775JtOxRdPvskX/rui5fvjhB3cwOfE6JDmBo2hvxEsvvWQ+FdXEoUKFCu777rvPb1GgtH55x48fb36hdKYjTSZ0tfc//vgj6ArSuuiYJiS674UXXuhesGBBwH119Xi9+dMbcr1xbNasmfvrr792R2sbzpgxwxyf1pfnp6d6E61vwmXLljU3l3pevYbeAIXTH5DcbkddlE1fV3Xq1DE9BfrHSnuirrvuuqCfnmlPiy7qpdfW2PSGSGeg04UKo/n3WT9d1U/+27Vrl2ZckfRazI42tGbd0Ru99GhSd+mll5qbQU2OdbHFX375JeiN5B133OEuX758ai/fG2+84dXDEk1taC3umdaXvm9aJkyYYP7maDz6N0Vf4zrLmV4r1NkOndaGJ0+eNB+2NGzY0CQp+n6oH9706dPHaxHQzMQWbb/Lx48fN7/H+vckrfe1nHgduvQ/GS8GAwAAAIDsxYB4AAAAAGGB5AQAAABAWCA5AQAAABAWSE4AAAAAhAWSEwAAAABhgeQEAAAAQFggOQEAAAAQFkhOAAAAAISFOLsDAAAAOW/AgAHy6aefmn83aNBAli1b5vV4cnKyDB8+XEaNGiX//vuvVKlSRdavXy8vvviifPzxx7JixQqJicn4Z5rvvvuuOe/atWslb968Xo+9+uqrct9996X+vGfPHilVqpTklqSkJJk/f76JLSEhQUqUKCFnn322VKpUKeRz7N2715xj165dkpiYKEWKFJF69epJw4YNvZ7X33//bfZRZcqUkdatWwd8rhnZF3Aiek4AAIhwP/30k7hcrqBfn332mdlPb3A///xzef755/3O8fbbb8tTTz0ll112mUlG3nvvPTl8+LC88MIL8r///c8vMRkyZIjZtnLlSr9zDRw4UGJjY2XKlCkmKTp16pQ5n69u3bqZeHr37i12mDlzpixdulRq1qwp7dq1M89n6tSpsnPnzpCO37p1q0yYMEFOnjwpzZo1M+fQpO7o0aNeycv3338vR44ckRYtWkjz5s1Nu06aNEkOHjzodb6M7As4FT0nAABEuCVLlpjvr7/+uhQvXtzv8a5du8r06dOlYMGCcs011wQ8h/aYXHDBBTJixAivng3tDejfv7/f/rfddptJcnQfz8TjjTfeMOcaNmyYdO/e3Wy7/vrr5ZVXXpG77rrLJEuWunXrmq9169bJd999J7lp9+7dpmdIeyWaNGlittWqVUvGjRsnc+fOlZ49e6Z5vCZcM2bMMMmItpvn8/KkvSBxcXHmfPny5Uu9zpgxY2TevHly4YUXZmpfwKlITgAAiHD66X/RokXlzjvvDHqTnBb95F8THO0N8aRJxqWXXpp6o+xJy42uvvpq0/Px7LPPml6Z3377Te6//37p06ePPP7446n7XnHFFaY8TG/mu3TpIuFgw4YNpq20BMuiiUGdOnVMkqC9H4UKFQp6vCZUJ06cMGVgep7Tp0+b433bX3thKleu7NWGBQoUkPLly5vyOT0uPj4+w/sCTkVZFwAAEU4TCy0rykxicuONN0r+/PnN+IsnnnjCnKNt27ayceNGk/Scf/75QY/V8SJ6g67jSrZs2WKSEO0J+eSTT7z20xIlHc8xceJEyQ46PkYTqlC+3G53wHPs27fPJHR58uTxS7qsx9Oybds2kygcO3bM9GxoIqdfs2bNMr1NFm1XLXHzpYmMPo/9+/dnal/Aqeg5AQAggml50erVq6VDhw5mzIIvvQFP69N27f3Qx7U067XXXjNJRNWqVWX27NnmcR33EIwOrNdSo7feesuMvdBP9vV7oB4HPc+ff/4p2UF7GCZPnhzSvlqSVrhwYb/tx48fN70SvqxtmnSk5dChQybx+fnnn01vS6tWrWT79u2yfPly8//kvPPOM/sVK1bMlJBpcmGN29EkRLf5Xicj+wJORXICAEAE01m0NCnQ3gv98qWJS+3atYMer2VW06ZNM+NRtCzMuil+8sknzffq1auneX0t49KB7XoD/cMPP8hZZ50VcL8aNWqYErDsULJkSbn44otD2ld7hQLR3o1AvRTWNk0K0qJtrufQsrD27duntpUmFjpJQMuWLU1iWL9+ffnjjz/k999/N2NbNKFZuHChSY58r5ORfQGnIjkBACCCaemV0lKqihUr+j2uA6pDOYf2gnjOyKVlTVpOlNa4C2XN1qXJhw68D0YH6msJWLAei4zQKYkzMt1vIPrcAt3sW9sCJS6+xyud6cuT/qxtolMBW8mJjl/RNl6zZo3Zp3Tp0ib5WLRokVevVkb2BZyK5AQAgAgfb6I3ylq+5Dt+IiPnSCuxCObXX3+VBx980CRAulaIljgFm1HKGvuRmXExgRIIXZckFDq4PND6LJogBSqTsnoptCcpLXr8gQMH/HpmrJ8949OSL00wdH/9f6Slczr7ltIExlNG9gWciOQEAIAIpp+yazlRZhMTXT9DB7M3atTIr3RKy5Z0zY1AYzZ0tqt+/fqZgfiapGjp2MiRI4MmJ3qzrTf0wcqsMkJ7JbI65kSfn44R0fEhnm1nje/Qx9OiPRo6KF4THB0rYrESHt/nqb095cqVS/1Zj9UEyPPYzOwLOA3JCQAAEZ6ctGnTJkvHq8aNG3tt11m3lM7a5fuYlh7pWhxaZqTrk+gn+rfffruZilhLmjyn57XoeQJtt2vMiZah6XPXeK11TrRHRsfo6IxdVjmbJmj6fLUHxnOKXz1+8eLFZn/PcrpVq1aZ3iGd/jcYXV9FV4LX/2/p9SRlZF/ACUhOAACIUDprlX7SbyUSWVnA0TcB0emE1fz5870e0/Ksa6+91tyU67ol1tgPTU4CLcpo0YHdOjNYdsiOMSeagGiCoSVTOhZGEywd56E9RZ06dUrdT9tXe2l0tjEd5G7RdV10li5tBx0Er8nIjh07TI9S06ZNU8vCdJs+d01gNLnR8+kxup5Jw4YNvWLKyL6AU5GcAAAQoazEQj9ZHz16tN/j2iPgW67lS3sP9GZYxzZ40ht3vSHWkq2BAwembn/66afNdMGagFizVFllTrr6vM7INXz4cK+yqAULFpg1OtJbdT23de7c2fSQ6HgZLe/SNtCZx9Lq9fDUsWNHc7wmEJs2bTL/1qTOs801SdEeD21nneFLS8x04Ubdx3csTEb2BZyK5AQAgAhllWRZCwD6+uyzz0JKTnx7TSyalDz11FOmZ0HLo7SE65lnnpFbb71Vbr755oCLMn700UdmSmPPFeLHjh0rVapUCZvV4S06kYCWS6VVFlehQoWAz1VpwqALTOpXMEWKFAm5BC0j+wJO5XIHWzoVAAA4xoABA2T69OmmbEhvykMZXK0LDWoPyosvvmhWks8MnbWqWrVq8sgjj8g999zj9Ziu4K7jOfT8I0aMMD1AWi4FIHrRRwgAQJTQWbm0/EpXkw+FjsN4+OGHTeKg4yoyQ3t0dOC89rb40h4WjUfPDwCKnhMAAKJkJXmdOlfp2IiszPCVncmSjtew6EB0FhoEohvJCQAAAICwQFkXAAAAgLBAcgIAAAAgLJCcAAAAAAgLJCcAAAAAwgLJCQAAAICwQHICAAAAICyQnAAAAAAICyQnAAAAAMICyQkAAAAACQf/BybG5aMa9k8XAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7012899287503107\n",
      "Predicted Value (f(x))  [0.61590864]\n",
      "Shapley Values + (E[f(X)]):  0.616\n"
     ]
    }
   ],
   "source": [
    "explainer = Explainer(X = X_test_scaled, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(features_woman[0], type = ShapleyValuesType.CONDITIONAL, is_asymmetric=True, causal_model={\"Age\": [\"Saving accounts\", \"Credit amount\"], \"Sex\": [\"Saving accounts\", \"Credit amount\"]})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Conditional Asymmetrix Shapley value: 0.0191574373195032\n"
     ]
    }
   ],
   "source": [
    "print(f\"Conditional Asymmetrix Shapley value: {phis[1]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2V/+/PnlzDPPlLFjx0osnK9jx47JBx98IN27d5dq1aqZ51+jRg25+uqrZenSpQH7XLdunbhcrqBfDRs2FKe/tvr27Rvy+Y8bNy5gv0lJSfLkk09K9erVzQgpZ5xxhgwZMkROnDghTj5X6b1OrK/PP/88ql9Xp3u+nn766XSff548eQK2Wb58ufTo0UOKFy8uBQsWlA4dOphZzIPRCc3uuusuqVixomlbgwYN5J133hG7xqOJ1LnS5zdq1Ci56qqrzGuwQIECUqVKFbn00kvN534wofZr5yzUkXxtpbf+iy++mKNty+3nypXB59azzz6bqfVzwwznCXY3AAiX++67T15//XW57LLLzIeFXtDqz//++6/8/PPPEheXfsy9fv166dSpkxw6dEhuvPFGqV27tvmju3DhQtm8ebPPun/99ZdZV/8YDx482Cx78803zR/wWbNmSaNGjXwuoNq3by87duyQ+++/38wW/MUXX8iVV14pH3/8sdxwww3i5POlF3v9+/c350DXq1ChgqxZs8ZcvHz99dfyww8/mAtKf9quyy+/3GdZsWLFxOmvLcvIkSMDlrVs2TJgWe/evWXixInSr18/adOmjfz555/yxBNPyKpVq+STTz4Rp54rDUSCnSN15513ytGjR6Vr165R/bo63fOlz0Mviv3puRo+fLhccsklPstXr14tbdu2lYSEBHnooYfMTMl6Q0DP0/fff29uoliOHz8uXbp0Me3QwKNevXpmndtvv122b99uLrSceq40kO/Tp480bdrUBB4a0G/dulXeffdd8x777LPP5Nprrw3Yl37+62edt2CBnxNfWxa9cC9VqpTPshYtWuRo23L7uRoZ4nNL31P6Hg12bqPttZVpOmQu4DSLFi3yuFwuz+WXX+6z/PXXX9dbcp7PP/88w320b9/eU6lSJc+WLVsyXPess87yFC5c2LNp06a0Zfp/XdalSxefdR988EHThm+//TZtWXJystlHiRIlPAcPHvQ4+Xzt2rXL8++//wYsX7x4sSdv3ryeFi1a+Cxfu3atacNTTz3licXX1vXXX2/2mxlTpkwx695///0+y/VnXf7HH394nHyugpk1a5Y51hVXXBHVr6ucOl/B9O/f32w/efJkn+W9evXyxMXF+bwf9fOnSpUqntq1a3vcbnfa8rfeesvsQ9viTduaJ08ez7p16zxOPVcnTpzwzJgxI2Ddbdu2eUqWLOkpU6aMJyUlxecx3Ye+d2P1taXvK12u7zO72pZbzlUwGzduNO/NM888M+CxaHttZQVBBxzpscceM2/M3377zWf50aNHPQUKFPBccMEF6W7/66+/+vyBPX78uOfw4cNB1125cqVZt1+/fgGP6TL98Nq6dWvasooVK3rOOOOMgHU/++wzs5/Ro0d7nHy+0tO8eXNPYmJiyItDbU929pubz5UVdOgF4P79+wMubrxdc801Zt0NGzb4LNefdfltt93mibXXlb4HdR8//PBDVL+ucuJ8BXPo0CFPkSJFTOCmNze8l+t7rXPnzgHbDB482LTj77//TlvWrl070wZtizdtq677wgsveJx6rtKjF6baDu/PeO8Lw6SkJFtuJNl9vryDDv3c0sAtkm3L7a+twSffg++++27AY9H22soKajrgSP/884/p/vRPP9HcTO0i18fT891335nvmrerXZtad6D5zpraobm9/sdS2s3ur3Xr1iYfeO7cueZn7ZLXlBBdHmxd7/059Xyll0Or56ds2bJBH3/ppZdMLrXuV/NrtW5B0x5i5Vxp6ot+6fqa5hIsl1yPrSl+en686c+axhbp15bdrytNyRozZoxUrVrVnLNofl3lxPkKRmvFDhw4YGqD4uPjfVI99HmG+tyy2mO9N+fNmyfNmjUzbfGmbdV88tz22srKuUrPpk2bJG/evEFT8rTmSl9bWudXpkwZk5amqYF2sOt8NW7c2Hxu6XE0lU9T8iLRttz82vJ4PDJixAjzmaS1jsFE02srKwg64EhaqK15pFpI608vynbt2mVylEPR4kp18803mxqMTz/91NRb6B8Xze3VDwTvY1n7DXYsZeWeZ2Vdp56vUDQ/WoOO66+/3me5fvh37txZhg4dKhMmTJAPP/xQ6tevL88884xcfPHFkpKSIk4+V+XKlTP5xVrz8s0338jAgQNlzpw5JqdXc4v92xbstWW1LdKvLbtfV6NHjzaBh9ZJ+edgR9vrKifOVzAfffSRCQq0xsf/WNZ+gx1LWa+XvXv3mpqYYOtqW7XNue21lZVzlV5QPHv2bFNHFSwY05x8vTjU162+1qw6P31NRlqkz5cGYVpz8MYbb5gas+eee87UZ1100UUBtWXhaFtufm1Nnz5d1q5dK7169TKD0viLttdWltjd1QKEQ40aNTyVK1cO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pTdPevbs6TPhZHba5tT34ZEjR8x7UD/f0/v8idbXVma59B+7U7wAAAAAOBeF5AAAAADCiqADAAAAQFgRdAAAAAAIK4IOAAAAAGFF0AEAAAAgrAg6AAAAAIQVQQcAAACAsCLoAAAAABBWCeHdPQAAyI6+ffvKp59+av7foEEDWbRokc/jbrdbhg4dKiNGjJANGzZIlSpVZPXq1TJs2DD5+OOPZcmSJRIXl/V7i++++67Z78qVKyUxMdHnsVdffVXuu+++tJ937twppUqVkkhJSUmROXPmmLYlJSVJiRIl5KyzzpJKlSpleh+7du0y+9i+fbskJydLkSJFpF69etKwYUOf5/XPP/+YdVSZMmWkVatWQZ9rVtYFYhk9HQAARNiPP/4oLpcr5Ndnn31m1tML15EjR8rzzz8fsI+3335bnnzySbn88stNkPHee+/JgQMH5IUXXpCHH344IOAYNGiQWbZ06dKAffXr10/i4+NlypQpJtg5fvy42Z+/bt26mfZcdtllYocZM2bIwoULpWbNmtK2bVvzfL7//nvZtm1bprbftGmTTJgwQY4dOybNmjUz+9Bg7dChQz5BybfffisHDx6UFi1aSPPmzc15nTRpkuzbt89nf1lZF4h19HQAABBhCxYsMN9ff/11KV68eMDjXbt2lenTp0vBggXl2muvDboP7eHo0qWLDB8+3KcnQu/eX3311QHr33bbbSZ40XW8A4o33njD7GvIkCFy0UUXmWXXX3+9vPzyy3LXXXeZIMhSt25d87Vq1Sr55ptvJJJ27NhhenK0F6FJkyZmWa1atWTcuHHy999/S/fu3dPdXgOpX375xQQZet68n5c37bVISEgw+8uXL1/acUaPHi2zZ8+W888/P1vrArGOoAMAgAjTu/VFixaVO++8M+TFb3r0Tr0GLtp74U2Dh0svvTTtAtibpv1cc801pqfi2WefNb0ov/76q9x///3Ss2dPeeyxx9LWvfLKK02all6kd+7cWaLBmjVrzLnSVCiLXvDXqVPHXPxrb0WhQoVCbq+B0tGjR006lu7nxIkTZnv/86+9JpUrV/Y5hwUKFJDy5cubNDbdLk+ePFleF4h1pFcBABBhGjBoek92Ao4bb7xR8ufPb+obHn/8cbOPNm3ayNq1a00wc95554XcVusx9MJb6zY2btxoggvtufjkk0981tNUIa2XmDhx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",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array(phis),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test_scaled, ModelWrapper()),\n",
    "                                output_names=['Prediction'])\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Pishap and Pathwise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.neural_network import MLPRegressor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "treatment_set_female = scaler.transform([[0, 1, 0, 0]])[0][1]\n",
    "treatment_not_set_male = scaler.transform([[0, 0, 0, 0]])[0][1]\n",
    "\n",
    "sample = features_woman[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "treatment_col_index = gender_col_index = 1\n",
    "savings_col_index = 2\n",
    "amount_col_index = 3\n",
    "age_col_index = 0\n",
    "\n",
    "\n",
    "y_hat_model = ModelWrapper().predict(X_test_scaled)\n",
    "T_test1 = X_test_scaled[:, treatment_col_index]\n",
    "\n",
    "def train_inner_models(X, y, T):\n",
    "    \"\"\"\n",
    "    Train T-learner models using treated and control splits,\n",
    "    excluding treatment column from features.\n",
    "    \"\"\"\n",
    "    # Remove treatment column from features to avoid leakage\n",
    "    X_no_treatment = np.delete(X, treatment_col_index, axis=1)\n",
    "\n",
    "    X_treated = X_no_treatment[T == treatment_set_female]\n",
    "    y_treated = y[T == treatment_set_female]\n",
    "    X_control = X_no_treatment[T == treatment_not_set_male]\n",
    "    y_control = y[T == treatment_not_set_male]\n",
    "    \n",
    "    model_mu1 = MLPRegressor(hidden_layer_sizes=(100,), max_iter=500, random_state=42)\n",
    "    model_mu1.fit(X_treated, y_treated)\n",
    "    model_mu0 = MLPRegressor(hidden_layer_sizes=(100,), max_iter=500, random_state=42)\n",
    "    model_mu0.fit(X_control, y_control)\n",
    "\n",
    "    return model_mu1, model_mu0\n",
    "\n",
    "def predict_cate(model_mu1, model_mu0, X):\n",
    "    # Remove treatment column before prediction\n",
    "    T = X[:, treatment_col_index]\n",
    "    X_1 = X[T == treatment_set_female]\n",
    "    X_0 = X[T == treatment_not_set_male]\n",
    "\n",
    "    X_0=np.delete(X_0, treatment_col_index, axis=1)\n",
    "    X_1=np.delete(X_1, treatment_col_index, axis=1)\n",
    "\n",
    "    mu1 = model_mu1.predict(X_1)\n",
    "    mu0 = model_mu0.predict(X_0)\n",
    "\n",
    "    cate_mean = np.mean(mu1) - np.mean(mu0)\n",
    "    return mu1, mu0, cate_mean\n",
    "\n",
    "# === Train models on full dataset ===\n",
    "def filter_close(X, col_idx, val, tol=0.2):\n",
    "    return np.abs(X[:, col_idx] - val) < tol\n",
    "\n",
    "model_mu1, model_mu0 = train_inner_models(X_test_scaled, y_hat_model, T_test1)\n",
    "\n",
    "# === 1. Full data (all mediators present) ===\n",
    "# E[Y | do (T = 1)] -  E[Y | do (T = 0)]\n",
    "mu1_full, mu0_full, ate = predict_cate(model_mu1, model_mu0, X_test_scaled)\n",
    "\n",
    "# === 2. Remove Mediator 1: filter by mediator2 + confounder only ===\n",
    "# E[Y | do (T = 1), M1 = m1] -  E[Y | do (T = 0), M1 = m1]\n",
    "mask_savings = filter_close(X_test_scaled, savings_col_index, sample[savings_col_index])\n",
    "X_filtered_savings = X_test_scaled[mask_savings]\n",
    "mu1_m2, mu0_m2, cate_savings = predict_cate(model_mu1, model_mu0, X_filtered_savings)\n",
    "\n",
    "\n",
    "# === 3. Remove Mediator 2: filter by mediator1 + confounder only ===\n",
    "mask_amount = filter_close(X_test_scaled, amount_col_index, sample[amount_col_index])\n",
    "X_filtered_amount = X_test_scaled[mask_amount]\n",
    "mu1_m1, mu0_m1, cate_amount = predict_cate(model_mu1, model_mu0, X_filtered_amount)\n",
    "\n",
    "\n",
    "# === 4. Remove Both Mediators: filter by confounder only ===\n",
    "\n",
    "mask_savings_age = filter_close(X_test_scaled, savings_col_index, sample[savings_col_index])& \\\n",
    "            filter_close(X_test_scaled, age_col_index, sample[age_col_index])\n",
    "X_filtered_savings_age = X_test_scaled[mask_savings_age]\n",
    "\n",
    "mu1_m2, mu0_m2, cate_savings_age = predict_cate(model_mu1, model_mu0, X_filtered_savings_age)\n",
    "\n",
    "\n",
    "mask_amount_age= filter_close(X_test_scaled, amount_col_index, sample[amount_col_index])& \\\n",
    "            filter_close(X_test_scaled, age_col_index, sample[age_col_index])\n",
    "X_filtered_amount_age = X_test_scaled[mask_amount_age]\n",
    "mu1_m1, mu0_m1, cate_amount_age = predict_cate(model_mu1, model_mu0, X_filtered_amount_age)\n",
    "\n",
    "\n",
    "mask_savings_amount_age = filter_close(X_test_scaled, amount_col_index, sample[amount_col_index]) & \\\n",
    "            filter_close(X_test_scaled, savings_col_index, sample[savings_col_index]) & \\\n",
    "            filter_close(X_test_scaled, age_col_index, sample[age_col_index])\n",
    "\n",
    "\n",
    "X_filtered_mask_savings_amount_age = X_test_scaled[mask_savings_amount_age]\n",
    "\n",
    "mu1_conf, mu0_conf, cate_savings_amount_age = predict_cate(model_mu1, model_mu0, X_filtered_mask_savings_amount_age)\n",
    "\n",
    "# === Compute Path-wise SHAP values (effects) ===\n",
    "path_wise_shap_t_amount_y = cate_savings_amount_age - cate_savings_age\n",
    "path_wise_shap_t_savings_y = cate_savings_amount_age - cate_amount_age\n",
    "\n",
    "pishap_t_amount_y = ate - cate_amount\n",
    "pishap_t_savings_y = ate - cate_savings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.05395659430271471)"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "path_wise_shap_t_amount_y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.04453838302028246)"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "path_wise_shap_t_savings_y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(-0.0359565133658738)"
      ]
     },
     "execution_count": 107,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pishap_t_amount_y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(-0.05449638472303053)"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pishap_t_savings_y"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ------------"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simulation import path_wise_dataset_1, path_wise_dataset_gt, treatment_col_index, mediator1_col_index, mediator2_col_index, confounder_col_index, calculate_true_cate_but_mediator2, ModelWrapperGT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_test, y_test = path_wise_dataset_gt(num_samples=5000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "[(1, 2, 3, 0)]\n",
      "0.0\n",
      "[(3, 2, 1, 0)]\n",
      "0.20770456901262968\n",
      "[(1, 0, 3, 2)]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[11]\u001b[39m\u001b[32m, line 2\u001b[39m\n\u001b[32m      1\u001b[39m explainer = Explainer(X = X_test, model = ModelWrapperGT(), is_classification=\u001b[38;5;28;01mFalse\u001b[39;00m, rounding_precision = \u001b[32m1\u001b[39m, feature_names = [])\n\u001b[32m----> \u001b[39m\u001b[32m2\u001b[39m phis = \u001b[43mexplainer\u001b[49m\u001b[43m.\u001b[49m\u001b[43mcompute_shapley_values\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[32;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m0.2\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m0.6\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mtype\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m=\u001b[49m\u001b[43m \u001b[49m\u001b[43mShapleyValuesType\u001b[49m\u001b[43m.\u001b[49m\u001b[43mCONDITIONAL\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/Files/Heavy/Work/NYU_NEW/Main/shapley_values/causal_shap.py:118\u001b[39m, in \u001b[36mExplainer.compute_shapley_values\u001b[39m\u001b[34m(self, sample, type, is_asymmetric, causal_model, features_to_compute)\u001b[39m\n\u001b[32m    115\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m feature \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(n_features):\n\u001b[32m    117\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m features_to_compute \u001b[38;5;129;01mor\u001b[39;00m feature \u001b[38;5;129;01min\u001b[39;00m features_to_compute:\n\u001b[32m--> \u001b[39m\u001b[32m118\u001b[39m         local_shap_score = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mapproximate_shapley\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfeature\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msample\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mtype\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m    119\u001b[39m \u001b[43m                                                    \u001b[49m\u001b[43mcausal_model\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mis_asymmetric\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    121\u001b[39m         phis.append(local_shap_score)\n\u001b[32m    123\u001b[39m \u001b[38;5;66;03m# Check if the sum of the Shapley values and expected value adds up to the prediction\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/Files/Heavy/Work/NYU_NEW/Main/shapley_values/causal_shap.py:171\u001b[39m, in \u001b[36mExplainer.approximate_shapley\u001b[39m\u001b[34m(self, xi, x, type, causal_struct, is_asymmetric)\u001b[39m\n\u001b[32m    168\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m index, permutation \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28menumerate\u001b[39m(R):\n\u001b[32m    170\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m is_asymmetric \u001b[38;5;129;01mor\u001b[39;00m (is_asymmetric \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;28mself\u001b[39m.follows_causal_structure(permutation, causal_struct)):\n\u001b[32m--> \u001b[39m\u001b[32m171\u001b[39m         abs_diff, f1, f2 = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mget_value\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mtype\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mlist\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mpermutation\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcausal_struct\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    172\u001b[39m \u001b[43m                                        \u001b[49m\u001b[43mxi\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    174\u001b[39m         \u001b[38;5;28mprint\u001b[39m(abs_diff)\n\u001b[32m    175\u001b[39m         \u001b[38;5;28mprint\u001b[39m([permutation])\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/Files/Heavy/Work/NYU_NEW/Main/shapley_values/causal_shap.py:267\u001b[39m, in \u001b[36mExplainer.get_value\u001b[39m\u001b[34m(self, type, permutation, x, causal_struct, xi)\u001b[39m\n\u001b[32m    264\u001b[39m     prob_x_hat_2 = get_probability(\n\u001b[32m    265\u001b[39m         \u001b[38;5;28mself\u001b[39m.X_counter, x_hat_2, indices_baseline_2, lenX)\n\u001b[32m    266\u001b[39m \u001b[38;5;28;01mcase\u001b[39;00m ShapleyValuesType.CONDITIONAL:\n\u001b[32m--> \u001b[39m\u001b[32m267\u001b[39m     prob_x_hat_2 = \u001b[43mconditional_prob\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m    268\u001b[39m \u001b[43m        \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mX_counter\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_hat_2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mindices_2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mindices_baseline_2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlenX\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    269\u001b[39m \u001b[38;5;28;01mcase\u001b[39;00m ShapleyValuesType.CAUSAL:\n\u001b[32m    270\u001b[39m     prob_x_hat_2 = \u001b[32m0.1\u001b[39m \u001b[38;5;66;03m# Implementation with do intervetions\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/Files/Heavy/Work/NYU_NEW/Main/shapley_values/probabilities.py:18\u001b[39m, in \u001b[36mconditional_prob\u001b[39m\u001b[34m(unique_count, x_hat, indices, indices_baseline, n)\u001b[39m\n\u001b[32m     16\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mconditional_prob\u001b[39m(unique_count, x_hat, indices, indices_baseline, n):\n\u001b[32m     17\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(indices) == \u001b[32m0\u001b[39m:\n\u001b[32m---> \u001b[39m\u001b[32m18\u001b[39m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mget_probability\u001b[49m\u001b[43m(\u001b[49m\u001b[43munique_count\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_hat\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mindices_baseline\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mn\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m     20\u001b[39m     numerator_indices = indices + indices_baseline\n\u001b[32m     21\u001b[39m     numerator = get_probability(unique_count, x_hat, numerator_indices, n)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/Files/Heavy/Work/NYU_NEW/Main/shapley_values/probabilities.py:11\u001b[39m, in \u001b[36mget_probability\u001b[39m\u001b[34m(unique_count, x_hat, indices_baseline, n)\u001b[39m\n\u001b[32m      8\u001b[39m x_hat_array = np.asarray(x_hat)\n\u001b[32m     10\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m key, occurrences \u001b[38;5;129;01min\u001b[39;00m unique_count.items():\n\u001b[32m---> \u001b[39m\u001b[32m11\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28;43mall\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mkey\u001b[49m\u001b[43m[\u001b[49m\u001b[43mj\u001b[49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[43m==\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_hat_array\u001b[49m\u001b[43m[\u001b[49m\u001b[43mj\u001b[49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mj\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mindices_baseline\u001b[49m\u001b[43m)\u001b[49m:\n\u001b[32m     12\u001b[39m         count += occurrences\n\u001b[32m     14\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m count / n\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    }
   ],
   "source": [
    "explainer = Explainer(X = X_test, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = [])\n",
    "phis = explainer.compute_shapley_values([1, 0.2, 0.6, 1], type = ShapleyValuesType.CONDITIONAL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.12.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
