{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import pandas as pd\n",
    "from nn_model import NNModel\n",
    "\n",
    "from spn.algorithms.Marginalization import marginalize\n",
    "from spn.algorithms.Inference import log_likelihood\n",
    "\n",
    "def get_related(index, data_name):\n",
    "    for i in range(5):\n",
    "        testdata = pd.read_csv(f\"{path_base}/{data_name}/{i}/data/X_subtest.csv\", index_col=0)\n",
    "        if index in testdata.index:\n",
    "            with open(f\"{path_base}/{data_name}/{i}/models/spn.pickle\", \"rb\") as f:\n",
    "                spn = pickle.load(f)\n",
    "            with open(f\"{path_base}/{data_name}/{i}/models/dhandler.pickle\", \"rb\") as f:\n",
    "                dhandler = pickle.load(f)\n",
    "            nn = NNModel(dhandler.encoding_width(True), [20, 10], 1)\n",
    "            nn.load(f\"{path_base}/{data_name}/{i}/models/nn.pt\")\n",
    "            break\n",
    "    return spn, dhandler, testdata.loc[index], i, nn\n",
    "\n",
    "\n",
    "def get_bounds(feat):\n",
    "    bound_edits = {\n",
    "        \"Credit amount\": (0, -8500),\n",
    "        \"Duration\": (0, -30),\n",
    "    }\n",
    "    if hasattr(feat, \"bounds\"):\n",
    "        min, max = feat.bounds\n",
    "    elif hasattr(feat, \"numeric_vals\"):\n",
    "        min, max = feat.numeric_vals[0], feat.numeric_vals[-1]\n",
    "        return min, max+1, feat.numeric_vals, 0.5\n",
    "\n",
    "    if feat.name in bound_edits:\n",
    "        min += bound_edits[feat.name][0]\n",
    "        max += bound_edits[feat.name][1]\n",
    "    if feat.discrete:\n",
    "        return min, max, np.arange(min, max+1), 0\n",
    "    return min, max, np.linspace(min, max, 1000), 0\n",
    "\n",
    "\n",
    "path_base = \"results/real_data\"\n",
    "\n",
    "with open(path_base + \"/results.pickle\", \"rb\") as f:\n",
    "    smaller_results = pickle.load(f)\n",
    "\n",
    "\n",
    "data_names = [\"credit\", \"adult\", \"gmsc\"]\n",
    "\n",
    "results = {}\n",
    "for data_name in data_names:\n",
    "    results[data_name] = {\n",
    "        \"LiCE_optimize\": smaller_results[data_name][\"LiCE_optimize\"],\n",
    "        \"LiCE_median\": smaller_results[data_name][\"LiCE_median\"],\n",
    "        \"LiCE_quartile\": smaller_results[data_name][\"LiCE_quartile\"],\n",
    "        \"LiCE_sample\": smaller_results[data_name][\"LiCE_sample\"],\n",
    "        \"MIO + SPN\": smaller_results[data_name][\"MIO_no_spn\"],\n",
    "        \"VAE + SPN\": smaller_results[data_name][\"VAE\"],\n",
    "        \"DiCE + SPN\": smaller_results[data_name][\"DiCE\"],\n",
    "        \"CH-CVAE \": smaller_results[data_name][\"CVAE\"],\n",
    "        \"FACE_knn\": smaller_results[data_name][\"FACE_knn\"],\n",
    "        \"FACE_eps\": smaller_results[data_name][\"FACE_eps\"],\n",
    "        \"PROPLACE\": smaller_results[data_name][\"PROPLACE\"],\n",
    "    }\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predicted [False]\n",
      "LiCE_median 1 ['Installment rate in percentage of disposable income'] [4] [2.809594]\n",
      "MIO + SPN 3 ['Duration' 'Installment rate in percentage of disposable income' 'Age'] [36 4 30] [35.0 2.951445 31.0]\n",
      "PROPLACE 8 ['Status of existing checking account' 'Duration' 'Purpose'\n",
      " 'Credit amount' 'Savings account/bonds' 'Present residence since' 'Age'\n",
      " 'Number of people being liable to provide maintenance for'] ['A11' 36 'A42' 3959 'A61' 3 30 1] ['A14' 6.0 'A48' 1238.00006812 'A65' 4.0 36.0 2.0]\n",
      "FACE_eps 8 ['Status of existing checking account' 'Duration' 'Credit history'\n",
      " 'Credit amount' 'Installment rate in percentage of disposable income'\n",
      " 'Personal status and sex' 'Present residence since' 'Age'] ['A11' 36 'A32' 3959 4 'A93' 3 30] ['A12' 24.0 'A33' 2064.0 3.0 'A92' 2.0 34.0]\n",
      "FACE_knn 7 ['Duration' 'Purpose' 'Credit amount' 'Present residence since' 'Property'\n",
      " 'Age' 'Housing'] [36 'A42' 3959 3 'A122' 30 'A152'] [24.0 'A41' 6579.0 2.0 'A124' 29.0 'A153']\n",
      "CH-CVAE  5 ['Duration' 'Credit amount'\n",
      " 'Installment rate in percentage of disposable income' 'Age' 'Job'] [36 3959 4 30 'A174'] [19.0 3899.761969655752 3.0260162353515625 36.0 'A172']\n",
      "VAE + SPN 7 ['Duration' 'Purpose' 'Credit amount' 'Present employment since' 'Age'\n",
      " 'Job' 'foreign worker'] [36 'A42' 3959 'A71' 30 'A174' 'A201'] [21.0 'A40' 1982.0 'A73' 31.0 'A173' 'A202']\n",
      "DiCE + SPN 7 ['Duration' 'Credit amount'\n",
      " 'Installment rate in percentage of disposable income'\n",
      " 'Other debtors / guarantors' 'Present residence since' 'Job'\n",
      " 'foreign worker'] [36 3959 4 'A101' 3 'A174' 'A201'] [37 7516 2 'A102' 1 'A173' 'A202']\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "shown_folds = []\n",
    "data_name = \"credit\"\n",
    "fact_i = 993\n",
    "\n",
    "testdata = pd.read_csv(f\"{path_base}/{data_name}/0/data/X_subtest.csv\", index_col=0)\n",
    "spn, dhandler, factual, fold, nn = get_related(fact_i, data_name)\n",
    "print(\"Predicted\", nn.predict(dhandler.encode(factual)) > 0)\n",
    "\n",
    "x_i, y_i = 4, 1\n",
    "\n",
    "feat_x = dhandler.features[x_i]\n",
    "feat_y = dhandler.features[y_i]\n",
    "\n",
    "\n",
    "minx, maxx, x, shiftx = get_bounds(feat_x)\n",
    "miny, maxy, y, shifty = get_bounds(feat_y)\n",
    "\n",
    "\n",
    "X, Y = np.meshgrid(x, y)\n",
    "flatX = X.flatten()\n",
    "flatY = Y.flatten()\n",
    "\n",
    "marginal_spn = marginalize(spn.spn_model, [x_i, y_i])\n",
    "custom_data = np.zeros((flatX.shape[0], dhandler.n_features))\n",
    "custom_data[:,x_i] = flatX\n",
    "custom_data[:,y_i] = flatY\n",
    "lls = log_likelihood(marginal_spn, custom_data, axis=1)\n",
    "lls[lls<-12.5] = -12.5\n",
    "\n",
    "\n",
    "plt.figure(figsize=(7,4))\n",
    "plt.imshow(lls.reshape(X.shape), interpolation='none', origin=\"lower\", aspect='auto', extent=[minx,maxx,miny,maxy], vmax=lls.max(), vmin=lls.min(), cmap=\"cividis\")\n",
    "\n",
    "methods_plt = [\n",
    "    (\"LiCE_median\", \"red\", \"LiCE (ours)\"),\n",
    "    (\"MIO + SPN\", \"yellow\", \"MIO (ours)\"),\n",
    "    (\"PROPLACE\", \"turquoise\", \"PROPLACE\"),\n",
    "    (\"FACE_eps\", \"forestgreen\", \"FACE ($\\epsilon$)\"),\n",
    "    (\"FACE_knn\", \"lime\", \"FACE (knn)\"),\n",
    "    (\"CH-CVAE \", \"whitesmoke\", \"C-CHVAE\"),\n",
    "    (\"VAE + SPN\", \"deeppink\", \"VAE (+SPN)\"),\n",
    "    (\"DiCE + SPN\", \"magenta\", \"DiCE (+SPN)\"),\n",
    "]\n",
    "kwargs = {\"marker\":\"D\", \"s\":100, \"edgecolor\":\"black\", \"linewidths\":0.7, \"alpha\":1}\n",
    "\n",
    "for method, color, label in methods_plt:\n",
    "    if \"valid\" not in results[data_name][method][fact_i]:\n",
    "        continue\n",
    "    ce = results[data_name][method][fact_i][\"valid\"][\"CE\"]\n",
    "    mx = feat_x.encode(ce[feat_x.name], normalize=False, one_hot=False)\n",
    "    my = feat_y.encode(ce[feat_y.name], normalize=False, one_hot=False)\n",
    "    plt.scatter(mx+shiftx, my+shifty, color=color, label=label, **kwargs)\n",
    "    diffs = factual.values != ce.values.flatten()\n",
    "    print(method, sum(diffs), np.array(dhandler.feature_names)[diffs], factual.values[diffs], ce.values.flatten()[diffs])\n",
    "\n",
    "plt.scatter([feat_x.encode(factual[feat_x.name], normalize=False, one_hot=False)+shiftx],\n",
    "            [feat_y.encode(factual[feat_y.name], normalize=False, one_hot=False)+shifty],\n",
    "            marker=\"X\", color=\"white\", label=\"Factual\", s=70, edgecolor=\"black\", linewidths=0.5)\n",
    "\n",
    "plt.legend(bbox_to_anchor=(1, 0.5), loc=\"center left\")\n",
    "plt.ylabel(\"Duration [months]\")\n",
    "plt.xlabel(\"Credit amount\")\n",
    "\n",
    "if hasattr(feat_x, \"orig_vals\"):\n",
    "    plt.xticks(np.array(x)+0.5, feat_x.orig_vals, rotation=90)\n",
    "if hasattr(feat_y, \"orig_vals\"):\n",
    "    plt.yticks(np.array(y)+0.5, feat_y.orig_vals)\n",
    "\n",
    "plt.title(\"Log-likelihood of counterfactuals on Credit dataset\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"motivation.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
