{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "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",
    "from simulations.simulations import path_wise_dataset_1, ModelWrapper\n",
    "from sklearn.neural_network import MLPRegressor\n",
    "\n",
    "\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sample 1, 0.5, 0.3, 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [1.27005161]\n",
      "Shapley Values + (E[f(X)]):  0.202\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.3, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.3729084\n",
      "Predicted Value (f(x))  [1.278]\n",
      "Shapley Values + (E[f(X)]):  0.182\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.3, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Xqhbt645u4qeeUd/ferRvgjfbay7wTp06GB6/fT0oXqaSD1lpI4c6IEuOgfkmDFjQvzu3aE621ifo2fDGjZsmJk3VUeNli9fbs6EpT15S5cu9ZlHk++xs7cx3+Pw3c7+bN++3WzPCRMmlJtSrMZ9l0MaqeEKhYWF1pNPPmnObhITE2O1bNnSmjRpkvk1V1q7du3Mr8HSrr/+erOsosuQIUPKrW/dunXWiBEjrHr16lnx8fHWoEGDrMWLFwf9fbpZqLZxbm6udeONN1rdu3e36tevb0VFRVnNmze3Ro0aZX3//fche79uVJ1t/NZbb1nDhw+3WrdubcXGxlpxcXFW586drYkTJ1o7duzwuz6+x87dxnyPw3c7+6NnravojGc17bvMSC4AAAAchwPPAAAA4DiEXAAAADgOIRcAAACOQ8gFAACA4xByAQAA4DiEXAAAADgOIRcAAACOQ8gFAACA40TZXQAAAECwjRs3Tl5//XXz727duklycrLP/cXFxfLYY4/Ja6+9Jjt37jSnHt+6datMnz5dXn31VVm3bl2505BXxUsvvWRed/PmzRIbG+tz39///ndz+luvAwcOSOPGjSVUioqK5KeffjK15eXlScOGDaVfv37SunXrkz43PT3dnMr54MGDkp2dLVFRUeaUzb169TKnevbSUzxv2rSpwte55pprpHbt2n7vW7FihalPX/d0Tv3MSC4AAAhrixYtEo/HU+Fl7ty55nEaIN944w3529/+Vu41Zs2aJVOmTJGRI0eaUPuPf/xDMjMz5YknnpD77ruvXMB95JFHzLL169eXe60bbrhBIiMjZeHChSZc5+fnm9cr66KLLjL1XHHFFWKHpUuXyurVq6Vjx45yzjnnmPfz8ccfy759+0763KysLCkoKJBOnTqZ5/bt27dkW5T+TLp27SrnnXeez2Xo0KElobiigKuvv2rVKvO408VILgAACGs///yzuZ45c6YJTmVdeOGF8tlnn5lAde211/p9DR3BveCCC2TGjBk+I62FhYVy1VVXlXv8bbfdZsKyPqZ0gH3uuefMa02bNk2GDx9ull1//fXy9NNPy+23325Ct1eXLl3MZcuWLfL+++9LKKWlpZmR6l/96ldm9FUlJSXJO++8I99//71cdtlllT5fR7r1UpqOkOv70OCs4VY1a9bMXErTEK2fq4brinz33XfStGlT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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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [1.27005161]\n",
      "Shapley Values + (E[f(X)]):  0.883\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.3, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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eko6duwo1atXl3r16snZZ58tb775pjBf2e652bVrl9x9993mdZUrV5ZmzZrJvffeK/v37y/32kNVyF7LvryMGjVKJk+eLFdeeaX5n2/NmjXm8bJly2T+/PlSqVLRM/z48eNl9+7d5VqvS8ri3Jx77rly5513+m3jH1X752bLli3Sp08f8w/sbbfdZi4xp1c9Wb58uezYsSNonyMclebcDB482PyBkJ+el0mTJsnAgQPLufrwVppzo4Gpf//+smjRIrn55pvlnnvuMY0g//znP+WWW24xx3rmmWeC+nnCSWnOTUpKipx11lmyc+dOueuuu6RDhw6ycuVKmTp1qixYsEAWLlwoVatWDernCQm67BNyrVy50hMREeEZPHiw3/bJkyfrn5qef/zjH0U+1pIlSzyRkZGe5557zrx2+PDh5VCxO8ri3Oh+N998czlW6aayODfnnHOOp2nTpp6dO3eWY6XuKcvfab7uvPNO8/qPP/64jCp1T2nPzaJFi8x+f/zjH/22Z2VleVq0aOGpWbNmudTtgtKem3vvvdfs98477/ht18e6/fHHHy+XukMdgdTHww8/bP5nWbBggd/2jIwMT9WqVT39+/cv0nGys7M93bp18wwYMMCTmJhIIK0g58YbSPUXdlpaWjlW65bSnptvvvnGvF5/2asjR454Dh06VK41u6Ksfqf5Sk9P99SoUcP8AaG/62Dn3Hz22Wfm9RMnTizwXPfu3T2NGzcu85pdUdpz06lTJ0+VKlU8OTk5ftuPHTvmiY2N9SQkJJRL3aGOMaQ+fvrpJ9MM36NHD7/tOn6kS5cu5vmi0HEna9eulZdeeqmcKnVPWZ2bWbNmma4SHW/VoEED082lXcOwd24++eQTc69jrLQLuEqVKlKtWjXTbf/222+Xa+3hrqx+bny9//77cvDgQRk2bJhERkaWYbVuKe250dfVqlVLJk6caM7J1q1bzb87Y8eOlSVLlpjxv7BzbrKyssy+Os7alx5Tf79t2rRJ9uzZUy61hzICqQ8d76GDwgNd/qtJkybmf6AjR46c8BiJiYnmEmI6frR58+blWK1byuLc6C8X/SWtoXTGjBnSr18/80eDjivVsYuwc27WrVtn7u+44w4zsUnPzRtvvGEmAtx4440yffr0cq0/nJXFz01+f//7380/tLfeemsZVuqe0p6b2rVry3/+8x+pU6eOXHvttRIfHy9t27aVl19+WT744APz8wQ756Z9+/ayb98++eWXX/y262PdrvQPCPhjUpMPHRBe2LVo9a8d7z76D2VhdFadzqy/7777yq1OF5XFufnxxx/9Ht90003SqVMnefjhh+XFF1809wj+uUlLSzP32mr91Vdf5e13xRVXmJ+lhx56yEzaKM6EQpTdz03+Px6+++47Of/886VFixZlWqtryuLc6AohOmFm0KBBZna9/kGngfT666+XOXPmyIUXXlhu9Yez0p6bP/7xjzJ79mzzh8Jf//pXc45WrVpltusk2qNHj5rXwx+/4X1oV642tQeSmZmZt09htHvx888/NzPpmLldsc5NYUaPHm1+qcydO7fUNbqqtOdGu7DUdddd5/cLXluA9B/a5OTkvFZU2P250dZRdfvtt5dRhe4q7blZsWKFCaEaOnXFA50NritU6B8MDRs2NC2kx44dK7f6w1lpz432ur377rvmj+0BAwaY1msdjqTL2F122WVmnxo1apRT9aGLQOqjcePGpik+0P+IuvSMNuEX9heRvkZbRS+99FLzy2Djxo3mpsvZKB2nqI9Zgyz45+ZE9A8H77Fh59w0bdrU3OvPTX6NGjUy995uLtj7ucnOzpaZM2dK3bp1TfiB3XOjcxU0HF1zzTV+2zUoaQjSf3s2b95cLrWHu7L4udHzsn37drNMlC71pMMAXnnlFbMtKioq4HJqriOQ+ujevbtZ223x4sV+2/WHXsd+nHnmmYW+NiMjw6w5qi1trVq1yrvp2ore1lN9PG3atHL/HOGoNOfmRPT1+gvilFNOKaNK3VPac+OdOKDnIT/vNp2ABrs/Nx999JFZ7Hvo0KGFdmcieOfGuz5voFZQ/ePB9x52fm500p9OgtIWU/0dpr09GlB79+7NOqQBEEh9DBkyxAzW1zEfvl5//XUz3uOGG27I2/bbb7+ZGY1eOitYZzrmv02ZMsU8f8kll5jH2gWJ4J4btXfv3oDHHTdunPmlzQLf9s6NjhXV8aP6R5vv5LKkpCQzDktn29OaYOfcBOqu125h2D837dq1M/d6VSZf2gun40d1yAs/N/Z/brw04I4cOdL8AcF8hULYXneqohkxYoRZf+zKK6/0vP7665777rvPExUV5endu7dZQ8wrPj7e7HcyrENaMc6NLh7ds2dPz9ixYz1Tp071TJo0ydO3b1+z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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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.3729084\n",
      "Predicted Value (f(x))  [1.278]\n",
      "Shapley Values + (E[f(X)]):  0.915\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.3, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QVcAAABwNgIrAAAAHI3ACgAAAEcjsAIAAMDRCKwAAABwNAIrAAAAHI3ACgAAAEcjsAIAAMDRYsRhxowZI3PmzDH/7t69u6xcudJnfWFhoTz22GMye/Zs2bZtm7Rr1042btwoU6ZMkVdeeUV+//13qVWr4jn8hRdeMPtdv369xMXF+ax75plnZPz48cWPd+/eLU2bNpVwKigokJ9//tnUl5eXJ40bN5b+/ftL27ZtLZ+bkZEhS5culT179sihQ4ckJiZGGjVqJL1795akpKTi7b788ktZt25dmfu56qqrpF69egHXLVu2zNSn+x01alQl3yUAAIDNLawfffSRREVFlXmbO3eu2U7D4GuvvSb/+Mc/Su1jxowZMmnSJBk5cqQJqC+++KJkZmbKE088Iffee2+psPrwww+bZatXry61r+uuu06io6Nl0aJFJigfPnzY7M/fueeea+q5+OKLxS4aJpcvXy4dO3aUk046ybynDz74QNLS0iyfm52dLUeOHJHOnTub5/br16/4eJT8XLp16yZDhgzxuQ0ePLg44JYVVnX/v/76q9kOAACguoU1Yfz222/mfvr06SYA+TvnnHPk888/N8Ho6quvDrgPbVk966yzZOrUqT4toPn5+XLFFVeU2v6WW24xwVe3KRlG//nPf5p9PfroozJ8+HCzbPTo0TJt2jS57bbbTID26tq1q7lt2LBB/ve//0m4paenm1bkE0880bSKqk6dOsn8+fPlhx9+kAsvvLDc52srtN5K0tZrfS8agjWoqhYtWphbSRqI9bPVoFyW77//Xpo3b64Xc5bc3NwqvFMAAACbW1g1HDVo0EDGjRtnAqn/rVmzZuU+X8OQht7TTjvNZ7kGzwsuuEDi4+NLPUeDlJ7K1hZSPSWuvvrqK7nzzjvlkksukQceeKB428suu0y2bt0qX3zxhTjJpk2bTID2BkulrZldunSRXbt2mRbOitIWWv1ioK3K5dGQrsoKrKmpqbJ582bTcgsAAFDjA6uGzb59+/q0Xgbr+uuvlzp16pi+nA8++KDZx6BBg0xY0iB85plnlvlc7X+ak5Nj+qlu377dBFNtMX311Vd9tjv++ONN39CFCxdKddE+txq0g7lpC2Uge/fuNUG/du3apcK4d30wtFuAvo52odDPTD+LNm3alFu7tuxqq2v9+vUDrv/222/NZ6mfGwAAQI3uEqAteWvXrpVTTjmluKWzJA1ksbGxZT5fW0l1vZ7Wf/bZZ01A0gFDS5YsMeu9/TID0dPfZ599tjz//POyYMECE9z0PiEhodS2uh8NYdVFT6m/9957QW2rXRoCBUMdKFW3bt1Sy73LDh48GNT+9dS9t8+qBv727dvLySefXOb2Gmh1gJd2PwhE96Wtu94uFQAAADU6sOrofQ2K2sqpN38aZnVQUFmGDh0qn332mTmNrV0KvIOrJk6caO47dOhQ7utrFwAdPKX9Qd9//3059thjA26XnJxsug9UlyZNmsh5550X1LbaghyI9iHVwWH+vMu01TkYPXv2NJ+TBmDtZqAtuuU9V7sD6Oesn4k/banVWQE04JdVNwAAQI0KrHoKWulp+ECnoctqxfPfh7aWlpwJQE+Ha3/OQK2lJXlbFjV86eCusuhgMO0+UFarZkXpFFnBTD1VHn1/gYKld1mgMBtIw4YNzU3plwOdHUFnCrjoootKddPQLxfan1drD9Q3+KeffjLvTY8HAABARARW7b+qwUtPe/v3xazIPsoLm2X59NNPZcKECSYU6zymH3/8sekiEIi3H2ll+tkGoqFST6sHQ4NhoDlkNTgHOu2voVqVNd2UFQ3vX3/9tRw4cKA4yHpt2bKlzNkBdPs1a9aYPsTeGrzvVfu1ZmVlme4bgYIuAACAo1tY9XR0ZcPq/v37TZ9KPa3tf8pdg5WGpED9P/XU9+WXX24Ge2lw1ZbFp59+uszAum/fPhMQq+s0t47ir2ofVn2PKSkpph9wyc9Puzd411eGfm4q0EwB2h1AQ6f2c/Wn4VmDvfYf9vYhLumNN96QHj16MHMAAACoeYF14MCBVXq+6tWrl89yHaGudLYA/3U6IEjnKNXgpXOO6sCu//u//zMXE9AuAiWnifLS/QRabmcfVm0J1fevNXvnYdXWTO33qzMFeLtDaADV96wtmyVbN7WLg/++tSVUW5u1O4H/nLi6/Y4dO0zraqCLAeiAt0CBX7sJaFcCDaqJiYlBvWcAAABHBFYdKa+tgd5wWZWLDviHUj0trXQAUMl12gJ4zTXXmFCn86p6+5FqYA10IYGSlxjVGQmqS3X0YdVQqqH1xx9/NGFSg7deQlVblU8//fTi7fQz1tZcHQh1wgknFC/X0/7aitqqVSvTfUBP42sLqrZa65cI/9kZdCor/fzKmntVw3CgltcVK1aY+0DrAAAAHB1YvWFz9+7d8vrrr5dar62G/qf6/WkLow7W8p/vU4Ocnn7W0/16qVWvhx56yExdpaG05NRNenECvUiBzgTw2GOP+ZxOX7p0qWRkZFheOcoOeolUbUnVVlENn/o56KwHGkKt6GekwV1natDR/dqtQC9/O2DAgIDhUsOstsiWN0crAABA2HjCYMqUKTqSqczb3Llzi7cdPXq0JykpqdQ+BgwY4Bk2bFjA/U+bNs2TkJDgOXTokHn89ttve6Kiojw333xzwO1XrVpl1j/66KM+y++9915Pu3btPIWFhQGfN3nyZFPv7t27K/T+AQAAUHlR+h9xkDFjxsjnn39uTs1r/0n/0euB6Kh1bUWcMmWKuSJWZehIfm1t/Otf/yp33HGHzzptldS+obr/qVOnmpZibaEEAABAhF2aNVg6G4CeuterYgVD+3Tec889JkzqYKLKmD17tunLefPNN5dapxc60Hp0/wAAAAgvx7Wwaj9LncJJaZ/NqswsUJ0BWvuAeulAp/IuIwsAAIAIDqwAAACA47sEAAAAAF4EVgAAADgagRUAAACORmAFAACAoxFYAQAA4GgEVgAAADgagRUAAACORmAFAACAoxFYAQAAIE72/wH9zdCT5GVTYwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array([phis[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sample 1, 0.5, 0.6, 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [0.89301092]\n",
      "Shapley Values + (E[f(X)]):  0.204\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7r33XvH5fEEvjzzyiE2vEE7vJ/q+MH78eHMKTZ2c/aSTTjLr+eMf/yjp6elVPof3ksgTzv2E9xPv7SMV5ebmSkpKivmdT5o0ScL9XhITkrWgTiZPniyzZs2SSy+91OxAa9euNbd/+OEH+eijjyQqqurPHy+88II8/fTTMnLkSPOmExsbK59++qncc8898tprr8m3334riYmJZY/fvHmznHnmmRITEyO33367eYN6/vnn5bzzzpP3339fzj333DC9atTXfcRP39xatGgRsOy0006z5fXB+f1Ez9CkAUWfq2do0veIlStXypw5c+Sf//yn/Pjjj9KqVauyx/NeErnCuZ/48X7inX2kIh1g2bdvn1TF9vcSnSYM4bdq1SrL5/NZo0aNClg+a9YsnbbN+tvf/lbt87///nsrKyur0vK7777bPP/JJ58MWD527FgrKirK+uGHH8qWHT582OrQoYPVtWtXq7S09IRfEyJ7H5k2bZpZnpaWFqJXgEjYT6ry2muvmec//PDDAct5L4lM4d5PeD/x9j6ybNkyKzo62nr00UfNcydOnFjpMXa/l9Ci4JB//OMf+uFC/u///i9g+Q033GC++nnllVeqff7pp59uPu1UNG7cOHO9atWqsmX61cI777wjw4YNM19R+yUlJcn1119vvsr+/vvvQ/CqEKn7SLBziRcXF9e5dkTOflKVjh07muuDBw+WLeO9JHKFcz+piPcTb+0jJSUl5jnnn3++jBo1KuhjwvFeQsB1iP7idKh/4MCBAcu150V/2XX9xerXSKp169Zly1asWCEFBQUyePDgSo/X/kx/PfDuPlJenz59TDDW7ejXR/pVEdy/n+Tn58v+/fvN/vHhhx/K//7v/5rlF154YdljeC+JXOHcT8rj/cR7+8jjjz8u69atk6eeeqrKx4TjvYSA65Ddu3ebvqRgp7Jr166deQMpLCys1Tr1U9P9999v+lmuuOKKgG351xtsW2rXrl11eBVwyz6imjRpIr/97W/lySeflIULF8pDDz0k27ZtkxEjRsi8efNO+PWgfu8nc+fONQcj6kEl2gOXlZVlRmz0oI/y2/KvN9i2FO8l9VM49xPF+4k395G0tDRzml7tv+3UqVO12/KvN9i2QvFewkFmDtGjC6s6T7N+WvI/Ji4ursbr1K8V/v3vf8uDDz4o3bp1C9iWCra98tuCd/cR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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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.3729084\n",
      "Predicted Value (f(x))  [0.912]\n",
      "Shapley Values + (E[f(X)]):  0.187\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [0.89301092]\n",
      "Shapley Values + (E[f(X)]):  0.837\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.3729084\n",
      "Predicted Value (f(x))  [0.912]\n",
      "Shapley Values + (E[f(X)]):  0.867\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.5, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqQAAAFxCAYAAAClXbqoAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAODdJREFUeJzt3Qd8VeX9x/FvSCCMsIcsWQKCDBEFwaooaq3iqChSRxVntaIWZx2g1lXBUamCg1alttaKFv5OqlZFpYoVlb1kb1myAyH3//o96YV7kxtISMiTe5/P+/W6veSce8/53ZwmfvOskxaJRCICAAAAPKng68QAAACAIZACAADAKwIpAAAAvCKQAgAAwCsCKQAAALwikAIAAMArAikAAAC8IpACAADAKwIpAAAAvCKQAgAAwCsCKQAAALwikAIAgJSUm5urBx54QIcccogqVqzonocOHap27dq5fcX1zDPPqFmzZsrOzj4g9YYsLRKJRHwXAQAAUNqeeuop3XDDDbr55pvVuXNn1axZU5dddpkeffRR91xc27dvV4sWLXTnnXe645aVXbt26b///a/mzp3rwnCdOnXUrVs3NW3adJ/v/fHHH/XVV19p1apVrv6srCy1bt1ahx9+uDIyMgq8fs2aNe5c9vqcnBzVqFFD7du3V8eOHff7mEVBIAUAACnpyCOPVL169TR+/Hj39R/+8Afdc889LkhVrlx5v455++2369VXX9WCBQuUlpamsvDhhx9q/vz56tSpkwvVc+bM0erVq3XmmWeqYcOGhb5v8+bNGjNmjCpVqqTDDjtMmZmZ7rPb+5s3b65TTz017vVLly7Ve++9575nrVq1cq3KGzdulEXFHj167Ncxi2r/YiwAAEA5Zi133333ne67777d21544QWdddZZ+x1Gzfnnn++6/T/66CP17t1bB9rq1av1/fff6+ijj3YtkKZNmzYuFH755Zc6++yzC32vtaju2LHDfWZrVTXW2mkBM9raaoHS2OvsM9mQhFNOOaXQsF2cYxYHY0gBAEBKueKKK1SlShXX1X333Xe7cNWoUSNNmTJFJ598coHXL1u2zIXUyy+/PG77Bx984FoJBw0aFNfqakFs3LhxZfJZ5s+f7+q30Bdl3eKHHnqoa5m0FsvCWHA0VatWjdtuX9sxK1TYEwPnzZunbdu2uaEAtm/nzp0uZJbkmMVBIAUAACnloosu0q9+9Sv37yeffFJ/+ctfdM0117ivu3btWuD1TZo00ZVXXqmXX35ZixYtcttmzZqlfv366bTTTtNjjz0W93o7xueff77POmzilLXUFuURKWQE5dq1a103vXWRx2rQoMHu/YVp3Lixe/7kk0/c2FALr9baOmPGDHXo0MGF7dhQbl9v2bLFDUmw1mR7fPrpp24s6f4cszjosgcAACnFutJt3GW1atU0cOBA12o3ePBgt69ly5YJ33PHHXdo1KhReuSRR3T//ffrjDPOcBOYXnnllQKtfja+0kLuvqxcuVJvvfVWkWq+4IILVL169QLbt27dWqA10kS3WYAszMEHH6yjjjpK33zzze6gbY444gjXEhrLJipZKP7Xv/7lWl+7d++u5cuXa/r06a5V9KSTTir2MYuDQAoAAFKOdc9bi100TFpLonV124zwRKyV9KqrrtLzzz+vyZMnu+5rawW0UJtf7dq13f7CwmJU3bp1dfrppxep3ipVqiTcbq2T6enpBbZHt9mwhL2xkGvDFSyI27CExYsXuzBp54udOW9d9HYuGxrwk5/8xG2z91gr78yZM10ItZba4hyzOAikAAAg5diEpuLO+L7lllvcUlEWZq2r2kJqItHu9X3NsrfJPUVZmmlvLEQnCp3RbYnCauy40AkTJqh///67g7iFSKt/0qRJbqmm6ASv6HJNti2WfW2B1MarWiAtzjGLgzGkAAAgpWzYsEFLlixxyyTFtlZaC+CmTZsKfd+DDz7onu110Rnkiaxfv961jBbWqhkbGq0VtSiP3EIW6rfz2P78otsSteBG2bhOW8Ipf6uwLc9kn9HGgMaex+T/TNGvozcDKM4xi4MWUgAAkFKshdPYYvhRdncmY+uHxm6PGjZsmBtDai2kt956qwun9nUidozYWe+FsVbFko4hrVu3rhvLaeM4Yyc22XJQ0f2FsWEFiZZgiobf2IlU9evXdxObbExqrVq1dm+PjlGNBtPiHLM4CKQAACDluutNbPDs2bOne7a7EOUPpGPHjtVvf/tbN5npuuuuc+tpjhgxQnfddVfCSVA2xtRm8u9LaYwhbdWqlQvY1m0eXYfUWl5nz57tZtpHWyqtddJmvFt3ebTL3LrYbbF7azGODZk2K96GG8S2Att5vv32W3fc2KEKttpAdNms4h6zOAikAAAgpViAs1CVP3DZ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qVMn3yUEj0AKAACCxrJP/hFIAQBA0LKzs32XEDwCKQAACFr16tV9lxA8AikAAAhakyZNfJcQPAIpAAAI2qxZs3yXEDwCKQAAALwikAIAgKA1bdrUdwnBI5ACAICg5eTk+C4heARSAAAQtJUrV/ouIXgEUgAAAHhFIC2ODVukq0dK9QdI1S6QThwiTf7ed1UAAKAEOnbs6LuE4BFIiyo3V+rzgPS3T6WBp0lDL5FW/yidMESau9x3dQAAYD99/z2NS0kXSMeMGaO0tDT3OPfccxO+ZtGiRcrIyHCv6dSp0+7t7733nvr166f27durcuXKbv/DDz+scuGEwdKAPxa+f8x/pImzpRcHSvf0l647Tfr4d1J6BemeV8uyUgAAUIq2bdvmu4Tg7XcLacWKFTV+/Hht3bq1wL7hw4crEomoQoX4w7/xxht6/fXXtXnzZrVs2VJJxQLpQbWkvj32bKtfUzr/GGncJCl7p8/qAADAfqpWrZrvEoK334H02GOP1ZYtWzRq1KgC+1577TV1797dhdZYd9xxh9atW6clS5Zo4MCBSirfLJC6tpLyhWx1byNtzZbm0G0PAEAyatasme8SgrffgbRLly5q3ry5Ro8eHbfduuUtcF522WUF3mOtorVq1VJSWrFealS74PbotuXryrwkAABQcjNnzvRdQvBKNKmpf//+mjx5subOnbt728iRI1WjRg0NGDBA5dbOHGnNxviHbbNu9/zbbTKT2bZDyswoeKzKlfbsBwAAQNkG0htuuEHp6el68skn3debNm3S+++/rz59+qhSpf8FtQPIuv+zs7N3f719+55/mx07dmjt2rVx21asWCF9Pitv6abYh01Y+vtnBbZvmDIv7xxVKknZOW78q33OqJ2b/jeG1vbHniP/OfMtwGtjbAv7HPnPUejn4Bycg3NwDs7BOThHic/RuHHjlPgc5fkc+5IWia2giLPsbab8oEGD9Pjjj+v44493LaR24scee0y33HKLJk6cqJ49e7qZ9G3atNHUqVMLHOfpp59240gfeughN7a0VIx6X7pqpPT8tdKVpxT+uvWbpa/zLfFw84tSw9rSrWfHbz+2fV4raJvrpDaNpHfujt//pw+kK0dIU56QOjUvnc8BAADKzOrVq9WgQQPfZQQtQR908Vx++eVuvOi4cePceFILoBZGy7XaWdLJhxfcZuNB82+P6tJC+nRmXhd+7MSmL+dKVTOlto0PbM0AAOCAWL58OYE02RfGv+iii1S7dm3de++9riX0wgsvVEo6r6e0aoP0xhd7ttkY09cmSmceJWXGrygAAACAMmohtaWdzjrrLL300ktu3GjSLedUnEDao6102VPSjKVSverSiPekXbnSfb/wXR0AANhPdsMeJHkgNbfffrsLo61bt1a9evWUktLT88aP3vqSNPztvFn13VpLL14vHdrEd3UAAGA/LV682A05RJIHUvvL4rnnntvn66ZPn+4mM5lZs2a557ffftutW2quu+46dejQQV58fP++X2PjTEddl/cAAAApwW70gxQIpMVZeNbWKY31+eefu4fp3bu3v0AKAACCVKVKFd8lBK/YgfS8886LW6tqb7Zv377f7wUAACgLhxxyiO8SglfiWfYAAADJbNq0ab5LCB6BFAAAAF4RSAEAQNAaNmzou4TgEUgBAEDQMjLKdI43EiCQAgCAoC1dutR3CcEjkAIAAMArAikAAAhau3btfJcQPAIpAAAI2rJly3yXEDwCKQAACNqmTZt8lxA8AikAAAhaZmam7xKCRyAFAABBa9u2re8SgkcgBQAAQZs6darvEoJHIAUAAIBXBFIAABC0Bg0a+C4heARSAAAQtMqVK/suIXgEUgAAELTFixf7LiF4BFIAAAB4lVqBtGur+GcAAIB9YNkn/9IikUjEdxEAAAC+LFiwQC1btvRdRtBSq4UUAACgmH788UffJQSPQAoAAIJWsWJF3yUEjy57AAAAeEULKQAACNq3337ru4TgEUgBAADgFYEUAAAErV69er5LCB6BFAAABC0rK8t3CcFLuUC6cuVK3yUAAIAksnDhQt8lBI9ACgAAAK9SbtmnzZs30/QOAACKjOzgX8q1kK5du9Z3CQAAIImQHfxLrUA6+Xs1bzHIPQMAABTF+vXrfZcQvBQLpPPjnwEAAPYhPT3ddwnBS61ACgAAUEydOnXyXULwCKQAACBoU6ZM8V1C8AikAAAgaLm5ub5LCB6BFAAABK1OnTq+SwgegRQAAAStVq1avksIHoEUAAAEbf58VufxjUAKAAAArwikAAAgaC1btvRdQvAIpAAAIGgbN270XULwCKQAACBo3MvePwIpAAAIWlpamu8SgkcgBQAAQTv88MN9lxA8AikAAAjatGnTfJcQPAIpAAAIWk5O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/qgaNWoc8PNh/3GtkgPXKXlwrZIH1yp5bAz4WqXcpCYAAAAkFwIpAAAAvEqpQGrN27169SqzZm6bkXfPPfcwMy8JcK2SA9cpeXCtkgfXKnmEfK1SagwpAAAAkk9KtZACAAAg+RBIAQAA4BWBFAAAAF4RSAEAAOAVgTSf3NxcPfHEE2rXrp0qV67sFtq/+eabtWXLlmIfa+vWrWrVqpXS0tI0cODAA1JvyEp6rey6JHqk2t0xUuFnat26dbrlllvUunVrd4z69evrxBNP1KeffnpAaw9NSa7VvffeW+jPlD0qVqxYJp8hFCX9ubI7Aj300EPq1KmTqlevrnr16umYY47Riy++KOY6l69rtWrVKl1zzTXufZUqVVKzZs104403asOGDUolSXsv+wNl0KBBGj58uM455xz3f5iZM2e6r7/55ht98MEHqlCh6Bl+yJAh+uGHHw5ovSErjWt13HHH6eqrr47bxn84y9d1WrRokU444QT3H9ArrrjC3X7O7mIyZcoULVu2rMw+RwhKcq369u3r/mDIz67TsGHDdOaZZx7g6sNSkmtlAem0007TxIkTdemll+r66693DSivvPKKLrvsMnesRx55pEw/TyorybVavXq1jj76aC1fvly/+tWv1LFjR02bNk0jR47UhAkT9Pnnn6tq1apKCbbsE/JMmzYtkpaWFunbt2/c9uHDh9ufi5G//vWvRT7W119/HUlPT4889thj7r3XXXfdAag4XKVxrex1l1566QGsEqVxnY499thI06ZNI8uXLz+AlaI0f//Fuvrqq93733rrrVKqFCW9VhMnTnSv+81vfhO3PTs7O9KyZctIzZo1D0jdISrptbrxxhvd6/72t7/Fbbevbfv9998fSRUE0hh33XWXu8ATJkyI275t27ZI1apVI6eddlqRjpOTkxPp2rVrpE+fPpEFCxYQSMvptYoGUvslvGnTpgNYbbhKep0++eQT93775W127NgR2bJlywGtOVSl9fsv1ubNmyM1atRwf1DY70WUj2v13nvvufcPHTq0wL5u3bpFGjduXOo1h6qk16pz586RKlWqRHJzc+O279q1K1K5cuVIq1atIqmCMaQxvvrqK9d03r1797jtNuajS5cubn9R2FiRWbNm6amnnjpAlaK0rtWYMWNcd4eNoWrQoIHrurLuYJSP6/TOO++4ZxszZV2+VapUUbVq1Vy3/csvv3xAaw9Naf1MxXrttde0ceNGDRgwQOnp6aVYbdhKeq3sfbVq1dLQoUPdNVq8eLH7b9Ydd9yhr7/+2o0HRvm4VtnZ2e61Ng47lh3Tfh/Onz9fa9asUSogkMawMRo2sDvRLbuaNGniLvqOHTv2eowFCxa4237Z+NEWLVocwGrDVhrXyn5B2C9eC6UvvfSSevfu7f6IsHGlNl4R/q/T7Nmz3fNVV13lJjbZdfrzn//sBvb/8pe/1AsvvHBA6w9JafxM5fenP/3J/Yf08ssvL8VKUdJrVbt2bf3f//2f6tSpo/PPP1/NmzdX+/bt9fTTT+v11193P28oH9eqQ4cOWr9+vb799tu47fa1bTf2B0UqYFJTDBvUXdj9Y+0vlOhr7D+GhbGZcDaz/qabbjpgdaJ0rtWXX34Z9/Ull1yizp0766677tKTTz7pnuH3Om3atMk9Wwv2Rx99tPt1P//5z93P2Z133ukmZRRnsiEO3M9U/j8mPvvsM5100klq2bJlqdYautK4VraaiE2QOeuss9zsevuDzwLphRdeqHHjxumUU045YPWHpKTX6je/+Y3Gjh3r/nD4wx/+4K7Z9OnT3XabgLtz5073/lTAb/EY1nVrzeOJbN++ffdrCmNdiO+//76b/cZM7fJ9rQpz6623ul8Mb7/9dolrRMmvk3VJmQsuuCDuF7a18Nh/SFeuXLm7FRXl62fKWkfNlVdeWUoVorSu1dSpU10ItdBpKyDY7G9bwcL+gGjYsKFrId21a9cBqz8kJb1Wxx13nP7+97+7P8779OnjWrNt+JIte3fGGWe419SoUUOpgEAao3Hjxq75PNH/eWx5GWt2L+yvGHuPtYqefvrp7gd63rx57mFL1hgbl2hfp9q6Ycl4rfbG/pCIHhv+r1PTpk3ds/1M5deoUSP3HO22Qvn5mcrJydHo0aNVt25dF3ZQvq6VzXOwMNSvX7+47RaMLPTYf7cWLlx4QGoPTWn8XPXr109Lly51y0TZUk82DOCZZ55x2zIyMhIut5aMCKQxunXr5tZnmzRpUtx2+8G18RpHHXVUoe/dtm2bW3PUWtbatGmz+2HrJ0ZbT+3rUaNGHfDPEYKSXKu9sffbD/lBBx1USpWGraTXKToRwK5JftFtNhkN5etn6s0333SLeV988cWFdlfC37WKrt+bqBXU/piIfUb5+LlKT093k6CsxdR+51nvkAXUXr16pcw6pATSGP3793cD8G2cRqznn3/ejdG46KKLdm/7/vvv3azEKJv5a7MV8z9GjBjh9v/sZz9zX1s3I/xeK7N27dqExx08eLD7Rcwi3uXjOtlYURs/an/QxU40W7FihRtXZbPtU6V1INmvVaLueusGRvm7Vocddph7trsyxbIePBs/akNi+Lkqfz9XURZwb7jhBvcHRUrNdfC97lR5M3DgQLdm2DnnnBN5/vnnIzfddFMkIyMj0qtXL7fuV1Tz5s3d6/aFdUjL57WyBaF79OgRueOOOyIjR46MDBs2LHLiiSe61x199NGRrVu3evhEqamkP1PPPvus296hQwd3o4mHH3440qxZs0jFihUj48ePL+NPk9pK4/ffsmXL3E1BunfvXoaVh6ck12rhwoWROnXquAXbL774Yvc78MEHH4y0aNHCvfbpp5/28IlSV0mu1aZNmyLt27eP3Hnnne69jz76aOTII490r7NrlkoIpPnY4s12wdu2bRupVKmSWyB40KBBBRZOJ5Am97UaO3Zs5Kc//al7T2Zmplug+PDDD3c/4LZgMcrXz9Trr7/u/lCw65SVlRU55ZRTIp999lkZfYJwlMa1sp8h2/fcc8+VUdVhKum1mjdvXuSSSy6JNGnSxIWj6tWrR4477jj3s4byc62ys7Mjv/jFL9wfC/bfqtq1a7v/dtnNDVJNmv2P71ZaAAAAhIsxpAAAAPCKQAoAAACvCKQAAADwikAKAAAArwikAAAA8IpACgAAAK8IpAAAAPCKQAoAAACvMlTODBgwQC+99JL7d4cOHTRt2rQC93B96KGH9MILL2jx4sVq1qyZu//r0KFD9ec//1kzZsxQhQrFz9nPPPOMO+7cuXOVmZkZt8/uQTto0KDdX//www+qV6+eypLds/a///2vqy87O1t16tRRt27d1LRp032+d926dfr666+1Zs0ad+/cjIwMd6/iww8/XM2bN9/9uo8//lhz5swp9Dh2z91q1aol3Dd58mRXnx23X79++/kpAQBAiMq0hXT8+PFKS0sr9DF69Gj3Ogt7f/nLX/T73/++wDFGjBihIUOGqG/fvi6APvvss9q4caMeeeQR3X777QXC6H333ee2zZw5s8CxLr/8cqWnp+vtt992QXjHjh3uePn97Gc/c/Wcc8458sXC4pQpU9S6dWsdc8wx7jO9++67Wrly5T7fu3nzZu3cuVNt27Z17+3atevu6xH7fWnfvr1OPPHEuMcJJ5ywO8AWFkbt+N9++617HQAAQHGVaYL47rvv3PPw4cNdwMnv1FNP1b///W8XfC6++OKEx7CW0VNOOUXDhg2La8HMycnRBRdcUOD11157rQu29prYsPnHP/7RHeuBBx5Qnz593LZLL71Ujz/+uK6//noXkKPatWvnHvPmzdM///lPlbXVq1e7VuCjjz7atWqaNm3aaMyYMfryyy919tln7/X91opsj1jW+myfxUKuBVFz0EEHuUcsC7z2vbUgXJgvvvhCDRo0sBvwavv27SX4pAAAIERl2kJq4admzZoaOHCgC5z5H/Xr19/r+y3sWKg9/vjj47ZbsDzrrLNUuXLlAu+xoGRdzdbCaV3W5pNPPtFNN92kc889V3fdddfu155//vlatGiRPvroI5Un8+fPdwE5GhyNtUYeeuihWrVqlWuhLC5rYbXgb63Ce2Mh3BQWSFesWKEFCxa4llcAAIByH0gtTB5xxBFxrY9FdcUVV6hKlSpuLOXdd9/tjtGzZ08XhizonnzyyYW+18Z/btu2zY0TXbJkiQue1uL54osvxr3uyCOPdGMzx40bp9JiY14tSBflYS2Miaxdu9YF+UqVKhUI29H9RWHd9nYeG+Jg3zP7XjRp0mSvtVvLrLWaVq9ePeH+zz//3H0v7fsGAABQrrvsrSVu9uzZOvbYY3e3VMaywFWxYsVC32+tnLbfut2ffPJJF4BsQs7EiRPd/ui4yESse/qnP/2pnn76aY0dO9YFM3vOysoq8Fo7joWs0mJd3m+99VaRXmtDDhIFP5uIVLVq1QLbo9u2bNlSpONb13p0zKgF+hYtWugnP/lJoa+3wGoTqGx4QCJ2LGudjQ55AAAAKNeB1Ga/WxC0Vkp75Gdh1SbdFKZ379768MMPXTezdflHJy8NHjzYPbds2XKv57cuepucZOMx33nnHR1yyCEJX9eqVSvXvV9a6tatq9NPP71Ir7UW4ERsDKdNvsovus1ajYuiU6dO7vtkAdeGAViL7N7ea9319n2270l+1tJqs+otwBdWNwAAQLkKpNZFbKybPFE3cWGtcPmPYa2dsTPprbvaxlMmau2MFW0ZtHBlk6cKY5OtrHu/sFbJ4rIlpIqyNNPe2OdLFByj2xKF1URq1arlHsbCv60uYDPtf/7znxcYRmF/PNh4Wqs90djcr776yn02ux4AAABJEUht/KgFK+uWzj8WsjjH2FuYLMwHH3ygW265xYVeW8fzX//6l+vCTyQ6jnN/xrkmYqHRur2LwoJfojVULRgn6pa30GwKW45pXyycf/rpp/rxxx93B9WohQsXFjq73l4/a9YsN4Y3WkP0s9q40k2bNrnhFYmCLAAAgNcWUusu3t8wumHDBjem0bqd83eJW3CyEJRo/KV1Tffv399NprJgai2DTzzxRKGBdP369S4AllY3tM2CL+kYUvuMy5cvd+NwY79/Nvwgun9/2PfNJJppb931FiptnGl+Fo4tuNv43egY3livvPKKOnbsyMx7AABQ/gJpjx49SvR+07lz57jtNsPb2Gz7/Ptswo2t0WnBytbctIlTv/71r91i+daFH7uMUpQdJ9F2n2NIrSXTPr/VHF2H1FojbdytzbSPDlewgGmf2VomY1snbQhC/mNbS6a1Flt3f/41Ye31S5cuda2jiRa7twlliQK9deNbV78F0Ro1ahTpMwMAAJRJILWZ5taaFw2PJVlUP3/otG5jYxNsYvdZC94vf/lLF9psXdHoOE4LpIkWyo+9BabN6C8tpTGG1EKnhdJJkya5sGjB2m7xaa3CvXr12v06+x5ba6xNNDrqqKN2b7dueWsFbdSokevet252awG1Vmf7IyH/6ga21JN9/wpbe9TCbqKW06lTp7rnRPsAAAC8BtJomLR7wL/88ssF9lurX/6u+PyshdAmQ+Vf79KCmnUPW3e83Qo06t5773VLO1nojF3ayBbft0X4bSa93bs+trvb7vdu933f152PfLBbeFpLqLVqWri074OtGmAhc1/se2TB3FY6sNnx1u1vt2ft3r17wvBoYdVaVPe2RikAAECpiZSBoUOH2kyhQh+jR4/e/dpLL7000rx58wLH6N69e+S0005LePzHH388kpWVFdm6dav7+o033oikpaVFrrnmmoSvnz59utv/wAMPxG2//fbbI82aNYvk5uYmfN8999zj6v3hhx+K9fkBAABQuDT7H5UjAwYMcPezt65zG7+Yf/Z3Ijbr21oBhw4d6u7otD9sJry1Fv72t7/VjTfeGLfPWhVtbKYdf9iwYa6l11oYAQAAkGS3Di0qm01vXet2V6eisDGVt912mwuLNllnf7zwwgtuLOU111xTYJ8t5G/12PEBAABQuspdC6mNc7QljoyNmSzJzPzSDMg2BjPKJhLt7TanAAAASOJACgAAgLCUyy57AAAAhINACgAAAK8IpAAAAPCKQAoAAACvCKQAAADwikAKAAAArwikAAAA8IpACgAAAK8IpAAAAJBP/w/Q42cELlNDowAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array([phis[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sample 1, 0.2, 0.6, 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [0.60841192]\n",
      "Shapley Values + (E[f(X)]):  0.209\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.2, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAr0AAAFxCAYAAAB+5hCKAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAObpJREFUeJzt3Qd8FHX6x/FnUwi9l1CkSSgCgqgI6l8R9SycnAXwFAt270TvsBcEPRVPsZyo4Ckngl5R0ZPzUBFPsZ7lRKX30BNagBDSSDL/1/OLG7LJJuyGZCY7v8/79VqXnS3zZNzMfvPbZ34TcBzHEQAAAMDH4rwuAAAAAKhphF4AAAD4HqEXAAAAvkfoBQAAgO8RegEAAOB7hF4AAAD4HqEXAAAAvkfoBQAAgO8RegEAAOB7hF4AAAD4HqEXAAAAvkfo9ZmioiJ5+OGH5cgjj5TExERz/fjjj0vPnj3NfdF64YUXpGPHjpKXl1cj9QIAALgh4DiO48qa4IrnnntObrnlFrntttvk6KOPliZNmshVV10lTzzxhLmOVm5urnTu3Fnuvfde87puKCwslP/973+yevVqE7abN28uxx9/vHTo0KHS523fvl1WrVolaWlpsm/fPklKSpI2bdrIcccdJ02bNi153IEDB+Snn34yj9+xY4dZx6mnnio9evRw4acDAABeYKTXZ2bMmCFnnnmmTJ48WS6//HJZt26dFBQUyCWXXFKl16tbt65ceeWV8tRTT4lbfx8tWLBAFi1aJN26dZMTTzxR4uLi5P3335f09PRKn6dBNjU1Vdq1a2ee16tXLxOA3377bcnIyAgJ8gsXLpQ9e/aYQA0AAPyP0OsjGuY0+J1yyikhIXj48OEmvFbVqFGjZMOGDfLJJ59ITdPR17Vr18rAgQNl0KBBJrgOGzZMGjVqJN98802lz+3bt69ceumlctJJJ5l2jgEDBpifXcP6jz/+WPK4+vXry2WXXWYeq+sAAAD+R+j1iWuuuUbq1atnWgPGjx8vgUBA2rZta0ZMzzjjjHKP37JliwnCV199dcjyjz76yPQCjxs3rmTZsccea0ZE58yZU+M/h45Ma+0adoMSEhJM68G2bdskKyurwucmJydLfHx8yDJt72jWrJkZ1Q3Sx2jwBQAA9iD0+sTo0aPlhhtuMP9+5pln5NVXX5Ubb7zR3NYRz7Lat28v1157rbz22mtmFFetWLFCRo4cKeecc448+eSTIY/X1/jyyy8rrUEPlNPR5kguFbVK7Nq1ywTVOnXqhCxv3bp1yf3R0PXk5OQc1kg3AACIfQleF4DqMXToUPnPf/4jDRo0kLFjx5o+2Pvvv9/c16VLl7DPueeee2T69Ony2GOPyUMPPSS//OUvzUFrf//7383zS+vatasJ0pXRntt///vfEdWrPcbaslBWdnZ22FHY4LL9+/dLNNasWWOeo6PVAADAXoReH9FWht69e5cEVh0V1daAhg0bhn28jvZed9118tJLL5kDu3RE9NNPPzXBuSxtEdD7KwqlqkWLFnLuuedGVKu2YoSjB92VbVFQwWXavhEpbWn44osvzAwO3bt3j/h5AADAfwi9PqIHsZ111llRPef2228305xpYP78889NEA4n2I6g/bYV0SnCDjWt2KFoSA8XbIPLwgXicDSc64wP2iahPc1lR64BAIBdCL0+oaOamzZtMjMYlB551ZFTnbM2XCuBeuSRR8y1Pq6y6bt2795tRngrGqENBtNIT2KhPbbhgqiuI1wLg4ZYFW4Uuqz8/HwTePVaZ2+I5DkAAMDfCL0+oSO1Sk9IEaTTdimdu7b08iCdy1d7enWk94477jABWG+Ho69RekaFcHR2hcPt6dWgvnXrVhNYSx/MplOZBe+vjIb3Dz74QPbu3WumOtO2DAAAAEKvj1obVOlwO3jwYHOtZzcrG3rfeecdufvuu80BbDfddJM5+9nUqVPlvvvuC3vgm/b86gwRlamOnl49YE4D/PLly6Vfv34lI8grV640MzgE+5M13Or0ZTpiHJyZQWeP0IP5NHxrm4f28gIAAChOQ+wTekCafqW/efPmkOXa7qCXv/3tbyXLvv/+e3MCi4suukhmzZpllunoqgZOPWlD2dFefbyeylfn8D399NNr/GfR9ejIstat05fpqYV1pFdnl9C5h4P16qiyTqWmtamvvvpKlixZIh07dpQjjzyy3OumpKSU/Fsfp6PJ2jaxbNkyM2tFy5YtzX19+vQpN2UaAACIbYz0+oSOjoZrYdCTT0yYMMHMvKCjqxqKzzvvPDnmmGPMrA1BeupefawG3rKjvW+++aYJkjotmhuGDBliRnR19FmDqfYan3322SWBtyLBOXw3btxoLpWFXt1epU90sX79enMJPo7QCwCAvzDS63Pa26oj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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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.3729084\n",
      "Predicted Value (f(x))  [0.612]\n",
      "Shapley Values + (E[f(X)]):  0.192\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.2, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.37176499062253027\n",
      "Predicted Value (f(x))  [0.60841192]\n",
      "Shapley Values + (E[f(X)]):  0.712\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "mlp = MLPRegressor(random_state=1)\n",
    "\n",
    "mlp.fit(X_test1, y_test1)\n",
    "\n",
    "sample = np.array([1, 0.2, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = mlp, is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqQAAAFxCAYAAAClXbqoAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAOLZJREFUeJzt3Qd4VFX6x/E3JJAEQu9FSqRKFQHBRhELslhQZO1YF/+guyjo2sDesKyoYGEV0C0uWFhFZVFXRVFRQJHeQg2hhRZIAiHzf96TnZDJzCSZJM7JzPl+nmec5M7Mve9ch+HHaTfG4/F4BAAAALCkkq0DAwAAAIpACgAAAKsIpAAAALCKQAoAAACrCKQAAACwikAKAAAAqwikAAAAsIpACgAAAKsIpAAAALCKQAoAAACrCKQAAACwikAKAACiUm5urjz66KNy4oknSuXKlc39008/Le3btzePheqVV16R5s2bS3Z29m9Sr8tiPB6Px3YRAAAA5e2ll16S22+/Xe68807p0qWL1KxZU66//np55plnzH2osrKypGXLlnLvvfea/YbLsWPH5KeffpK1a9eaMFynTh3p2bOnNGvWrMjXffnll7JmzZqgj1911VVSrVo1OXr0qPzyyy+yc+dO2bVrlzlG3759pV27dn6vSU9Pl0WLFsnu3bvl8OHDEhcXJ7Vr15auXbtKixYtSv0eCaQAACAqnXLKKVKvXj2ZO3eu+f0vf/mLTJgwQXbs2CEJCQml2ufdd98t77zzjqSkpEhMTIyEw+effy4bNmyQzp07m1CtIVPD45AhQ6RRo0ZBX6fv88CBAz7bNPZ98803Ur16dRk2bJjZdvDgQfnHP/4hSUlJZvv27duDBtLNmzfLsmXLpGHDhlK1alXJyckx5yItLU3OPPNM6dChQ6neI4EUAABEHW3N1ID10EMPyX333We2aSuetpS+9dZbpd6vtg726NHDhMQBAwbIb23nzp3ywQcfyKmnnmrqVxoCZ82aJYmJiXLRRReFtD8Njv/+979NC+vJJ5+c3wKrraIaMLWF9P333w8aSAPR4Q/6Gq1r+PDhpXiXjCEFAABR5sYbbzRhTYPW/fffb1oyGzduLEuXLpWBAwf6PX/btm2mxfSGG27w2f7ZZ5+ZsadjxozxaXXVLvPZs2eH5b1s2LDB1F+w5VG7yTUsagtoRkZGSPtbt26duW/dunX+ttjYWBNGS6tSpUqm6//IkSOl30epXwkAAFAB6djIP/zhD+bnF154wbSIjhw50vzevXt3v+c3bdpUbrrpJnn77bdl06ZNZtuqVatMl/agQYPk2Wef9Xm+7uPbb78tUcuhttSW5OYJ0mG9Z88e001fpUoVn+0NGjTIf7yktJ7169eb7nbtmi8LHXeqdeuQAA36W7ZsMeextOLKVA0AAEAFo13p2qWurXajR482LXgPPPCAeaxVq1YBX3PPPffI1KlT5amnnpJHHnlEfve735kJTDq2Ul9fUHJycom6/bV7/KOPPipRzVdccUXAkKgThwK1Xnq3HTp0SEpKQ6N2zbdp00bK6vvvv5eVK1ean7UFV8/V6aefXur9EUgBAEDU0Va7jh075odJbUnUrm4dVxqItu7dfPPN8vrrr8vixYslMzNTvvrqKxNqC9NZ5fp4sLDoVbduXbngggtKVG9iYmLA7TouU7vUC/Nu02EJoXTX6/nQQF1WOsFKw72eAx1WoC28odRSGIEUAABEHV3G6LzzzgvpNWPHjjVLRWmYnT9/ftAuaG/3enGz7OPj44tdmqk4cXFxAYOed1ugsBqsi12HI2g9pV1hoKBatWqZm2rbtq3MmTPHrGZw8cUXl2r1AQIpAACIKvv27TPd09qKV7C1UlsbdYmjYOMnH3vsMXOvz9OJS8Hs3bvXtIwGa9X08s5eL4mEhAS/oQFKjxOoW15bJlWgFtxANm7caN5XwclM5UlbXTXE79+/Pz+ohoJACgAAooq2cCpd4slLr86kdM3Mgtu9Jk6caMaQagvpuHHjTDjV3wPRfZRkvU2dBV/WMaR169aV1NRUM4O94MQmXQ7K+3hJu+t1xQAd6/lb0LCrSjvTnkAKAACirrteFQyeffr0Mfd6xaPCgVTX+fzzn/9sJjONGjXKXBFp8uTJZv3SQJOgdIypzuQvTnmMIU1OTjYBWycQedch1ZbX1atXm5n23jGxGgh1CShtaS3cJa/jXbdu3WpaR3UIQFnovgrXqrP39Zzp8AEdX1saBFIAABBVNMDp+M+C3e4a7Dp16mTWFi243qgudK/hUm/eBfTvuusuc936QK2k+ny9fGZJFqQvjzGkDRo0MLUvXLjQhEHvlZp06IEuXl+wxVRbY3VJKl24vyBd6knHvRbVXa9XX9LWTe9QAB1v6h0qoOfN2zqr3fL6PF3XVYcL6PO19VWHSfTu3du0wpYGgRQAAERdIA3ULa9BdPz48fmtfNpqqJff1CsW6ex6ryZNmpjnahgt3Eo6c+ZMad68eViu0uTVr18/0xKqrZAaBjVon3/++SYUloQGRn2/Ra0Tques4CL7OuZUb0qXifIGUg3H2jq7YsUKsw6pbtfLs/bq1atMwwG4dCgAAHCCTrjRQPX000+bqzmFSicoaejS7v0//vGPv0mNruJKTQAAwAna3a3d8TqBScc9hurNN980XdLeqz6h/NBCCgAAAKtoIQUAAIBVBFIAAABYRSAFAACAVQRSAAAAWEUgBQAAgFUEUgAA4KwDBw6Yhef1HvYQSAEAgLM0iH711VcEUssIpAAAALCKQAoAAACrCKQAAACwikAKAACcVaNGDenTp4+5hz1cyx4AADht1apV0r59e9tlOI1ACgAAnJaTkyNxcXG2y3AaXfYAAMBpy5Yts12C8wikAAAAsIpACgAAnNaoUSPbJTiPQAoAAJxWuXJl2yU4j0AKAACctmXLFtslOI9ACgAAAKtY9gkAADgtMzNTEhMTbZfhNFpIAQCA07Zv3267BOdF1yqwmdkiP6y1XQUAAKhIalYVOTk56MMHDhwIazmI9kB6+19Fpn5muwoAAFCR1EgU2T1dpHLg2BMfHx/2khDNXfZpe21XAAAAKpoDmSJfrwj6cLt27cJaDqI9kAIAABQWFysye2HQh5cuXRrWcuCPQAoAAKJbzjGRWd+JsLBQhUUgBQAA0W/7XpGfUwI+1KBBg7CXA18EUgAAEP1iKwXttmcNUvsIpAAAIPody83rtg9g06ZNYS8HvgikAADADcu3iGzcabsKBEAgBQAAbqgUE7Dbvk2bNlbKwXEEUgAA4AadZP/e936bd+3aZaUcHEcgBQAAbtBln75ZKZJ+0Gfzvn37rJWEPARSAADgjlyPyJxFPpsqV65srRzkIZACAAC3ln96/wefTR07drRWDvIQSAEAgFvLP32yRCTrSP6mX375xWpJIJACAADXaBj9/Pj16z1cUtQ6AikAAHBLXKzIB8eXf6pXr57VckAgBQAArsk5ljeONDfX/Fq9enXbFTmPQAoAANyz56DID2vNjykpKbarcR6BFAAAuCeuksgHvrPtYQ+BFEDkq1lV5NWRIjvfFMn4u8gXD4mcnFyy1940UOTLR0TS3hDJekdkwxSRN0aLtKhf9OtOby/ieS/vVpfuPiDi5OSKzPrO/HjiiSfarsZ5cbYLAIAyiYkRmXO/SNcWIhNni+w+IPJ/54t8+bDIKeNE1m0v+vUaXFN2iPz7R5G9GSKtGorcPFDkd6eIdL1DZPvewMd88SaRjEyRpMTf7K0B+I1t2CGyaqvsrZrLOFJXWkhjYmJKfFu2bFm4ygJQ0f33YZE3Rwd//LI+ea2VI14SefhfIpM/Fek3Pm+twYeGF7//Ua+JXP+SyHP/FnnzC5Hx/xAZ/JhI/Zoi1/YL/JpbzhE5oZ7I1M9L/74A2FcpRmT2QklPT7ddifPC1kI6ceJEn9+//vpr+fDDD2XIkCFy1lln+TzWrFmzcJUFINJpIE3bK/Le98e3aSvpvxaIXH2WSJU4kSM5oe1z4868+1rV/B+rnSTy6JUi4/8p0qBmGYsHYP0you9+L7EXtLFdifPCFkjHjh3r8/vRo0dNIO3Tp4/fYwBQYie3Elm8QVe29t2+cK3IH84VadtEZNnm4vdTJ0kkNlakeT2R8Zfnbfv8V//nPXKFSNo+kVf/I/LAsHJ6EwCs+WmddK5PQ5htTGoCENka1w48ztO7rUmdku1n29S8SVE/TRQ5rZ3IbVNFPit0OcHOLfJC7h1v5q9fCCDCeUS2TvnAdhXOY1ITgIp19RSdMV9Q5TiR+Mr+M9nTM/JaRROriGQH6JL3XqdaHy+JQY+KJFQW6dBM5Oq+ItXi/Z8z6UaRTxaLzOO610DUqBQjNT5fKfKQ7ULcFtEtpDoIOTs7O//3HL3yAoDIpZOTdk/3vem2K870365d6yrziEh8gH9bJ1Q5/nhJfLlM5NMlIs9/KDJsosiEy0VGDTr++OWn57Wc3jmtPN4pgIoi1yOJ2/bJkSNHZM+ePT4Pbd++vcjf09LSxFNguFDhXJKRkSEHDx7M/93lY0R1C2mdOr5dcXHaugIgcv2yUWTgg77bnh2RN2lJl3QqSMdxervmtdu+MO+21PTSLQWzJEXkqrNEXv4kb9vEa0Vmfpc3Qcq7Rql30pPOuNfJU4GGDgCo2OIqieeiXlKlShWpW7euz0ONGzcu8vdGjRoVmUuSkpJ8fnf5GFEdSAFEmX2HRD5f6rtN1wbVoFd4u9fPG0XO7JC3NmjBiU2nthE5lCWyJrV0tWhXvw4V8GpeX+QqvfmuCmIseVbk5xSRk+8s3bEA2JOTK5u6NRDm2dtFIAUQ2fRKK8NOExnaW+TdvKuumPGmuu3Dn3yXfEpueLwFVMVWEqmemBeEC+rZOm8C09/nH9928ZP+x/79GXm3a14Q2erbfQUgQtRJkkOdmWVvG4EUQOQH0u9W5y2ef1Izkd0H867UpGFzwj99n/v5/2YttBqZd5+UILLlNZF3vhVZvkXkULZI5+Yi1w8Q2X9Y5JGZx187e6H/sbu1yrvXiU57jo+vAhBB17O/+FRp1ZpLh9pGIAUQ2XT5pQseFZl4ncjtg/O62n9cJzLixeK76w8fybvaUv9OeQvs62tT94r84xuRR2eKbNoVrncBwNb17C/uZSbs1KzJhS5sIpACqNj6jy/+OdrlfvPkvFtRvC2jXkdzRMa8UfraHnon7wYgMulSbwO7yO7VK7lKpGURvewTAABAqeiwnvNOFkmMlxidFAmrYjwFF56KdEMeE/loke0qAABAJJh+m8i1/W1XAVpIAQCAkyrFiAzuYX5cvny57WqcRyAFAABu0S7609rnX5L46NGjtityHoEUAAC459Le+T/WqlXLaikgkAIAANfo9JmLeuX/Wr/+/y4HDGsIpAAAwC16EY1W/7tym4isXbvWajkgkAIAANeWe7q0j+0qUAiBFAAAuONY3tWZCmrRooW1cpCHQAoAANzRqLbIyck+mzIzM62VgzwEUgAA4Ia4WJGhp+Yt+1TAzp07rZWEPARSAADghpxjIpecarsKBEAgBQAAbkhKEOnb0W9zly5drJSD4wikAAAg+sVVEhnSQ6RynN9Dq1evtlISjiOQAgCA6Jejs+sDd9dnZ2eHvRz4IpACAAA3WkjPPzngQzVq1Ah7OfBFIAUAANGtUoxI/84iNaoGfLhx48ZhLwm+CKQAACD6r10/tHfQhxlDah+BFAAARDePiFzY03YVKIL/VLNI9sffiRw5ZrsKAABQkbSsL9KkTtCHTzjhhLCWA38xHo+2YwMAALgpLS1NGjVqZLsMp9FlDwAAxPVACrsIpAAAALCKLnsAAOC0nJwciYuLrmk1kYYWUgAA4LR169bZLsF5BFIAAOC0rKws2yU4j0AKAACclpSUZLsE5zGGFAAAOC07O1vi4+Ntl+E0WkgBAIDTVq5cabsE5xFIAQAAYBWBFAAAOK1p06a2S3AegRQAADiN6TT2RVcgXbxeJGZo3j0AAEAJpKam2i7BeVEWSDf43gMAAKDCi65ACgAAEKKTTjrJdgnOI5ACAACnbdq0yXYJziOQAgAApx06dMh2Cc4jkAIAAKdVrVrVdgnOI5ACAACntWrVynYJziOQAgAApy1fvtx2Cc4jkAIAAMAqAikAAHBa48aNbZfgPAIpAABwWmxsrO0SnEcgBQAATtu6davtEpxHIAUAAIBVBFIAAOC09u3b2y7BeQRSAADgtG3bttkuwXkEUgAA4LSDBw/aLsF5BFIAAOC0hIQE2yU4j0AKAACc1qZNG9slOI9AGop9h0RumSJSf4RItStE+o8XWbzedlUAAKAMfv31V9slOI9AWlK5uSKDHxX5+3yR0YNEnr5WZOd+kX7jRdam2q4OAAAgYoU9kB44cEDuuusu6dixoyQlJZmrI9SsWVN69uwpTzzxhBw5ckSs6PeAyIgXgz8+6zuRBatFpo0WmTBcZNQgkS8fFomtJDLhnXBWCgAAylHDhg1tl+C8uHAebMmSJTJ48GDZvn27dOvWTW6++WapX7++7NixQ77++mu59957Zfny5fL2229LhaOBtGEtkaG9j2+rX1Pk8tNE3v5aJPuoSHxlmxUCAIBSiI+Pt12C8+LCuaTC7373OxM+J0+eLLfeeqvfc+bOnSvffPONVEhLUkS6J4tUKtSo3KuNyGvzRNakinRuYas6AABQSps3b5Y6derYLsNpYQukjz/+uKSmpso111wTMIyq8847z9wqpO17Rc46yX9749p596npBFIAAICKHEg//PBDc3/nnXeKdUdzRPYf9t+m3e67D/hur5OU1yqaeUQkPsDpSqiSd6+PAwCAiNO2bVvbJTgvbIF048aNkpiYKF27dhXrvl2Vt2RTYTpp6Z+FhgykvCLSsoFIYhWR7Bz/12T9L4jq4wAAIOKkpaVJcnKy7TKcFrZZ9pmZmeV+JYT09HTJzs7O/z0r6/jPSmfs79mzx2ebTqiSri1F5k0wtz3/vC3v5y4tRM7tJunv3C6e/4zPfzy9iifvGNo1v32vZGRk+FxiLGfLrrwfmtTxPUbhYxb64Hs8nqDvo/Axgr4PjsExOAbH4Bgcg2OU+Ri6AlA0vI+KfIzixHgKVvAb0iWecnNz5fDhQl3l5WnqPJGbp4i8fqvITeeEvuyTtoROuy3w48MmisxfKZI61Xdiky6U/7evRdJnMMseAIAItGLFCjnppADzRBB9LaQtW7Y0raS//PKLRKTL+ojs2Cfy3vfHt+l405kLRIb0IIwCABChOnToYLsE54UtkA4ZMsTcP//88xKxgbR3W5HrXxJ5+F8ikz/Ja1U9livy0O9tVwcAAEopYhvLokjYAuk999wjTZo0MYvev/baawGf89lnn8kDDzwgFVJsrMjH94sMP11k0hyRcTNE6tUQ+eIhkXZNbVcHAAAQscI2hrTwlZq6d+8uffv2lXr16snOnTvNgviLFy+Wq6++WmbMmBH+MaQAAMBJ27Ztk6ZNaVxy5tKhJ598sqxatUoeeeQRmTNnjrz66quSlZVlJjy1a9dOnnzySRkzZkw4SwIAAI6rVq2a7RKcF9ZAqmrUqCETJ040NwAAANt0rfRu3brZLsNpYRtDCgAAAARCIAUAAE5r3bq17RKcRyAFAABO2717t+0SnEcgBQAATtu3b5/tEpxHIAUAAE6Liwv7HG8UQiAFAABO69Spk+0SnEcgBQAATuPSofYRSAEAgNPCeNFKBEEgBQAATqtbt67tEpxHIAUAAE7Tq0jCLgIpAABwWkpKiu0SnEcgBQAAgFUEUgAA4LTk5GTbJTiPQAoAAJzGlZrsI5ACAACnpaen2y7BeQRSAADgtEqViEO28X8AAAA4rUuXLrZLcF50BdLuyb73AAAAxfj1119tl+C8OIkm3U8U8bxnuwoAABBBjh07ZrsE50VXCykAAECIateubbsE5xFIAQCA07iWvX0EUgAA4LR169bZLsF5BFIAAABYRSAFAABOa9mype0SnEcgBQAATsvIyLBdgvMIpAAAwGm7d++2XYLzCKQAAACwKsbj8XjslgAAAACX0UIKAACctnz5ctslOI9ACgAAnHb06FHbJTgvugLp4vUiMUPz7gEAAEqgZs2atktwXpQF0g2+9wAAAMVo2LCh7RKcF12BFAAAIERr1qyxXYLzCKQAAACwikAKAACc1rx5c9slOI9ACgAAnJaVlWW7BOcRSAEAgNN27txpuwTnEUgBAABgFYEUAAA4rXPnzrZLcB6BFAAAOI1ln+wjkAIAAKdlZ2fbLsF5BFIAAOC06tWr2y7BeQRSAADgtKZNm9ouwXkEUgAA4LRVq1bZLsF5BFIAAABYRSAFAABOa9asme0SnEcgBQAATsvJybFdgvMIpAAAwGlpaWm2S3AegRQAAABWEUhDse+QyC1TROqPEKl2hUj/8SKL19uuCgAAlEGnTp1sl+A8AmlJ5eaKDH5U5O/zRUYPEnn6WpGd+0X6jRdZm2q7OgAAUErr19O4FHGBdNasWRITE2Nul156acDnbNq0SeLi4sxzOnfunL/9008/lWHDhkmHDh0kISHBPP7EE09IhdDvAZERLwZ/fNZ3IgtWi0wbLTJhuMioQSJfPiwSW0lkwjvhrBQAAJSjzMxM2yU4r9QtpJUrV5a5c+fK4cOH/R6bNGmSeDweqVTJd/fvvfeevPvuu5KRkSGtWrWSiKKBtGEtkaG9j2+rX1Pk8tNEZi8UyT5qszoAAFBK1apVs12C80odSM844ww5dOiQTJ061e+xmTNnSq9evUxoLeiee+6R9PR02bJli4wePVoiypIUke7JIoVCtvRqI3I4W2QN3fYAAESi5s2b2y7BeaUOpN26dZMWLVrIjBkzfLZrt7wGzuuvv97vNdoqWqtWLYlI2/eKNK7tv927LTU97CUBAICyW7lype0SnFemSU3Dhw+XxYsXy9q1a/O3TZkyRWrUqCEjRoyQCutojsjuA7433abd7oW362QmlXlEJD7Of18JVY4/DgAAgPAG0ttvv11iY2PlhRdeML8fPHhQ5s2bJ4MHD5YqVf4X1H5D2v2fnZ2d/3tW1vGf1ZEjR2TPnj0+27Zv3y7y7aq8pZsK3nTC0j+/8du+b+m6vGMkVhHJzjHjX/V9eh09+L8xtPp4wWMUPmahBXh1jG2w91H4GEHfB8fgGByDY3AMjsExynyMJk2aRMX7qMjHKE6Mp2AFJZxlrzPlx4wZI88995ycddZZpoVUD/zss8/K2LFjZcGCBdKnTx8zk75Nmzby66+/+u3n5ZdfNuNIH3/8cTO2tFxMnSdy8xSR128Vuemc4M/bmyGyqNASD3dOE2lUW2TcRb7bz+iQ1wraZpRIm8YiH9/v+/hfPxO5abLI0udFOrcon/cBAADCZufOndKgQQPbZTgtQB90aG644QYzXnT27NlmPKkGUA2jFVrtJJGBXf236XjQwtu9urUUmb8yrwu/4MSmH9aKVI0Xadvkt60ZAAD8JlJTUwmkkb4w/lVXXSW1a9eWBx980LSEXnnllRKVLusjsmOfyHvfH9+mY0xnLhAZ0kMk3ndFAQAAAISphVSXdrrwwgtl+vTpZtxoxC3nFEog7d1W5PqXRFZsFalXXWTypyLHckUe+r3t6gAAQCnpBXsQ4YFU3X333SaMtm7dWurVqydRKTY2b/zouOkik+bkzarv2Vpk2m0i7Zrarg4AAJTS5s2bzZBDRHgg1X9ZvPbaa8U+b/ny5WYyk1q1apW5nzNnjlm3VI0aNUo6duwoVnz5SPHP0XGmU0fl3QAAQFTQC/0gCgJpKAvP6jqlBX377bfmpgYMGGAvkAIAACclJibaLsF5IQfSyy67zGetqqJkZWWV+rUAAADhcOKJJ9ouwXllnmUPAAAQyZYtW2a7BOcRSAEAAGAVgRQAADitUaNGtktwHoEUAAA4LS4urHO8EQCBFAAAOG3r1q22S3AegRQAAABWEUgBAIDT2rdvb7sE5xFIAQCA07Zt22a7BOcRSAEAgNMOHjxouwTnEUgBAIDT4uPjbZfgPAIpAABwWtu2bW2X4DwCKQAAcNqvv/5quwTnEUgBAABgFYEUAAA4rUGDBrZLcB6BFAAAOC0hIcF2Cc4jkAIAAKdt3rzZdgnOI5ACAADAqugKpN2Tfe8BAACKwbJP9sV4PB6P7SIAAABsSUlJkVatWtkuw2nR1UIKAAAQov3799suwXkEUgAA4LTKlSvbLsF5dNkDAADAKlpIAQCA037++WfbJTiPQAoAAACrCKQAAMBp9erVs12C8wikAADAaUlJSbZLcF7UBdK0tDTbJQAAgAiyceNG2yU4j0AKAAAAq6Ju2aeMjAya3gEAQImRHeyLuhbSPXv22C4BAABEELKDfdEVSBevlxYtx5h7AACAkti7d6/tEpwXZYF0g+89AABAMWJjY22X4LzoCqQAAAAh6ty5s+0SnEcgBQAATlu6dKntEpxHIAUAAE7Lzc21XYLzCKQAAMBpderUsV2C8wikAADAabVq1bJdgvMIpAAAwGkbNrA6j20EUgAAAFhFIAUAAE5r1aqV7RKcRyAFAABOO3DggO0SnEcgBQAATuNa9vYRSAEAgNNiYmJsl+A8AikAAHBa165dbZfgPAIpAABw2rJly2yX4DwCKQAAcFpOTo7tEpxHIAUAAE7jSk32EUgBAIDT6tWrZ7sE5xFIQ7HvkMgtU0TqjxCpdoVI//Eii9fbrgoAAJTBunXrbJfgPAJpSeXmigx+VOTv80VGDxJ5+lqRnftF+o0XWZtquzoAAAB3AumsWbPMel16u/TSSwM+Z9OmTRIXF2ee07lzZ7MtNzdXnnnmGenfv780atRI4uPjTRN579695ZNPPhHr+j0gMuLF4I/P+k5kwWqRaaNFJgwXGTVI5MuHRWIriUx4J5yVAgCActSyZUvbJTiv1C2klStXlrlz58rhw4f9Hps0aZJ4PB6pVOn47vV548aNk40bN8oFF1wgDzzwgFx++eWyZs0aGTx4sAmrFZoG0oa1RIb2Pr6tfk2Ry08Tmb1QJPuozeoAAEApHTp0yHYJzit1ID3jjDPM/8CpU6f6PTZz5kzp1auXCa1eVapUMa2rKSkp8sYbb8j9998vkydPlkWLFkm1atXkkUcekWPHjkmFtSRFpHuySIGQbfRqI3I4W2QN3fYAAESiXbt22S7BeaUOpN26dZMWLVrIjBkzfLZ/+umnsmXLFrn++ut9tmsgDdTF36pVK3OFhAMHDpiu/gpr+16RxrX9t3u3paaHvSQAAABxfVLT8OHDZfHixbJ27dr8bVOmTJEaNWrIiBEjSryfnTt3mjGnDRo0kLA4miOy+4DvTbdpt3vh7TqZSWUeEYmP899XQpXjjwMAgIjDpUMjPJDefvvtEhsbKy+88IL5/eDBgzJv3jwzJlRbREti2rRpJtDqZKekpCQJi29X5S3dVPCmE5b++Y3/9s27816TWEUkO8CVHLKOHH8cAABEnJUrV9ouwXllCqRNmzaVPn36yLvvvmt+f+211yQzM1Nuu+22Er1eW1dHjx4ttWvXDjgWtTjp6emSnZ2d/3tW1vGf1ZEjR2TPnj0+27Zv3y7StaXIvAnmtueft+X93KWFyLndJP2d28Xzn/H5j6dX8eQdQ7vmt++VjIwME7y9crb8b9xJkzq+xyh8zALS0tLMpK9g76PwMYK+D47BMTgGx+AYHINjlPkYuv9oeB8V+RjFifEUrKAEdGLSsGHDZMyYMfLcc8+ZFk4dL/rBBx/I+PHjTSDVmfMqISFB2rRpI7/++qvffpYuXSoDBgwwb1iXfdJJUmU2dZ7IzVNEXr9V5KZzQl/2qWUDkWlBwvSwiSLzV4qkTvWd2KQL5f/ta5H0GSLxxydxAQCAyLBhwwZJTk62XYbTyrww/lVXXWVaOB988EETPK+88spiX7Ns2TI5++yzJSsrS2bPnl0+YfS3dlkfkR37RN77/vg2HWM6c4HIkB6EUQAAIpSujw67AszSCY0u7XThhRfK9OnTzbhR7YIvLozqeFFdl1TDqLaSRgQNpL3bilz/ksiKrSL1qotM/lTkWK7IQ7+3XR0AACgl7dnV1YMQwYFU3X333SaMtm7d2lx9KZjly5ebAKrrl77//vsycOBAiRixsSIf3y8ybrrIpDl5s+p7ts7r4m/X1HZ1AAAAbgfSDh06mAlNRdHBr9oyqovPXnbZZaZ7v/DYUl2nVNclteLLR4p/Tu0kkamj8m4AACAqNG/e3HYJziuXQFoSOtvKeyUEnRilt0DXkrUWSAEAgJMKzihHhARSbd0s6cR8nbTk1alTpxK/DgAAIFx27NghjRs3tl2G08o8yx4AAAAoCwIpAABwWufOnW2X4DwCKQAAcJpewhx2EUgBAIDTCs55gR0EUgAA4LTq1avbLsF5BFIAAOC0pk25wI1tBFIAAOC0VatW2S7BeQRSAAAAWEUgBQAATmvWrJntEpxHIAUAAE47duyY7RKcRyAFAABO2759u+0SnEcgBQAAgFUEUgAA4LSOHTvaLsF5BFIAAOC0lJQU2yU4j0AKAACcdvjwYdslOI9ACgAAnFatWjXbJTiPQAoAAJzWokUL2yU4L7oCafdk33sAAIBirFixwnYJzouyQHqi/LxkvLkHAABAZIiuQCoiTZo0sV0CAACIIGQH+6IukMbExNguAQAARBCyg31RF0i3bdtmuwQAABBByA72RV0gBQAAQGSJ8Xg8Hoki2dnZEh8fb7sMAAAQIcgO9kVdC+mWLVtslwAAACII2cG+qAukGRkZtksAAAARhOxgX9QF0oSEBNslAACACEJ2sC/qxpDm5ORIXFyc7TIAAECEIDvYF3UtpMuWLbNdAgAAiCBkB/si9p8Dx44dkzVr1vht37BhAzPlAABAiZEdfntt27aV2NjY6AukGkZPOukk22UAAACgGCtWrJAOHTpE3xjSQC2kaWlpMmDAAPniiy+kUaNGUpFn8/Xq1UsWLlwoSUlJtsuJGJy30HHOSofzFjrOWelw3kLHOYvM81ZcC2nEBtJAtm7dKieccIJZT6xZs2ZSUR04cEBq1qwp+/fvlxo1atguJ2Jw3kLHOSsdzlvoOGelw3kLHecsOs9b1E1qAgAAQGQhkAIAAMCqqAqk2gTdt2/fCtkUXZDO5JswYQIz+kLEeQsd56x0OG+h45yVDuctdJyz6DxvUTWGFAAAAJEnqlpIAQAAEHkIpAAAALCKQAoAAACrCKQAAACwikBaCrm5ufL8889L+/btJSEhwSzGf+edd8qhQ4dC3tfhw4clOTlZYmJiZPTo0QGfs3r1arn44ouldu3aUq1aNTnzzDPN1agiSTjP2YMPPmgeC3R75plnxKXzFuw8BLtKB5+10M4ZnzVf6enpMnbsWGndurXZR/369aV///4yf/58v+f+8MMPMnDgQKlevbpZGeX888+Xn3/+WSJJOM/ZiBEjgn7WZs2aJa6ct6L+zOmtcuXKfq9x/XvtwRDPma3vtYi9lr1NY8aMkUmTJskll1xiPhArV640vy9ZskQ+++wzqVSp5Dl//PjxsmvXrqCPr1+/Xk477TSJi4uTu+66y1xl4fXXX5fzzjtPPvnkE/OFHgnCec689A9vvXr1fLadcsopEknK47zpl+8tt9zisy3QlzaftdDPmRefNZFNmzZJv379zOUJb7zxRnOZQL0izNKlS2Xbtm0+z/3+++/Nc5s2bSoPP/yw2fbSSy+Z875gwQLp3LmzRIJwnjOvt956y2+bXg4ykpTlvA0dOtSE98L0nE2cOFGGDBnis53vNQn5nFn7XtNln1Byy5Yt88TExHiGDh3qs33SpEm6fJbnb3/7W4n3tWjRIk9sbKzn2WefNa8dNWqU33OGDRvmqVSpkmfJkiX52w4ePOhp3ry5p23btp7c3FxPRRfuczZhwgTzWEpKiieSlcd50+ddd911JToen7XQzxmftePOOOMMT7NmzTypqanFPrdnz56e6tWre7Zu3Zq/TX/Wbeecc44nEoT7nOlnMhr+yi7Pvw8KuuWWW8zrP/roI5/tfK+Ffs5sfa9F/qc7zO677z7zP+rrr7/22Z6ZmempWrWqZ9CgQSXaT05Ojqd79+6ewYMHm//pgcJVRkaGJz4+3jNgwAC/1z/88MPmNT/88IOnogvnOSv8h2n//v2eo0ePeiJReZw3b7jKzs42X8LB8FkL/ZwpPmt5vvrqK/N6/QtSHTlyxHPo0KGAz127dq157g033OD3mG7Tv3i3b9/uqejCec4KBlINUPpZO3bsmCcSldffB4W/v2rUqGHCvf49UXA732uhnTOb32uMIQ3Rjz/+aJrGC3eR6JiObt26mcdLQpvCV61aZbqpgtHm9OzsbOnTp4/fY717986vp6IL5zkrqEuXLqZ7Ro+jXTbaPRNJyuu86fiyqlWrmrF6DRo0kNtuu810CxbEZy30c1aQ65+1jz/+2Nw3b97cdP8lJiaasXraBf3222/7HUsF+6zpvwkWLVokFV04z1lB+jnTmz7/nHPOMWNxI0l5/RktaObMmXLgwAEzzjY2NjZ/O99roZ8zm99rBNIQpaammjEVgS69peOhdu/eLUeOHClyHykpKebyXToWsmXLlkUey7vfQMdSwcYZuXrOVK1atcz4vxdffFFmz54tTzzxhBmrNXjwYJk2bZpEivI4b/oFpgPUNWBNnz5dBgwYkD9WT8etFTyWd7+BjuXSZ62k50zxWTs+aUTdfPPNZpKOnrc33nhDqlSpItdcc428+eabPsfy7jfQsVz5rIVyzlSjRo3MOMIpU6bI+++/L/fee6/89NNP5nOpYwgjRXn8GS3sr3/9q5lwc8MNN/gdy7vfQMdy5bMWyjmz+b3GpKZSzPAOdh1Y/VeE9zn6pRLMyJEjzSzxO+64o9hjqUDHK3isii6c50z96U9/8tumf+g6depkvtAvu+yyoLPMo+28FW49ufbaa82/eu+77z554YUXzL13P4rPWsnPmeKzlufgwYPmXluU//vf/+Y/T2c2659bDU/XXXedaeXhsxb6OVNPPvmkz+v1eVdeeaVpIbv11ltl7dq1EgnK489o4WD/zTffyNlnny2tWrXyO5Zy/bMWyjmz+b1GC2mItBtPuwACycrKyn9OMNoVM2/ePPOv3KJm7RbcT6DjleRYLp6zYOrWrWtC7b59+8ws3khQ1vMWzLhx48wX15w5c3yOpVz/rIVyzoJx8bOm3cfqiiuu8PlLUZfZufDCCyUtLS2/RZDPWujnLJg2bdrI5ZdfLuvWrZM1a9ZIJCjvP6Pa0qduuummgMdSrn/WQjlnNr/XCKQhatKkiWkeD/Th0KZ/bVYP9q8UfY228F1wwQWm+0W/RPSmTeFKx6jp7/o/3Hss734DHStYV4TL56wo3q5+rSUSlOW8FUVDvXffBY/l3W+gY7nwWQv1nBXFtc9as2bNzL3+GS2scePG5n7v3r35x/LuN9CxXPmshXLOiuLaZ62gnJwcmTFjhglLuhxSoGN59xvoWK581kI5ZzY/awTSEPXs2dMsULtw4UK/f6Xoos49evQI+trMzEyzfqa2sui/bL03XYfO2xKov0+dOtX8rmvxaTP9d99957cvXcdPFXU8F89ZUbxdWg0bNpRIUJbzVhR9/datW33OA5+10M9ZUVz7rHknW+g5Ksy7TSeHeY+lgn3WdFxbJKzhGs5zVhTXPmsFffjhh7Jjxw65+uqrA3Zp870W+jmz+lkLy1z+KLJ06dIi1wN766238retW7fOs3LlyvzfdVmPmTNn+t0mT55sXnv++eeb31evXp3/mssuu8ysofbzzz/7raHWpk2biFhDLZznTJen2Ldvn18Nmzdv9tSpU8dTt25dz+HDhz2RoCznTe3evTvgfseOHWte/9RTT/lsd/2zFuo547N2XHp6ullDtGnTpj5LZen6mtWqVTPrPRbUo0cP8/xt27blb9OfddvZZ5/tiQThPGe6RI8u8VPY4sWLPVWqVPF06NDBEynKet4K0iUA9TW6z2D4XgvtnNn8XiOQlsLo0aPN/9BLLrnE8/rrr3vuuOMOT1xcnKdv374+a8O1aNGiRAsZF7Wmpq7ZV7t2bU+DBg08TzzxhOfll1/2dOvWzSwO/+mnn3oiRbjO2d69ez21atXyjBgxwoSH1157zXPnnXd6atasac7Zv/71L08kKct5+9Of/uTp3bu355577vFMmTLFM3HiRE///v3N80499VS/LxU+a6GdMz5rvl599VWzvWPHjubCFfoZ0r/0K1eu7Jk7d67Pc7/99lsTpJKTkz3PP/+8uenPGsQKBoeKLlznTBd1b9SokWfkyJHmea+88orn1ltvNWtsJiYmeubPn++JJOXx94H+A0b/nPXq1avIY/G9Fto5s/m9RiAtBV1E9plnnjH/gtUv1SZNmnjGjBnjt4h2eQRStWLFCs+FF15oPhD65XP66ad75s2b54kk4TpnWVlZnhtvvNHTqVMn84dK/8DqF/mll14aEQsgl+d5++CDDzznnnuueY3+xaULKHft2tXz2GOPBWxtUa5/1kI5Z3zW/L377rsmuOt5S0pKMldd+uabbwI+d8GCBWbBcg2h+lw973oltkgSrnOmFwq4+uqrPe3atTOtqvpZO+GEEzzXXnttka1h0Xze9M+kPqaBqTiuf6+Fcs5sfq/F6H9+m8EAAAAAQPGY1AQAAACrCKQAAACwikAKAAAAqwikAAAAsIpACgAAAKsIpAAAALCKQAoAAACrCKQAAACwKk4qmBEjRsj06dPNzx07dpRly5b5PJ6bmyuPP/64vPnmm7J582Zp3ry5rF+/Xp5++ml54403ZMWKFVKpUug5+5VXXjH7Xbt2rcTHx/s89pe//EXGjBmT//uuXbukXr16Ek7Hjh2Tn376ydSXnZ0tderUkZ49e0qzZs2KfW16erosWrRIdu/eLYcPH5a4uDipXbu2dO3aVVq0aJH/vC+//FLWrFkTdD9XXXWVVKtWLaR9AgAAVKgW0rlz50pMTEzQ24wZM8zzNOy99dZb8uSTT/rtY/LkyTJ+/HgZOnSoCaCvvvqqHDhwQJ566im5++67/cLoQw89ZLatXLnSb1833HCDxMbGypw5c0wQPnLkiNlfYeeff76p55JLLhFbNCwuXbpUWrduLaeddpp5T5988omkpaUV+9qMjAw5evSotG3b1ry2e/fu+f8/Cp6XDh06SP/+/X1u/fr1yw+b3jAayj4BAACKE9ZLh2orpobGSZMmmYBT2HnnnSfjxo0z4Wvjxo0B93HKKaeYwKrBp2AL5oQJE2THjh2SkJDg8/ydO3eaFrtrr73WJ2y++OKLcvvtt8ujjz4q9913n9mmtb3zzjuSkpJiAnJhDz74oAm44W4h1ffwwQcfyKmnnmpaIFVOTo7MmjVLEhMT5aKLLgp5n9rS/P7775v9DB8+POjzNPD++9//Nq2xJ598crnsEwAAwFqXvbbw1axZU0aPHh0w8BUnKytLfvnlFxMKC9Lu+wsvvNAvjKoGDRqYrmZt4XzsscdMkPzqq6/kjjvukEsvvTQ/jKrLL7/chOb//ve/MmDAAKkoNmzYYM6XtmB6aatlu3bt5McffzStlUlJSSHtU1tYtcVTw3VR1q1bZ+61Zba89gkAAGCty17DpLaylSaM3njjjaY1UMdS3n///WYfffr0Ma2ZGnQHDhwY9LU6/jMzM9OME92yZYsJnu3bt5dp06b5tb7q2MzZs2dLedFWQw3SJbkFa6zes2ePCfJVqlTxC9vex0tCu9j1ODrEQc+ZnoumTZsWWbuOz23YsKFUr169XPYJAABgrYVUx2euXr1azjjjDDMRpjANXJUrVw76em3l1Me12/2FF14wwVG74hcsWGAe945hDEQnR5177rny8ssvm65vDVF6H6hVUffz7bffSnnRLu+PPvqoRM+94oorAgY/nTRUtWpVv+3ebYcOHSrR/r///vv88Z0a6Fu2bCmnn3560OdruNQJVG3atCm3fQIAAFgLpDr7XYOgtlLqrTANqzpBJhjtQv/8889Nl7B2+XsnLz3wwAPmvlWrVkUeX7vodXKSjsf8+OOP5cQTTwz4vOTkZNO9X17q1q0rF1xwQYmeqy3AgeiYTJ18VZh3m7Yal0Tnzp3NedKAq8MAtEW2qNdqd72eZz0n5bVPAAAAa4FUu3OVdpMH6tItqhWu4D60tbPgTHrtrtbxlMWNofS24mm40slTwehkK+3eD9YqGSpdQqokSzMVRd9foJDn3RYorAZSq1Ytc1Ma/nV1AZ0cdvHFF/sNo9B/PGzatMnUHmhsbmn2CQAAYDWQ6vhRDVbaLV14LGQo+ygqTAbz2WefydixY03o1XU8//Of/5gu/EC84zjLK0xpaNRu75LQ4BdoDVUNxoG65TU0q4LLMYVCw/n8+fNl//79+aHSS1c50JbZkkxmKuk+AQAArLeQatduacPovn37zJhG7SIu3CWuwengwYMBx19qN7IuQaSTqTSYaive888/HzSQ7t271wTAYN3nodKlqMo6hlTfY2pqqhmHW/D86fAD7+OloedN6X4DddfrmF0dE1pe+wQAALAeSHv37l2m16suXbr4bNfZ8kpn2xd+TJdD0jU6NVjp+pg6cer//u//zLJR2oVfcBklL91PoO02x5Bqq6O+f63Zuw6ptrzquFudae8drqBhUN+ztrQW7GbXIQiF960z6LW1WLv7C68Jq8/funWraR3VVu1AQt0nAACA1UCqM821Nc8bHkvbXa8Kh05d+knpZTULPqZd79dcc40JbbquqHccpwZSvQKULqYf6KpMixcvNjP6y0t5jCHV0KmhdOHChSYIarDWS3xqq3Dfvn3zn6fnWFtjdaWAHj165G/XLnRtsWzcuLHp3teufm0B1VZn/UdC4dUNdKknPX9FddeHuk8AAACrgdQbJnXB9LffftvvcW31K9wVX5i2EOpkKF3uqSANap06dTLd8Xop0IJXVdKlnTR0FlyGqH79+nL11VebmfR67fqC3d16bXa9Rntprnz0W9NLeGpLqLZAahDU86CrBmggLI6eIw3mutKBrhmq3f56gYBevXoF7JLXYKmtn0WtJxrqPgEAAILyhMHTTz+tM4WC3mbMmJH/3Ouuu87TokULv3306tXLM2jQoID7f+655zxJSUmew4cPm9/fe+89T0xMjGfkyJEBn798+XLz+KOPPuqz/e677/Y0b97ck5ubG/B1EyZMMPXu2rUrpPcPAACA4MJ6LfuSGDFihHzxxRem61zHL5ZkprbO6NYWO73sp17RqTR0Jry27P35z3+WP/7xjz6PaQugjs3U/U+cODHs17IHAACIZmG9dGhJ6Wx67VrXqzqVhI6pvOuuu0xY1Ik1pfHmm2+acY8jR470e0wX8td6dP8AAAAoXxWuhVTHJOoSR0rHTJZlZn55BmQdL+mlE4mYtAMAABClgRQAAABuqZBd9gAAAHAHgRQAAABWEUgBAABgFYEUAAAAVhFIAQAAYBWBFAAAAFYRSAEAAGAVgRQAAABWEUgBAAAgNv0/4+cO/MZc68AAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array([phis[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, mlp),\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.3729084\n",
      "Predicted Value (f(x))  [0.612]\n",
      "Shapley Values + (E[f(X)]):  0.727\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=5000)\n",
    "\n",
    "sample = np.array([1, 0.2, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapperGT(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.DIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EPXr1zdN7qE+cNqFoE314f7lo8/Rlr5LL73UdN3oF5DetHld6Tg2/Vk/RN5jeV831LHCdWm4eK4K4u3q11ri7TwVREO897V9j+V93VDHKs2fqWiep1j+PJXEuWrYsKG519+9QPXq1TP3+/btyz+W93VDHSueP1NFOU+uf6Z85eTkyOTJk01w0qWRQh3L+7qhjhXPn6minKdY/0wVhkBaiC5duphFb+fNmxf0Lx9dBLpz585hn3v06FGzjqa2xOi/ir03XcPO2yKoP0+YMMH8rGv3adP/Dz/8EPRauu6fKuh4Lp2rgni7werUqSPxdp4Kos/funWr3/uO5c9UNM9TLH+eSuJceSdk6HkJ5N2mE8K8x1LhPlM69q20rocYzfPk+mfK16effio7d+6U6667LmT3Nt9TeQo7T7H+mSqU7Wn+pd3ixYsLXGPsvffey9+2du1az4oVK/J/1iVBpkyZEnQbN26cee4ll1xifl61alX+cwYOHGjWYlu0aFHQWmzNmzcvtWuxRftc6VIX+/fvD6ph8+bNnurVq3tq1KjhOXLkiCfezpPas2dPyNcdOXKkef5zzz3ntz1WP1PRPE+x/HkqiXOVkZFh1hBt0KCB3/JYutZmxYoVzTqQvjp37mwev23btvxt+mfddsEFF3hKq2ieJ126R5f+CbRgwQJPuXLlPK1bt/aUZqd6rnzpEn76HH3NcFz9nirKeToe499ThSGQRmD48OHmQ3LllVd63n77bc8999zjSUpK8vTo0cNvXbnGjRtHtAhyQWtr6hp/1apV89SuXdvzzDPPeF5//XVPx44dzSLxX375pae0i9a52rdvn6dq1aqeoUOHmmDx1ltvee69915PlSpVzLn617/+5YnX8/THP/7R061bN8+DDz7oGT9+vGfMmDGenj17msedffbZQV9IsfyZitZ5ivXPU0n87r355ptme5s2bcwFKfSzomGgbNmynhkzZvg9ds6cOSZUpaWleV5++WVz0z9rKPMNFC6fJ13gvW7dup7bb7/dPO6NN97w3HHHHWa9zfLly3tmz57tceH7XP+hor9DXbt2LfBYrn5PFeU87YuD76mCEEgjoAvTvvDCC+Zfv/olXL9+fc+IESOCFtouiUCqli9f7unfv7/5kOkX1+9+9zvPzJkzPbEgWucqKyvLc/PNN3vatm1rfkH1l1+//K+66qpS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bnzt6tcgWrly5YjeMwAAQFQCqc4019Y8b3g8lUX1A0OndhsrnWDju09b8K6//noT2nRdUe84Tg2koRbK970Eps7oLyklMYZUQ6eG0nnz5pmwqMFaL/GprcI9evTIf5yeY22N1YlGnTt3zt+u3fLaClqvXj3Tva/d7NoCqq3O+o+EwNUNdKknPX/h1h7VsBuq5XTJkiXmPtQ+AAAAq4HUGyb1GvDvv/9+0H5t9Qvsig+kLYQ6GSpwvUsNato9rN3xeilQr8cee8ws7aSh03dpI118Xxfh15n0eu163+5uvd67Xve9sCsf2aCX8NSWUG3V1HCp50FXDdCQWRg9RxrMdaUDnR2v3f56edauXbuGDI8aVrVFtaA1SgEAAEqMJwqef/55nSkU9jZ58uT8x954442exo0bB71G165dPX369An5+i+99JInNTXVc+TIEfPzRx995ElISPDcfvvtIR+/bNkys/+pp57y2/7AAw94GjVq5MnNzQ35vNGjR5t6d+/eXaT3DwAAgPAS9D9SigwdOtRcz167znX8YuDs71B01re2Aj7//PPmik7FoTPhtbXwT3/6k/zhD3/w26etijo2U19/zJgxpqVXWxgBAAAQY5cOjZTOpteudb2qUyR0TOX9999vwqJO1imOd99914ylvP3224P26UL+Wo++PgAAAEpWqWsh1XGOusSR0jGTpzIzvyQDso7B9NKJRAVd5hQAAAAxHEgBAADgllLZZQ8AAAB3EEgBAABgFYEUAAAAVhFIAQAAYBWBFAAAAFYRSAEAAGAVgRQAAABWEUgBAABgFYEUAAAAYtP/BxurMmXhycp6AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "explanation = shap.Explanation(values=np.array([phis[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapperGT()),\n",
    "                                output_names=['Prediction'])\n",
    "\n",
    "shap.plots.waterfall(explanation)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Indirect"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline Value (E[f(X)]):  0.7232835999999999\n",
      "Predicted Value (f(x))  [1.312]\n",
      "Shapley Values + (E[f(X)]):  0.581\n"
     ]
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=1000)\n",
    "\n",
    "sample = np.array([1, 0.2, 0.6, 1])\n",
    "\n",
    "feature_names = [\"T\", \"C\", \"M1\", \"M2\"]\n",
    "\n",
    "explainer = CausalExplainer(X = X_test1, model = ModelWrapper(), is_classification=False, rounding_precision = 1, feature_names = feature_names)\n",
    "phis = explainer.compute_shapley_values(sample, effect_type= EffectType.INDIRECT, causal_model=[[1], [0], [2, 3]], confounding=[False, False, False], is_asymmetric=False, features_compute = [0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "explanation = shap.Explanation(values=np.array([phis[0], 0, 0, 0]),\n",
    "                                feature_names=feature_names,\n",
    "                                base_values=get_baseline(X_test1, ModelWrapper()),\n",
    "                                output_names=['Prediction'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8uXLW6ecckrY8uTkZFPDmDFjrLIs1q9D/bks6a/j2bNnm3Xvu+++sOV6X5d/9913lh+PYTQLFiww+7ryyit9+zqM5vbbbzfP/+STT8KWDxo0yLx/hP5M6++1pk2bWm3btrXy8vIKlr/yyitmG1pLKK21XLly1saNGy2/HcPs7Gxr3rx5hdZNTU21ateubdWrV8/Kzc113fuyGxFubfTII4+YF+o333wTtjwzM9OqVKmSdeGFFx51G8EXelZW1jGFpccff9xs47XXXrN92244hl9//XXYL9zDhw9bBw4ciLru2rVrzbo333xzocd0mf5CTElJKVjWqFEjq1WrVoXWnTJlitnOBx98YPntGBane/fuVmJiYpGhQus5lu168RgGw62Gh3379hV6Awx17bXXmnU3b94ctlzv6/I777zTKgvKwutQf451G3PmzPHl6zCajIwMq1q1auaPBv3jPHS5/rz269evyPeVH374oWDZGWecYWrQWkJprbru008/bfntGBZHw7XWEfqe4pb3ZTei59ZGP/74o/l4I/JjRO3x0Y8p9PGS0B477dXRHtB69eqZj3z0o7ij0Z+Tt99+2/RJac+jndt2yzH89NNPza32OenHRdoDqsdDP87UXqjIfSn9uChSr169zPFctGiRua8fLenHoLo82rqh2/PTMSyux02PWf369aM+/txzz5nXoW5X+9+0f1Q/0isrnDqG+jGwfun6+pFvtD493be20ehxC6X3tS2E12E+bWX497//Lc2aNTPH0o+vw2j0HIH09HTT5x0fHx/2Mbt+70X9PgzWE/z5Xrx4sXTr1s3UEkpr1Z5Rr7wOS3MMi7N161YpX7581LaXsv6+7EaEWxvpyUZ16tSJeik+fTPauXOn6VMqjv4Aaq+Svtjfffdd6devX0EPqP6yLo42/ScnJ8ugQYPCLhFox7bdcgz1ZAh12223mR5Z/T61H1Z/qWgvlIb/0H0FtxttXyrY11eadf10DIuiPWYabm+88caw5fomo6+78ePHy8yZM2Xy5Mly0kknyRNPPCEXX3yx5Obmih+PYVJSkukL1F7lDz/8UB5++GH56aefzM+m9gRG1hbtdRisjddhvg8++MD8XtNe+MieSr+8DqP529/+ZsKn9mtH7iu43Wj7UsHX1p49e0wfc7R1tVat2Suvw9Icw+L+UFu4cKHplY/2x0BZf192JaeHjr2kZcuWVpMmTaI+dv3115uPH/bs2VPq7T755JPmuePGjSt2vauuusqsN3/+fNu37ZZjeM4555h1dDv6MU/Q7t27rRo1alhJSUkFH/kGP2r78ssvC21Hl+ljL7zwQthHbaNGjSq0rm5PH7v00kstvx3DaLTnUz/e7NKlS6GPLIty2223mX2+//77Vlng9DFUa9asMR+btm7dOmy59kT+4Q9/iPocXV69enWrLHD6GPbq1cscq02bNpW4Zq+9DiOtXr3aPEePbVHtVX/7298KPbZ+/Xrz2L333hvWAqM1RKM168+/345hUT/Hek6GtrWlpaW58n3ZjRi5tZF+rFDUR1o6ZVJwndIaOXKkGa2YPXt2kevoyIaO+OhUJ3rmup3bdtMx1I8ulbZl6PcVpNPa6HQsqampBSNCwe1E21/kvkqzrp+OYSRt4+jfv7/5eFxfU5GjFEV55JFHzK0fX4dFadOmjZmJQ2dAWLNmTYlr43UosnLlSjMTirYjaFtDSXntdRhtxFHdeuutUfdlx+9Dr70OS3MMI+knqeecc44Z5dWZJHRWDze+L7sR4dZG+oauH3FE+0HSj2j0o5HQX9IlpVOCBLddFJ3DUfer0+XYvW03HUOdniv4MW+kBg0aFHykFtxXcLvR9qWCH7uVZl0/HcNQ2oOnYUJ7Rr/66qtSHQ/td9TeNT++Doujcwer0OOitRX1ka8u9/vrsLQBxMuvw1A5OTlmKqratWubKbGi7Su43Wj7UsHXlv6BoX98RFtXa9WavfI6LM0xDKXTJOo0iNpaMHfu3LBpJd32vuxGhFsb9ejRwzTaa29N5F+HelEAnfD/WOjztRm9qJNzgr/M9QdCLzBg97bddAyDJw3o9xQpuEwb9oP7UjpHaCQd9dG/tk855ZSCN1P9Za3Lo62rjvX/r5uPYWiwDV4IQ4OtnsRTGjo3rvY5+vF1WJy1a9ea29DjorXpm/KWLVvC1tX72l/o59eh0v5JnfNWR8n04iJ+fh2G+vjjj838szrParT+Uw1furyo34cquD/tWe7evbuZJzYyNGqtejKuV16HpTmGocFW52fWk8I02OqJd25+X3Ylp/sivGTp0qXFzqf33nvvFSxbt26dtWrVqkJzhkYzYsSIYqdW+fHHH83jkfu1Y9tuO4baj6dz1Gp/U+i0KjpPZuXKlc1cjaF0PmBdf9u2bQXL9N+6LLKnKnisos1zqz2A6enplh+P4eLFi01Pmfa1aW9ecaK9DrVvcsiQIWVqOrVYHkOdVihab7IeV50ruEOHDmHLdV7N4ua5LU3PvZdeh0FTp06Nenz8+DoM1b9/f/Mc3WZRdD5g7VP++eefC81z26ZNm7B5bl9++eUi57lNSEgw06358Rjq/L7Nmzc3ve8LFy4stja3vC+7EeHWZsOGDTMvyssvv9x68803zS9Y/UHv06dP2MkPzZo1KzRp+//93/+ZkyAeeugha9KkSdaECROss88+26x32mmnWQcPHoy6zzvuuMOs8+mnnxZZ17Fu223HUL3++utmeceOHa3nnnvOeuqpp8wvZ51Y/PPPPy908pMGCD3pQE8e0y/9t755hv6CD/4i0n1WqVLFGj16tNlP3759zb4mT55slSWxOob6i1wnJ9c3j7Fjx5o3isgvDW9BWo/+0aAn5r3xxhvW+PHjzYUegifkHe0kKy8eQ50wX0+O0p9jXU/nqNa5avWkvIoVK0YNqxdffLHZ9i233GJee3qr96+77jqrLInlz3LQBRdcYJ6zcuXKIuvy0+sw+Ad7fHy81bNnz2L3pXN/16xZ01xsQI+1Xqiha9eu5rmRcwXrSX56zLQWrUlr0xq1hkcffdQqS2J1DHWAo0WLFmYbd999d9Tfh3pBBze+L7sN4dZmOpL37LPPmlEFDU0NGza0hg8fXmhy5mg/RDNnzrT++Mc/mufoG5ueKa1nnOqZk0Wdda4vfv0LUUfNivuFfCzbduMxDJo+fbr55aDfp4ZRvdrYt99+W+RVjHTicg20uq4ep0WLFkVdV69epgFCA50ex27duln/+te/rLImVsfwq6++Ms8v7it0BEeDmL6h1K9f3wQU3a7uQ99Ey1KgiOUx1End9TXVrl07M1Kpb7r683zDDTcUOYqkP7M6Ob3uW2vTN1Sd/UMvdODnn2U9i19HHk8//fRi6/Lb6zB49r0G+aPRPwoGDBhg3lf0jyu9WMPcuXOjrquzDNx1111WgwYNCj5leOmll8JGeP10DIMXBynuS39nuvF92W0C+h+nWyMAAAAAO3BCGQAAADyDcAsAAADPINwCAADAMwi3AAAA8AzCLQAAADyDcAsAAADPINwCAADAMwi3AAAA8IwEpwsAAAA40YYOHSrvvvuu+XfHjh1l+fLlYY/n5eXJ+PHj5e2335bNmzdL06ZNZf369fLMM8/IW2+9JStXrpS4uNKPCb722mtmu2vXrpXExMSwx/7617/K8OHDC+7/9ttvUqdOHYmV3Nxc+emnn0xtWVlZUqtWLenRo4c0bty42OfNmzdP1qxZU+Tj1157rVSuXFnS0tLMeikpKbJ//37z/devX19OPfVUqVGjRthzdu/eLYsWLZKdO3fKwYMHJSEhQWrWrCldunSRZs2aler7YuQWAAC42ueffy6BQKDIrylTppj1NDi+99578pe//KXQNl599VUZPXq0DBw40ITZ119/XdLT0+Xpp5+WBx98sFCwfeyxx8yyVatWFdrWzTffLPHx8TJ79mwTqg8fPmy2F+mCCy4w9Vx++eXihHnz5snSpUuldevWcvrpp5vv57PPPpPU1NRin9ehQwc5++yzw7769u1bEEg12KpffvlFkpOTpWHDhmb7+jwNujNmzDBhNlRGRoZkZ2dL27Ztzbrdu3cv+H8b7RgXh8vvAgAAV9PRVQ2gEydONOEq0vnnny8jR440YW7jxo1Rt3HKKaeY8KthKnRkdcyYMbJjxw6pUKFC2Po6KqkjijfccENYcH3ppZfknnvukXHjxskjjzxilmltH3zwgQl6GrYjjR071oTlWI7cpqWlycyZM+W0004zo6MqJydHpk2bJhUrVpRLL720VNvTQPzRRx+Zkd9u3boVLKtbt64J+kH79u0z+2jRooX069ev2G3qaPqHH35o6hoyZEiJa6EtAQAAuJqOPlavXl2GDRsWNTwezaFDh8woowbMUNqiMGDAgELBVtWrV898/K4jr08++aQJpV9//bXcd999csUVVxQEWzV48GATwL/66qujBrpY2bBhgzlWOpoapCOv7dq1kx9//NGMpFapUqXE21u3bp251VHgoKSkpELr6f8n/QNk7969R92mjiTrKLCG/tKgLQEAALiaBlMdLTyWYHvLLbeYkUrtP3300UfNNnr37m1GWTU0n3vuuUU+V/tlMzMzTV/tli1bTIht3769vPPOO4VGhbWfddasWWIHHdHUQF6SL6uID+h37dplgmb58uULhfbg46WpR/uTtZ+2atWqxa6r9egxi/YHg9LWBK1bW0L0+OtxbdSokZQGI7cAAMC1tJ/1119/lTPPPNOcjBRJA1y5cuWKfL6Ovurj2lrw4osvmhCq7QYLFiwwjwd7P6PRE9P++Mc/yiuvvGI+4tdgprfRRjx1O999953YQT/u/+STT0q07tVXXx01cOpJW5UqVSq0PLjswIEDJa5HA6iekNamTZsSjfDqtjXwR/P9998X9NjqHxrNmzeXM844Q0qDcAsAAFxLZzHQUKmjp/oVSYOvnqRUFG0T+PLLL83H39rWEDxxbNSoUeZWe0OLo20IemKY9rB++umn0qpVq6jrtWzZ0rQw2KF27dpy0UUXlWjdihUrRl2ufayhvbBBwWU6kl1SGlj1uOn3WBxtRfj222/NCG9R/086d+5sjrmGb22d0JHe0tSiCLcAAMC19KNrpa0A0T6+Lsloom5DR2FDZ0TQj+W1B/VofafBUUYNdnriWlG0z1Q/ji9qxLQ0dEqto03XdTT6vUULjcFl0YJvNPqHxaZNm0w9RbUaKP2+dSYGbYPQVo+iplXTKcKC04RpANYZJ/Qkv8suu6zEbSeEWwAA4Op+Ww1q+vF7ZP9oabZRXDAtyhdffCEjRowwAVrniv3Pf/5j2hSiCfa+HktfcLQAqm0AJVGhQoWoQVIDdrTWAw2hKjid19Ho7BM6Chx6Ilm01hENtnqrJ+iVdNvBPxrmz59vZlmInBu3KIRbAADgWjrqqh9jH2uw1Y/KtWdUPw6P/OhfQ5tefCBaz6p+ZK7TU+mJbBpydZTxhRdeKDLc7tmzxwTKotoESkOnJjventvatWvL9u3bTeAMPXbaXhF8vKQtCdqzrL2x0egxnDNnjgmn/fv3jzpVW3H0+UrrLCnCLQAAcHW47dWr13E9X5188slhy3XWA6WzJkQ+ptNk6TywGup0HlY9ae1Pf/qTmUpM2xRCp9cK0u1EW+5Uz23Lli3N9671Bue51RFh7VHWGROC7RgaLvX71RHgyLYDbbPYunWrGbXV0fNosyhoP7OGcR0Z117boui2ImvV5+uIuLZIlCYUE24BAIAr6awBOtIYDKLH2pKgIgOsTgem9PK0oY9pe8H1119vQqDOWxvsfdVwq1c+0ws/RLsa2eLFi83MDHawo+e2Xr16JuAuXLjQBEsN6HqpXB2p7tOnT8F6enx1lFhne9DL5obS6b/0eBTVkqAzH2g/rl7KWNsoNKgW1Q+trQc6OtugQQPTtqDtEToqrCPr+sdLcTNeRCLcAgAAVwoGU53k//333y/0uI5IRrYbRNLRSz0RTacAC6XBr1OnTqblQC+nG3o1MZ3uSwNs6BRVeiWu6667zsyIMH78+LCP9RctWmQuN1vaq36daH379jUjtBo6NVjqMdCZHzRgloSGTx1tLWoe2uBcuZs3bzZfkULDrR5v/YNBZ7/QeW61VUIvjNGzZ88iWx6KpJffBQAAcJtnnnlGz9Iq8mvKlCkF6954441Ws2bNCm2jZ8+e1oUXXhh1+88//7xVpUoV6+DBg+b+jBkzrEAgYN1xxx1R11+xYoV5fNy4cWHLH3zwQatp06ZWXl5e1OeNGTPG1Pvbb7+V6vtHdAH9T+niMAAAgLsMHTpU/vvf/5r2AO0PLcmZ93oSlI4o6qVz9Upmx0I/jteRxz//+c9y7733hj2mI5Taz6rbnzBhghmB1tFKHB8uvwsAAHxBZ0XQ9gG9mllJaB/qAw88YIKnntx0LN5++23TL3rHHXcUekwvOqH16PZhH0ZuAQCA52kvp059pbTP9HhmWLAzbGufaZCeyFWaE6cQHeEWAAAAnkFbAgAAADyDcAsAAADPINwCAADAMwi3AAAA8AzCLQAAADyDcAsAAADPINwCAADAMwi3AAAA8AzCLQAAAMQr/j/EHFw8mSgS8QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x350 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "shap.plots.waterfall(explanation)"
   ]
  }
 ],
 "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
}
