{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d05cab18",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "import seaborn as sn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d6302d10",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting so that the plots look normal even when using dark-reader\n",
    "sn.set_style(\"whitegrid\")\n",
    "sn.set_context(context=\"paper\", font_scale=2)\n",
    "pal = sn.color_palette(\"Set1\")\n",
    "\n",
    "# Setting up specifics for plotting + saving\n",
    "save_figures = True\n",
    "add_legend = False\n",
    "add_title = False\n",
    "add_axis = False\n",
    "save_parms = {'format': 'pdf','bbox_inches':'tight', 'pad_inches':0}\n",
    "line_parms = {'linewidth':4, 'color':'k'}\n",
    "if save_figures:  # saves all figures in a figure directory in the local directory\n",
    "    figure_dir = Path('.') / 'figures' / 'adult-income-experiment'\n",
    "    if not figure_dir.exists():\n",
    "        figure_dir.mkdir(parents=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d6302d10",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Experiment hyperparamters\n",
    "rng = np.random.RandomState(42)\n",
    "split_on_income = False  # if True: src := income>=50k, tgt :+ income<50k, if False: src := male, tgt := female\n",
    "n_samples = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "dade2b7e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished preprocessing adult income dataset.  Split on sex with resulting source shape: (1000, 3), target shape: (1000, 3).\n"
     ]
    }
   ],
   "source": [
    "# Loading in adult income dataset\n",
    "from data_utils import load_and_preprocess_adult_income_dataset\n",
    "# We will be using data from  the UCI: adult income data set\n",
    "# Link: https://archive.ics.uci.edu/ml/datasets/adult/\n",
    "data_dir = Path('../data/adult-income')\n",
    "\n",
    "source, target, feature_names = load_and_preprocess_adult_income_dataset(\n",
    "            data_dir, split_on_income, rng, n_samples, return_column_names=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "296df3b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# standardize the source and target data, and convert to domain labels\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "X = np.concatenate((source, target), axis=0)\n",
    "# standardize X to remove cardinatlity bias\n",
    "X = StandardScaler().fit_transform(X)\n",
    "y = np.concatenate((np.zeros(source.shape[0]),\n",
    "                    np.ones(target.shape[0])), axis=0)  # domain labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c5422e1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.datasets import make_classification\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "X_train, X_test, y_train, y_test = train_test_split(X, y,\n",
    "                                     stratify=y, random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "458c8f7c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "forest train accuracy: 0.648\n",
      "forest test accuracy: 0.606\n"
     ]
    }
   ],
   "source": [
    "from sklearn.ensemble import RandomForestClassifier\n",
    "\n",
    "forest = RandomForestClassifier(1000, min_samples_leaf=20)\n",
    "forest.fit(X_train, y_train)\n",
    "\n",
    "print(f\"forest train accuracy: {forest.score(X_train, y_train):.3f}\")\n",
    "print(f\"forest test accuracy: {forest.score(X_test, y_test):.3f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0fd7490e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Elapsed time to compute the importances: 0.080 seconds\n",
      "Feature importances:\n",
      " ['age:0.477', 'education-num:0.176', 'income:0.347']\n"
     ]
    }
   ],
   "source": [
    "import time\n",
    "import numpy as np\n",
    "\n",
    "start_time = time.time()\n",
    "importances = forest.feature_importances_\n",
    "std = np.std([tree.feature_importances_ for tree in forest.estimators_], axis=0)\n",
    "elapsed_time = time.time() - start_time\n",
    "\n",
    "print(f\"Elapsed time to compute the importances: {elapsed_time:.3f} seconds\")\n",
    "print('Feature importances:\\n', [f'{feat}:{value:.3g}' for (feat, value) in zip(feature_names, forest.feature_importances_)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6508cf4f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "forest_importances = pd.Series(importances, index=feature_names)\n",
    "fig, ax = plt.subplots()\n",
    "forest_importances.plot.bar(yerr=std, ax=ax)\n",
    "ax.set_title(\"Feature importances using MDI\")\n",
    "ax.set_ylabel(\"Mean decrease in impurity\")\n",
    "fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "139964da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.inspection import permutation_importance\n",
    "train_result = permutation_importance(\n",
    "    forest, X_train, y_train, n_repeats=10, random_state=42, n_jobs=2\n",
    ")\n",
    "test_results = permutation_importance(\n",
    "    forest, X_test, y_test, n_repeats=10, random_state=42, n_jobs=2\n",
    ")\n",
    "sorted_importances_idx = train_result.importances_mean.argsort()\n",
    "train_importances = pd.DataFrame(\n",
    "    train_result.importances[sorted_importances_idx].T,\n",
    "    columns=[feature_names[i] for i in sorted_importances_idx],\n",
    ")\n",
    "test_importances = pd.DataFrame(\n",
    "    test_results.importances[sorted_importances_idx].T,\n",
    "    columns=[feature_names[i] for i in sorted_importances_idx],\n",
    ")\n",
    "for name, importances in zip([\"train\", \"test\"], [train_importances, test_importances]):\n",
    "    ax = importances.plot.box(vert=False, whis=10)\n",
    "    ax.set_title(f\"Permutation Importances ({name} set)\")\n",
    "    ax.set_xlabel(\"Decrease in accuracy score\")\n",
    "    ax.axvline(x=0, color=\"k\", linestyle=\"--\")\n",
    "    ax.figure.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "5d9ba299",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Using XGBoost\n",
    "import xgboost\n",
    "\n",
    "def fit_xgboost(X_train, y_train, X_test, y_test, feature_names=None):\n",
    "    \"\"\" Train an XGBoost model with early stopping.\n",
    "    \"\"\"\n",
    "    dtrain = xgboost.DMatrix(X_train, label=y_train, feature_names=feature_names)\n",
    "    dtest = xgboost.DMatrix(X_test, label=y_test, feature_names=feature_names)\n",
    "    # model = xgboost.train(\n",
    "    #     { \"eta\": 0.001, \"subsample\": 0.5, \"max_depth\": 2,\n",
    "    #       \"objective\": 'binary:logistic', 'eval_metric': 'logloss'}, dtrain, num_boost_round=200000,\n",
    "    #     evals=[(dtest,'eval'), (dtrain,'train')], early_stopping_rounds=20, verbose_eval=False\n",
    "    # )\n",
    "    model = xgboost.train(\n",
    "        {\"objective\": 'binary:logistic', 'eval_metric': 'logloss'},\n",
    "        dtrain,\n",
    "        evals=[(dtest,'eval'), (dtrain,'train')],\n",
    "        verbose_eval=False)\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "bd7ac9f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "xgb_forest = fit_xgboost(X_train, y_train, X_test, y_test, feature_names)\n",
    "xgb_forest.feature_names = feature_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "dcaa3020",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_acc(model, samples, labels, feature_names=None):\n",
    "    predictions = (model.predict(xgboost.DMatrix(samples,\n",
    "                                                 feature_names=feature_names)) > 0.5).astype(int)\n",
    "    return (predictions == labels).sum() / predictions.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7ce6b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train score: 0.6833333333333333\n",
      "Test score: 0.61\n"
     ]
    }
   ],
   "source": [
    "print('Train score:', get_acc(xgb_forest, X_train, y_train, feature_names))\n",
    "print('Test score:', get_acc(xgb_forest, X_test, y_test, feature_names))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "97a1d2b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import shap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7db385db",
   "metadata": {},
   "outputs": [],
   "source": [
    "explainer = shap.Explainer(xgb_forest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "be14ac89",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "shap_values = explainer(pd.DataFrame(X_test, columns=feature_names))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "8e7a54a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 288x72 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Beeswarm plot\n",
    "if split_on_income:\n",
    "    dropped_feature = 'income'\n",
    "else:\n",
    "    dropped_feature = 'sex'\n",
    "    \n",
    "shap.plots.beeswarm(shap_values, show=False)\n",
    "\n",
    "fig = plt.gcf()\n",
    "fig.set_size_inches(4, 1, forward=True)\n",
    "if save_figures: plt.savefig(\n",
    "    figure_dir / f'adult-income-split-on-{dropped_feature}-SHAP-baseline.{save_parms[\"format\"]}',\n",
    "    **save_parms,\n",
    "    transparent=True\n",
    "    )\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.11 ('py37')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.11"
  },
  "vscode": {
   "interpreter": {
    "hash": "5ab0220f0ca30ec7bac8a7e209564eceae6d15412b9f87f3c2f91206aa8b151c"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
