{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e9b0b7f4",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:04.753834Z",
     "end_time": "2023-09-17T13:57:04.756234Z"
    }
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "sys.path.append('../')\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "from simulation.data_fico import get_Py1x_given, get_Px_given, get_Ps_given\n",
    "\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1447c7e5",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:04.757040Z",
     "end_time": "2023-09-17T13:57:04.758933Z"
    }
   },
   "outputs": [],
   "source": [
    "def get_c():\n",
    "    return 0.8\n",
    "\n",
    "def get_slack():\n",
    "    return 0.0001\n",
    "\n",
    "def get_seed():\n",
    "    return 24\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "e5943a68",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:24.774651Z",
     "end_time": "2023-09-17T14:41:24.780901Z"
    }
   },
   "outputs": [],
   "source": [
    "num_cat = 4\n",
    "seed = get_seed()\n",
    "slack = get_slack()\n",
    "c = get_c()\n",
    "\n",
    "# Set seed for reproducibility\n",
    "np.random.seed(seed)\n",
    "\n",
    "path = os.getcwd()\n",
    "\n",
    "\n",
    "total_samples = 50000\n",
    "policy_type = \"random\" #, random, biased, threshold\n",
    "if policy_type == \"random\":\n",
    "    Pd1 = [[0.5, 0.5, 0.5, 0.5],[0.5, 0.5, 0.5, 0.5]]\n",
    "elif policy_type == \"biased\":\n",
    "    Pd1 = [[0.1, 0.1, 0.3, 0.3],[0.1, 0.1, 0.9, 0.9]]\n",
    "else:\n",
    "    raise NotImplementedError\n",
    "\n",
    "Pd1 = np.array(Pd1)\n",
    "\n",
    "\n",
    "save_figure_path = \"../figures/05_estimation\"\n",
    "save_estimations_path = \"../estimations\"\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d64d5e16",
   "metadata": {},
   "source": [
    "## Create dataset"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Get S"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "1b0eca0c",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:25.375790Z",
     "end_time": "2023-09-17T14:41:25.383618Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples for group s0: 6035\n",
      "Number of samples for group s1: 43965\n"
     ]
    }
   ],
   "source": [
    "Ps = get_Ps_given() #FICO vs. 0.5\n",
    "# Total number of samples\n",
    "\n",
    "# Calculate the number of samples for each group\n",
    "num_samples_s0 = int(Ps[0] * total_samples)\n",
    "num_samples_s1 = total_samples - num_samples_s0\n",
    "\n",
    "print(\"Number of samples for group s0:\", num_samples_s0)\n",
    "print(\"Number of samples for group s1:\", num_samples_s1)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Get X | S"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.6145 0.2411 0.0904 0.054 ]\n",
      " [0.2054 0.2479 0.2435 0.3032]]\n"
     ]
    }
   ],
   "source": [
    "Px = get_Px_given(num_cat)\n",
    "print(Px)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:25.760260Z",
     "end_time": "2023-09-17T14:41:25.768859Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "96ff6757",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:25.976560Z",
     "end_time": "2023-09-17T14:41:25.980753Z"
    }
   },
   "outputs": [],
   "source": [
    "x_samples_s0 = np.random.choice(4, size=num_samples_s0, p=Px[0])\n",
    "x_samples_s1 = np.random.choice(4, size=num_samples_s1, p=Px[1])\n",
    "\n",
    "x_samples_s0_plot = pd.DataFrame(x_samples_s0)[0]\n",
    "x_samples_s1_plot = pd.DataFrame(x_samples_s1)[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "outputs": [
    {
     "data": {
      "text/plain": "0    3729\n1    1445\n2     542\n3     319\nName: 0, dtype: int64"
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_samples_s0_plot.value_counts()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:26.145980Z",
     "end_time": "2023-09-17T14:41:26.150037Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "outputs": [
    {
     "data": {
      "text/plain": "3    13429\n1    10936\n2    10611\n0     8989\nName: 0, dtype: int64"
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_samples_s1_plot.value_counts()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:26.328473Z",
     "end_time": "2023-09-17T14:41:26.337133Z"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Get D | X, S"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "ff3da79b",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:26.672155Z",
     "end_time": "2023-09-17T14:41:26.675329Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.5 0.5 0.5 0.5]\n",
      " [0.5 0.5 0.5 0.5]]\n"
     ]
    }
   ],
   "source": [
    "# use the policy to decide\n",
    "# Make binary decisions based on probabilities from Pd1\n",
    "print(Pd1)\n",
    "decisions_s0 = np.random.random(size=num_samples_s0) < Pd1[0, x_samples_s0]\n",
    "decisions_s1 = np.random.random(size=num_samples_s1) < Pd1[1, x_samples_s1]\n",
    "\n",
    "# Convert string values to integers\n",
    "decisions_s0_plot = pd.DataFrame(decisions_s0).astype(int)[0]\n",
    "decisions_s1_plot = pd.DataFrame(decisions_s1).astype(int)[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "outputs": [
    {
     "data": {
      "text/plain": "0    3030\n1    3005\nName: 0, dtype: int64"
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "decisions_s0_plot.value_counts()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:26.880863Z",
     "end_time": "2023-09-17T14:41:26.885213Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "outputs": [
    {
     "data": {
      "text/plain": "1    22033\n0    21932\nName: 0, dtype: int64"
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "decisions_s1_plot.value_counts()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:27.116607Z",
     "end_time": "2023-09-17T14:41:27.125362Z"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Get Y | X, S"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.318  0.8527 0.9405 0.9904]\n",
      " [0.4551 0.917  0.9774 0.991 ]]\n"
     ]
    }
   ],
   "source": [
    " # sample the ground truth y  for the datapoints that recieved D=1\n",
    "Py1x = get_Py1x_given(num_cat)\n",
    "print(Py1x)\n",
    "\n",
    "# use the policy to decide\n",
    "# Make binary decisions based on probabilities from Pd1\n",
    "labels_s0 = np.random.random(size=num_samples_s0) < Py1x[0, x_samples_s0]\n",
    "labels_s1 = np.random.random(size=num_samples_s1) < Py1x[1, x_samples_s1]\n",
    "\n",
    "\n",
    "labels_s0_plot = pd.DataFrame(labels_s0).astype(int)[0]\n",
    "labels_s1_plot = pd.DataFrame(labels_s1).astype(int)[0]\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:27.496076Z",
     "end_time": "2023-09-17T14:41:27.508701Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "outputs": [
    {
     "data": {
      "text/plain": "1    53.869097\n0    46.130903\nName: 0, dtype: float64"
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels_s0_plot.value_counts(normalize=True) * 100"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:27.733062Z",
     "end_time": "2023-09-17T14:41:27.737349Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "outputs": [
    {
     "data": {
      "text/plain": "1    85.838735\n0    14.161265\nName: 0, dtype: float64"
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels_s1_plot.value_counts(normalize=True) * 100"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:27.979771Z",
     "end_time": "2023-09-17T14:41:27.988693Z"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Get Y | D=1, S"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "outputs": [],
   "source": [
    "observed_features_s0_d1 = x_samples_s0_plot[decisions_s0_plot == 1]\n",
    "observed_features_s1_d1 = x_samples_s1_plot[decisions_s1_plot == 1]\n",
    "unobserved_features_s0_d1 = x_samples_s0_plot[decisions_s0_plot == 0]\n",
    "unobserved_features_s1_d1 = x_samples_s1_plot[decisions_s1_plot == 0]"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:28.396190Z",
     "end_time": "2023-09-17T14:41:28.399605Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "outputs": [],
   "source": [
    "observed_labels_s0_d1 = labels_s0_plot[decisions_s0_plot == 1]\n",
    "observed_labels_s1_d1 = labels_s1_plot[decisions_s1_plot == 1]"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:28.629599Z",
     "end_time": "2023-09-17T14:41:28.634443Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "outputs": [
    {
     "data": {
      "text/plain": "1    54.509151\n0    45.490849\nName: 0, dtype: float64"
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "observed_labels_s0_d1.value_counts(normalize=True) * 100"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:28.854809Z",
     "end_time": "2023-09-17T14:41:28.859658Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "outputs": [
    {
     "data": {
      "text/plain": "1    85.957427\n0    14.042573\nName: 0, dtype: float64"
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "observed_labels_s1_d1.value_counts(normalize=True) * 100"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:29.041605Z",
     "end_time": "2023-09-17T14:41:29.045763Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "def combine_and_plot_histograms(save_figure_path, features_s0_plot, features_s1_plot, labels_s0_plot, labels_s1_plot):\n",
    "    # Create a figure with one row and two columns\n",
    "    fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "\n",
    "    # Plot 1: Distribution of Features\n",
    "    bins_range = [-0.5, 0.5, 1.5, 2.5, 3.5]\n",
    "    axs[0].hist(features_s0_plot, bins=bins_range, alpha=0.5, label='S=0', edgecolor='black', width=0.5, align='mid')\n",
    "    axs[0].hist(features_s1_plot, bins=bins_range, alpha=0.5, label='S=1', edgecolor='black', width=0.5, align='mid')\n",
    "    axs[0].set_xlabel('Category', fontsize=20)\n",
    "    axs[0].set_ylabel('Frequency', fontsize=20)\n",
    "    axs[0].set_title(f'Features', fontsize=35)\n",
    "    axs[0].set_xticks(range(4))\n",
    "    axs[0].tick_params(labelsize=20)\n",
    "    axs[0].legend(fontsize=20)\n",
    "\n",
    "    # Plot 4: Distribution of True Labels\n",
    "    bins = [-0.5, 0.5, 1.5]\n",
    "\n",
    "\n",
    "    axs[1].hist(labels_s0_plot, bins=bins, alpha=0.5, label='S=0', edgecolor='black')\n",
    "    axs[1].hist(labels_s1_plot, bins=bins, alpha=0.5, label='S=1', edgecolor='black')\n",
    "    axs[1].set_xlabel('Label', fontsize=20)\n",
    "    axs[1].set_title(f'True Labels', fontsize=30)\n",
    "    axs[1].set_xticks([0, 1])\n",
    "    axs[1].set_xticklabels(['0', '1'], fontsize=20)\n",
    "    axs[1].tick_params(labelsize=20)\n",
    "    axs[1].legend(fontsize=20)\n",
    "\n",
    "    my_asp_ratio = 0.5\n",
    "    axs[0].set_box_aspect(my_asp_ratio)\n",
    "    axs[1].set_box_aspect(my_asp_ratio)\n",
    "\n",
    "    # Adjust the layout\n",
    "    plt.tight_layout()\n",
    "\n",
    "    # Save the figure\n",
    "    plt.savefig(f'{save_figure_path}/distributions_true_feat_label.png')\n",
    "\n",
    "    # Show the figure\n",
    "    plt.show()\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:29.191084Z",
     "end_time": "2023-09-17T14:41:29.195771Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1200x500 with 2 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAAFvCAYAAACb9ng+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACWd0lEQVR4nOzdeVxU5f4H8M/MsO+LIghuuSAilVkW5pLilnsumHjVS1wNS25uuVz13roumWXmQlkuqVRcMymXNBUElVuSlSmioGKoILLvwzLMnN8f3pkfI9vArODnfV++7sw5z3O+Xxg6HL7nOc8jEgRBABERERERERERkQGJjZ0AERERERERERE9fliUIiIiIiIiIiIig2NRioiIiIiIiIiIDI5FKSIiIiIiIiIiMjgWpYiIiIiIiIiIyOBYlCIiIiIiIiIiIoNjUYqIiIiIiIiIiAyORSkiIiIiIiIiIjI4FqWIiIiIiIiIiMjgWJQiIiIiIiIiIiKDMzN2AkTU8nl7e+vt2PPnz0dYWJjejk9ERERERETGwZFSREQmqqSkBGvXrjV2GkRERERERHrBohQRkQk6cuQIXn75ZURERBg7FSIiIiIiIr3g43tEpHPdu3fHwIEDdXKsPn366OQ4LUVubi4WLlyIX375xdipEBERERER6RWLUkSkc71798ayZcuMnUaLlJqayoIUERGRgehzXsxXXnkFGzZs0NvxW4uEhATMmjVL9b5fv34tYqR4eno6AgICVO9b0jyoQ4cORUZGBoCW8/2m1ouP7xERERERERERkcGxKEVERERERERERAbHx/eIiIiIiOixlJKS0miblvp4GRFRS8CRUkREREREREREZHAcKUVErYogCLh27RrS0tKQl5eHiooKuLi4oG3btujbty/s7Ox0Fqu8vByJiYnIzs5GUVERiouLIRaLYWdnB3d3d/To0QMdOnTQWTxTJ5VKce7cOdy7dw+Wlpbo0aMHnnnmGVhYWGjUv6ysDJcuXUJ2djZyc3NhYWEBV1dXdOrUCb1794ZYrP19lOLiYly9ehV3795FcXExJBIJnJ2d4eLigieffBIuLi5axyAiIiIiIs2wKEVErcKDBw+wY8cOnD59Grm5uXW2MTc3xzPPPIOQkBAMHjy4WXGKiopw8OBBREdH4+rVq5DJZA2279ixIyZPnoy//OUv9RbEoqKisGLF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dOzYEcHBwQgODkZFRQV+++03XLhwAT///DOuXr1a63snl8uxZMkSHD9+vMFlmImIiExFY9cejz56v3nzZowePVqfKRnNrl27ahWkevTogRdffBE+Pj544okn0KVLF9jZ2am1aehRvvooVyTUxKMjvGteIz16rTtw4ECj3+D08fGBj48PFi9ejAcPHuDChQtISEhAQkKC2qJBwMORWXPnzsWJEyfg5uZmpIypJWFRiohalEcnVBQEAXfv3q21IpuuvPfee2rvbW1tsWPHDvTr10+j/vp8ZE3p0VVQmnqHTZ9zPdX06ETkd+7cMUjc+lhZWeHFF19UPZ6Xl5eHY8eOYefOnWrzL1RWViIyMhJvv/22sVIlIqLH0KO/3zUtlDT2ON2j11J3795tUl4tRX5+PrZu3ap6b2ZmhvXr12PChAmN9i0tLW1yvEcXVmnIn3/+qfa+5uqHlpaWsLW1Vc3ldO/evSbnok/u7u6YOHEiJk6cCAC4desWDh8+jP3796tGZZWWlmLv3r1YunSpETOllsI01+4kIqrHo6uVAMDPP//crGPl5+c3OKro0qVLtS4a3n77bY0LUkDdhZdHh2xr69FlmJs6TPvRO1z68uSTT6q9v3btWrPmtaisrGzSxWJeXp5Go8FcXV0xe/ZsHDx4sNaort9++62paRIREWnl0UmjpVKpRv0aKzI9+vu4qddRmZmZePDggc6vZ3TtxIkTar//Z82apVFBCoBq1TklTUahX79+XePcLl26pPb+0RUZa35GaWlpda4+XZ/y8nKkpqY2aeRWXaRSKa5du4bU1NQG23Xr1g2LFy/Gp59+qrb98uXLWsWnxweLUkTUori4uKBr165q244ePdrk46Snp+PFF1/EU089hZEjRyIkJARnz55Va3Pjxo1a/Zq6pO5PP/1Ua1tzhoQ3xNraWu19QUGBxn2rq6tx9epVneZTn+eee07tvVwuxw8//NDk4+zcuRN9+/bF888/j0mTJuHvf/+7WpGquroaK1aswLRp09CvXz/079+/SRfcHh4etT7n/Pz8JudJRESkDVtbW7X3mqyilpGR0WhRyt3dXW2luIsXL9YqwtRHEATMnTsXgwcPhp+fH4YOHdqkgokhPXpj8YUXXtCo361bt3D79m21bZpcu505c0aj0epSqRQ//vij6r2bmxueeOIJtTaPzrl58ODBRo+r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oaFYuHBhvfGOHTuGf//733WujNevX796l/etrKzE3r17ceDAAWRkZNTZpn379pg9ezZmzJgBc3NzlJWVqT2e1tDxly9fju+++071XtvPWhAEnD59GhEREbh06VKDq9v06NEDgYGBmDZtWpMu5oCHc4l9/fXXiIuLazCGhYUFXnrpJcyePbvJq9UQEREREVHTsChFRK2KIAhITk7G7du3UVBQgJKSElhbW8PZ2Rne3t7o3r272qSeTVVRUYGrV6/i9u3bKCoqgiAIcHZ2hpubG/r06QMHBwedfS3l5eW4ePEibt++jbKyMlhZWcHV1RU9evRAr169Gu2fnJyMGzduICcnB9XV1XB1dUWvXr3g4+PT4OgwY5FKpbh06RKysrJQUFCA6upq2NnZwd3dHX5+fnBzc9M6RkVFBW7cuIHU1FQUFRVBKpXCzMwMzs7O6NKlC/z8/GBpaamDr4aIiIiIiBrDohQRERERERERERmc2NgJEBERERERERHR44dFKSIiIiIiIiIiMjgWpYiIiIiIiIiIyODMjJ0AGZdCoUB1dTXEYrFJTnxMRETUkgmCAIVCATMzM9Uy42QaeA1ERESkP5peA7Eo9Zirrq5GYmKisdMgIiJq1fz8/GBhYWHsNKgGXgMRERHpX2PXQCxKPeaUFUs/Pz9IJBIjZ2Pa5HI5EhMT+b1qIfh5tSz8vFoWfl6aU36vOErK9PAaiHguI9If/vdFml4DsSj1mFMOV5dIJDxZaIjfq5aFn1fLws+rZeHnpTk+HmZ6eA1ESvwZINIf/vdFjV0D8bYdEREREREREREZHItSRERERERERERkcCxKERERERERERGRwbEoRUREREREREREBseiFBERERERERERGRyLUkREREREREREZHAsShERERERERERkcGxKEVERERERERERAZnZuwEiIiIWrOioiJIpVJjp6FTcrkcpaWlxk6DiIgeM63xd2prJZfLkZubi8zMTEgkEmOnQ42wsbGBo6OjUWKzKEVERKQnRUVF2P7BWshKco2dik4pBAEF5Qr4+fnBxcXF2OkQEdFjoLX+Tm2tFIKA/Px8/NfFBWKRyNjpUCPM7dtg/turjFKYYlGKiIhaPUEQIJPJoFAoDBq3qKgIlqJqjH3WE84ONgaNrU95RVJ8ezEDxcXFsLFpPV/XoyQSCczMzCDixTQ1wFjnF9Ke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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# Example usage:\n",
    "# Call the function with your data and parameters\n",
    "combine_and_plot_histograms(save_figure_path=save_figure_path, features_s0_plot=x_samples_s0_plot, features_s1_plot=x_samples_s1_plot,labels_s0_plot=labels_s0_plot, labels_s1_plot=labels_s1_plot)\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:29.440111Z",
     "end_time": "2023-09-17T14:41:29.661456Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "def combine_and_plot_histograms_policy(policy_type, save_figure_path, observed_labels_s0_d1, observed_labels_s1_d1, decisions_s0_plot, decisions_s1_plot):\n",
    "    # Create a 1x2 subplot grid\n",
    "    fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "\n",
    "    # Plot 2: Distribution of Decisions\n",
    "    bins = [-0.5, 0.5, 1.5]\n",
    "    axs[0].hist(decisions_s0_plot, bins=bins, alpha=0.5, label='S=0', edgecolor='black')\n",
    "    axs[0].hist(decisions_s1_plot, bins=bins, alpha=0.5, label='S=1', edgecolor='black')\n",
    "    axs[0].set_xlabel('Decision', fontsize=20)\n",
    "    axs[0].set_ylabel('Frequency', fontsize=20)\n",
    "    axs[0].set_title(f'Decisions ({policy_type})', fontsize=30)\n",
    "    axs[0].set_xticks([0, 1])\n",
    "    axs[0].set_xticklabels(['0', '1'], fontsize=20)\n",
    "    axs[0].tick_params(labelsize=20)\n",
    "    axs[0].legend(fontsize=20)\n",
    "\n",
    "    # Plot 3: Distribution of Observed Labels\n",
    "    axs[1].hist(observed_labels_s0_d1, bins=bins, alpha=0.5, label='S=0', edgecolor='black')\n",
    "    axs[1].hist(observed_labels_s1_d1, bins=bins, alpha=0.5, label='S=1', edgecolor='black')\n",
    "    axs[1].set_xlabel('Label', fontsize=20)\n",
    "    # axs[1].set_ylabel('Frequency', fontsize=20)\n",
    "    axs[1].set_title(f'Observed Labels ({policy_type})', fontsize=30)\n",
    "    axs[1].set_xticks([0, 1])\n",
    "    axs[1].set_xticklabels(['0', '1'], fontsize=20)\n",
    "    axs[1].tick_params(labelsize=20)\n",
    "    axs[1].legend(fontsize=20)\n",
    "\n",
    "    my_asp_ratio = 0.5\n",
    "    axs[0].set_box_aspect(my_asp_ratio)\n",
    "    axs[1].set_box_aspect(my_asp_ratio)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    # plt.subplots_adjust(wspace=0.3)\n",
    "\n",
    "    # Adjust the layout\n",
    "\n",
    "\n",
    "    # Save the figure\n",
    "    plt.savefig(f'{save_figure_path}/distributions_{policy_type}.png')\n",
    "\n",
    "    # Show the figure\n",
    "    plt.show()\n",
    "\n",
    "#"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:30.811788Z",
     "end_time": "2023-09-17T14:41:30.816034Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1200x500 with 2 Axes>",
      "image/png": "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Zqhzp84yudT9cxz2Zbjnyc/PooEDByogIMBm41b8jLUlClgAAAAtQG3Fqwpjx45VfHy8LBaLjhw5Im9vb+u5yndE1aTifOW7pSr613dnVGlpqfW1h4dHlb6/d+5L4erqSvGiheN7wDm4urrKxWT6/1823YsMTaDisUGTC39fjq7ic+UMPwv5TgIAAECVq65ZWVnWtakkWXcErElZWZmKiookXXgksUKbNm3q7SvJunaVi4uLdb2rxs4NAACaHwpYAAAALUB9u0RX3p2wVatW6tmzp/X/K3YUrElGRoZ1odaKHQUlqVevXpIuPPZTl4rzAQEB1scAGzs3AABofn5XAau+tQgAAADgGJ566ildf/31uuWWW+psl5qaan3dq1cvderUyXpX07Fjx2rtd/ToUevr/v37W18HBwdLktLT0+vcITApKUmS1K9fP+uxxs4NAACan9+1BtYf//jHGotYla/sjR07ts4xTCaT4uLifs/0AAAAaKA2bdooOztb2dnZSktLq3J3UwXDMLR9+3ZJUlBQkHr37i1JGj16tD7++GPt3r1b8+bNq3Gh9F27dkmSOnbsWKUINWrUKEmSxWLR7t27NWnSpGp9T548qZSUFEnSyJEjq5xrzNwAAKD5+V13YJ06dUrp6enVvipu8TYMo8bzF38BAACgaVUuHL344os1tnnnnXesdzqFh4dbL1TefvvtkqS0tDTFxMRU63fo0CFt27ZNknTfffdVucDZrVs3DRs2TJIUHR1dbS0rwzC0ePFiGYYhX19fTZ48ucr5xswNAACan0u6A+vaa69tqjgAAADQBIYNG6Zbb71V27dv1969e3X//fdrzpw56tOnjzIzM7V+/Xpt3LhRkjR8+HBNnz7d2nfEiBEKDQ3Vl19+qUWLFikzM1N33323vLy8tHv3bi1dulRlZWXq2rVrlX4V5s+fr6lTpyotLU1hYWGaN2+eBgwYoNOnTys6Otp6B1VERESVnQdtMTcAAGheLqmAtW7duqaKAwAAAE3k5ZdfVmFhoeLj47V//37t37+/WpsbbrhBy5cvr/ao3uLFixUeHq7Dhw9r5cqVWrlyZZXzHTp00OrVq627DlYWEhKiRYsWacGCBUpJSVF4eHi1NrNmzdI999xTY9yNmRsAADQvv2sNLAAAADgPLy8vrVixQl988YU2b96sw4cPKy8vT+3atVO/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dznVtT309u3btXLlSr344ot1Poq3e/duTZkyRdddd12V9boqBAQE6KmnnrL+f+U1uGpy5ZVXWq9W7ty5s9Z2paWlio+PlyQNGTKkzjEBAAC+++476+uwsLAa2xQVFen777+XdGFn5Nrs27ev1nNxcXGSpIEDB1pzrmuuucZ6fteuXbX2/fbbbzV48GBNmDDBums0AMdCAQsALnLw4EEtWbJEktSlSxfdf//91nO33367dRHyF198scY7pH755RetWbNGeXl5Ki0ttS6i7ubmpkmTJkmSPvnkkxpvkc/IyNCmTZskXdhlx93dvdY4/f39dejQIeXk5OiDDz6osc2xY8esr3v06FHX25arq6vuuusuSRcSvIok8GJLly61XiGdMmVKnWMCAABUXsIgNTW12nmLxaKFCxdalyi4eI2sytauXVvjXVgbNmxQUlKSJGnatGnW41dddZX69esnSXrnnXeUlpZWrW9xcbFeeeUVlZSUKD09/ZJ2cQZw+bAGFoAWpby8vNr2yWazWXl5eTp+/LhiY2Oti4t6eXkpKiqqyhpPHTt21KOPPqpXX31Vhw8f1tSpUxUREaGhQ4eqtLRUiYmJeuONN5STkyOTyaRnn33WeveWJM2dO1exsbE6d+6c7r//fj322GMKDQ2Vi4uLvv/+e73++uvKycmRt7e3Hn300TrfS0hIiIYPH67ExET94x//UE5OjiZNmqTOnTvr/Pnz+uqrrxQVFSXpQvLWkGTsz3/+s7744gulp6fr8ccfV3h4uCZNmqQOHTooLS1Na9assV6VnDBhgm655ZYG/9kDAIDmIS0tTR999FG97a6++mpdccUVuummm/T+++9Lkp566ilFRkYqJCRE5eXlOnLkiNasWaODBw9a+9W1FmdeXp7CwsI0b948DR8+XIWFhdq0aZNWrVolSRo6dKjuuOOOKn3+9re/acaMGcrNzdW0adMUERGhP/zhD2rVqpWOHTumN99803r3V3h4eJVlFQA4DpPBg74AWoDQ0NA610y4WLdu3fT666/XWPQxDENRUVFasWJFrWsluLu7629/+1uNdygdPXpUDz/8sDIzM2vs6+Pjo3/84x+68cYbrcdmzJihxMREDR06VDExMdbjv/32m+67774aryZW6Nmzp957770qa3BFRkZq69at6ty5s/bs2VOlfVpammbPnq2ffvqp1jEnTZqkF154odpOQBVrhc2ePVtPPPFEjX2nT5+ub7/9VsOHD9e6detqnQMAADiWit/zDTV//nzrnexPPvmktm/fXmvbTp06aezYsdY8Z/fu3dbcJSEhQTNnzrSO+corr9T4mGFISIjefvtt+fn5VTu3a9cuPf3003UWx6ZMmaIXXnhBrq6u1mPLly/Xm2++KUlKSkpip2XAjvj0AWjxXFxc1KpVK3Xu3Fn9+vVTaGiobrnlllof3zOZTHrsscc0YcIE/e///q8SExOVkZEhi8WiwMBAXX/99Zo5c6b69OlTY/8BAwZox44dev/99xUXF6e0tDSVlpYqMDBQo0aNUnh4eJViU126dOmirVu3av369dq1a5eOHz+uwsJC+fj4qE+fPrr55ps1ffr0S9pxp2fPnvr000+1ceNGff755/rPf/6jwsJCde7cWVdddZWmTJmiESNGNHg8AACA1157Tdddd522bt2qlJQUlZSUqE2bNurVq5fGjBmjP/3pTyoqKtKHH34oi8WiL774Qvfdd1+1cSZNmqQBAwZo5cqV+uGHH2SxWNS7d29NnjxZ06dPrzV/Gzt2rGJjY7Vu3Tp99dVXOnnypEpKSuTr66shQ4Zo2rRpVS4eAnA83IEFAAAAAAAAh8Yi7gAAAAAAAHBoFLAAAAAAAADg0ChgAQAAAAAAwKFRwAIAAAAAAIBDo4AFAAAAAAAAh0YBCwAAAAAAAA6NAhYAAAAAAAAcGgUsAAAAAAAAODQKWAAAAAAAAHBoFLAAAAAAAADg0ChgAQAAAAAAwKFRwAIAAAAAAIBDo4AFAAAAAAAAh0YBCwAAAAAAAA7t/wF8w/H4C4ilCAAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    " # Example usage:\n",
    "# Call the function with your data and parameters\n",
    "combine_and_plot_histograms_policy(policy_type=policy_type, save_figure_path=save_figure_path, observed_labels_s0_d1=observed_labels_s0_d1, observed_labels_s1_d1=observed_labels_s1_d1, decisions_s0_plot=decisions_s0_plot, decisions_s1_plot=decisions_s1_plot)\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T14:41:31.435121Z",
     "end_time": "2023-09-17T14:41:31.628351Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "outputs": [],
   "source": [
    "df_s0_d1 = pd.concat([observed_features_s0_d1, observed_labels_s0_d1], axis=1, keys=['X', 'Y'])\n",
    "\n",
    "df_s0_d0 = pd.concat([unobserved_features_s0_d1], axis=1, keys=['X'])"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.285822Z",
     "end_time": "2023-09-17T13:57:05.287443Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "outputs": [],
   "source": [
    "df_s1_d1 = pd.concat([observed_features_s1_d1, observed_labels_s1_d1], axis=1,  keys=['X', 'Y'])\n",
    "\n",
    "df_s1_d0 = pd.concat([unobserved_features_s1_d1], axis=1,  keys=['X'])"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.288974Z",
     "end_time": "2023-09-17T13:57:05.291436Z"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Estimate P(Y|X, S) from observed labels"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "274d9721",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.293711Z",
     "end_time": "2023-09-17T13:57:05.300613Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Empirical probabilities P(Y=1 | X, S=0):\n",
      "Y         0         1\n",
      "X                    \n",
      "0  0.676692  0.323308\n",
      "1  0.219178  0.780822\n",
      "2  0.070513  0.929487\n",
      "3  0.009091  0.990909\n",
      "\n",
      "Empirical probabilities P(Y=1 | X, S=1):\n",
      "Y         0         1\n",
      "X                    \n",
      "0  0.568282  0.431718\n",
      "1  0.079351  0.920649\n",
      "2  0.024077  0.975923\n",
      "3  0.008729  0.991271\n"
     ]
    }
   ],
   "source": [
    "# Group the data by X and calculate the empirical probabilities\n",
    "grouped_s0 = df_s0_d1.groupby(\"X\")[\"Y\"].value_counts(normalize=True).unstack(fill_value=0)\n",
    "\n",
    "print(\"\\nEmpirical probabilities P(Y=1 | X, S=0):\")\n",
    "print(grouped_s0)\n",
    "\n",
    "\n",
    "grouped_s1 = df_s1_d1.groupby(\"X\")[\"Y\"].value_counts(normalize=True).unstack(fill_value=0)\n",
    "\n",
    "print(\"\\nEmpirical probabilities P(Y=1 | X, S=1):\")\n",
    "print(grouped_s1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "10f16f9e",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.302180Z",
     "end_time": "2023-09-17T13:57:05.304175Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "array([[0.32330827, 0.78082192, 0.92948718, 0.99090909],\n       [0.43171806, 0.92064923, 0.97592262, 0.99127109]])"
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Create a NumPy array with the two rows\n",
    "Py1x_est = np.vstack((grouped_s0[1].values, grouped_s1[1].values))\n",
    "# Py1x_est"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "bb04e5d6",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.308758Z",
     "end_time": "2023-09-17T13:57:05.327871Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f'{save_estimations_path}/Py1x_est_{policy_type}.npy', Py1x_est)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Estimate Dynamics under the Partially Observed Labels"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "8777ddb9",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.311909Z",
     "end_time": "2023-09-17T13:57:05.328059Z"
    }
   },
   "outputs": [],
   "source": [
    "from simulation.dynamics import get_Pxx_given_default\n",
    "Pxx = get_Pxx_given_default()\n",
    "Pxx_est = np.zeros(Pxx.shape)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "d40ab4ba",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.317042Z",
     "end_time": "2023-09-17T13:57:05.328104Z"
    }
   },
   "outputs": [],
   "source": [
    "df_s0_d1[\"D\"] = 1\n",
    "df_s0_d1[\"S\"] = 0\n",
    "\n",
    "df_s0_d0[\"D\"] = 0\n",
    "df_s0_d0[\"S\"] = 0\n",
    "\n",
    "df_s1_d1[\"D\"] = 1\n",
    "df_s1_d1[\"S\"] = 1\n",
    "\n",
    "df_s1_d0[\"D\"] = 0\n",
    "df_s1_d0[\"S\"] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "0e19ed58",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.323825Z",
     "end_time": "2023-09-17T13:57:05.328204Z"
    }
   },
   "outputs": [],
   "source": [
    "# Sample from categorical distribution Pxx[s][d][y][x] and add sampled values as 'X_new' column\n",
    "# Sample from categorical distribution Pxx[s][d][y][x] and add sampled values as 'X_new' column\n",
    "def sample_from_Pxx_d1(row):\n",
    "    s = row['S']\n",
    "    d = row['D']\n",
    "    y = row['Y']\n",
    "    x = row['X']\n",
    "    Pxx = get_Pxx_given_default()\n",
    "    # Handle case when D=0 and Y is NaN\n",
    "    if d == 0:\n",
    "        return x\n",
    "    # print(s, d, y, x)\n",
    "    p = Pxx[s][d][int(y)][x]\n",
    "\n",
    "    # Normalize probabilities to ensure they sum to 1\n",
    "    p_normalized = p / np.sum(p)\n",
    "\n",
    "    sampled_x_new = np.random.choice([0, 1, 2, 3], p=p_normalized)\n",
    "    return sampled_x_new"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "outputs": [],
   "source": [
    "# Sample from categorical distribution Pxx[s][d][y][x] and add sampled values as 'X_new' column\n",
    "# Sample from categorical distribution Pxx[s][d][y][x] and add sampled values as 'X_new' column\n",
    "def sample_from_Pxx_d0(row):\n",
    "    s = row['S']\n",
    "    d = row['D']\n",
    "    x = row['X']\n",
    "    Pxx = get_Pxx_given_default()\n",
    "    # Handle case when D=0 and Y is NaN\n",
    "    if d == 0:\n",
    "        return x\n",
    "    # print(s, d, y, x)\n",
    "    # same for y=0 as for y=1\n",
    "    p = Pxx[s][d][0][x]\n",
    "\n",
    "    # Normalize probabilities to ensure they sum to 1\n",
    "    p_normalized = p / np.sum(p)\n",
    "\n",
    "    sampled_x_new = np.random.choice([0, 1, 2, 3], p=p_normalized)\n",
    "    return sampled_x_new"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.326765Z",
     "end_time": "2023-09-17T13:57:05.328433Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "outputs": [],
   "source": [
    "# df_s0_d1"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.329233Z",
     "end_time": "2023-09-17T13:57:05.334342Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "fb6f9314",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:05.331057Z",
     "end_time": "2023-09-17T13:57:08.447813Z"
    }
   },
   "outputs": [],
   "source": [
    "# Apply the sampling function to each row\n",
    "df_s0_d1['X_new'] = df_s0_d1.apply(sample_from_Pxx_d1, axis=1)\n",
    "df_s1_d1['X_new'] = df_s1_d1.apply(sample_from_Pxx_d1, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "outputs": [],
   "source": [
    "df_s0_d0['X_new'] = df_s0_d0.apply(sample_from_Pxx_d0, axis=1)\n",
    "df_s1_d0['X_new'] = df_s1_d0.apply(sample_from_Pxx_d0, axis=1)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:08.449948Z",
     "end_time": "2023-09-17T13:57:11.298139Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "f8367861",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.305762Z",
     "end_time": "2023-09-17T13:57:11.324372Z"
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "# Group df_d1 by specified columns\n",
    "grouped_s1_d1 = df_s1_d1.groupby([\"S\", \"D\", \"Y\", \"X\", \"X_new\"]).size().reset_index(name=\"count\")\n",
    "grouped_s0_d1 = df_s0_d1.groupby([\"S\", \"D\", \"Y\", \"X\", \"X_new\"]).size().reset_index(name=\"count\")\n",
    "grouped_s1_d0 = df_s1_d0.groupby([\"S\", \"D\", \"X\", \"X_new\"]).size().reset_index(name=\"count\")\n",
    "grouped_s0_d0 = df_s0_d0.groupby([\"S\", \"D\", \"X\", \"X_new\"]).size().reset_index(name=\"count\")\n",
    "\n",
    "# Pivot the DataFrame to create a 4D array of counts\n",
    "pivot_table_s1_d1 = grouped_s1_d1.pivot_table(index=[\"S\", \"D\", \"Y\", \"X_new\"], columns=\"X\", values=\"count\", fill_value=0)\n",
    "pivot_table_s0_d1 = grouped_s0_d1.pivot_table(index=[\"S\", \"D\", \"Y\", \"X_new\"], columns=\"X\", values=\"count\", fill_value=0)\n",
    "pivot_table_s1_d0 = grouped_s1_d0.pivot_table(index=[\"S\", \"D\",  \"X_new\"], columns=\"X\", values=\"count\", fill_value=0)\n",
    "pivot_table_s0_d0 = grouped_s0_d0.pivot_table(index=[\"S\", \"D\",  \"X_new\"], columns=\"X\", values=\"count\", fill_value=0)\n",
    "\n",
    "# Replace 0 with 1 in the entire DataFrame\n",
    "pivot_table_s1_d1 = pivot_table_s1_d1.replace(0, 1)\n",
    "pivot_table_s0_d1 = pivot_table_s0_d1.replace(0, 1)\n",
    "pivot_table_s1_d0 = pivot_table_s1_d0.replace(0, 1)\n",
    "pivot_table_s0_d0 = pivot_table_s0_d0.replace(0, 1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "eca01460",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.323054Z",
     "end_time": "2023-09-17T13:57:11.327980Z"
    }
   },
   "outputs": [],
   "source": [
    "def round_down_up_to_fourth_digit(number):\n",
    "    rounded_down = math.floor(number * 10**4) / 10**4\n",
    "    return rounded_down"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "99dde51c",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.326097Z",
     "end_time": "2023-09-17T13:57:11.330094Z"
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "# Create a MultiIndex with all possible index combinations\n",
    "all_combinations = pd.MultiIndex.from_product(pivot_table_s1_d1.index.levels, names=pivot_table_s1_d1.index.names)\n",
    "\n",
    "# Reindex the pivot table to include all X_new values for each combination\n",
    "pivot_table_s1_d1 = pivot_table_s1_d1.reindex(index=all_combinations, fill_value=1)\n",
    "\n",
    "# Reorder the index levels if needed\n",
    "pivot_table_s1_d1 = pivot_table_s1_d1.reorder_levels(['S', 'D', 'Y', 'X_new'])\n",
    "\n",
    "# Sort the index if needed\n",
    "pivot_table_s1_d1 = pivot_table_s1_d1.sort_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "d0b50ba3",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.332812Z",
     "end_time": "2023-09-17T13:57:11.350366Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X              0    1     2      3\n",
      "S D Y X_new                       \n",
      "1 1 0 0      472   84   212     95\n",
      "      1       15    1     5      6\n",
      "      2       10    1     6      3\n",
      "      3       19    2     6      1\n",
      "    1 0      190   35   269    412\n",
      "      1      172  562   301    389\n",
      "      2       16  387  5064    403\n",
      "      3       14   37  3648  10720\n",
      "X              0   1   2    3\n",
      "S D Y X_new                  \n",
      "0 1 0 0      237  31  10    1\n",
      "      1        9   1   1    1\n",
      "      2       12   1   1    1\n",
      "      3       12   1   1    1\n",
      "    1 0       41   5   4    1\n",
      "      1       79  36   3    2\n",
      "      2        5  68  50    4\n",
      "      3        4   5  88  102\n"
     ]
    }
   ],
   "source": [
    "import math\n",
    "# Iterate through each entry defined by (s, d, y, x_new) in the pivot table\n",
    "\n",
    "for table in [pivot_table_s1_d1, pivot_table_s0_d1]:\n",
    "    print(table)\n",
    "    for s, d, y, x_from in table.index:\n",
    "        for x_to in [0, 1, 2, 3]:\n",
    "            divide_by = 0\n",
    "            element = table.loc[(s, d, y, x_to), x_from]\n",
    "            for i in [0, 1, 2, 3]:\n",
    "                divide_by += table.loc[(s, d, y, i), x_from]\n",
    "\n",
    "            Pxx_est[s, int(d), int(y), x_from, x_to] = element / divide_by\n",
    "\n",
    "# print(Pxx_est)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "9d01b950",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.356385Z",
     "end_time": "2023-09-17T13:57:11.357661Z"
    }
   },
   "outputs": [],
   "source": [
    "for table in [pivot_table_s1_d0, pivot_table_s0_d0]:\n",
    "    for s, d, x_from in table.index:\n",
    "        for x_to in [0, 1, 2, 3]:\n",
    "            for y in [0, 1]:\n",
    "                divide_by = 0\n",
    "                element = table.loc[(s, d, x_to), x_from]\n",
    "                for i in [0, 1, 2, 3]:\n",
    "                    divide_by += table.loc[(s, d, i), x_from]\n",
    "                Pxx_est[s, int(d), int(y), x_from, x_to] = element / divide_by\n",
    "                # round_down_up_to_fourth_digit(element / divide_by)\n",
    "\n",
    "# Pxx_est"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "e37182c0",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.357745Z",
     "end_time": "2023-09-17T13:57:11.360468Z"
    }
   },
   "outputs": [],
   "source": [
    "# Save the array to a binary file\n",
    "np.save(f'{save_estimations_path}/Pxx_est_{policy_type}.npy', Pxx_est)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "start_time": "2023-09-17T13:57:11.367457Z",
     "end_time": "2023-09-17T13:57:11.368717Z"
    }
   }
  }
 ],
 "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.8.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
