{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from stacked import plot_stacked_bars\n",
    "import tomli\n",
    "\n",
    "def load_config(path) -> dict:\n",
    "    with open(path, 'rb') as f:\n",
    "        return tomli.load(f)\n",
    "\n",
    "config = load_config('./assess.toml')\n",
    "dataset = 'adult'\n",
    "baseline = 'fairtabddpm'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['real', 'fairtabddpm'])\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>age</th>\n",
       "      <th>fnlwgt</th>\n",
       "      <th>education-num</th>\n",
       "      <th>capital-gain</th>\n",
       "      <th>capital-loss</th>\n",
       "      <th>hours-per-week</th>\n",
       "      <th>workclass</th>\n",
       "      <th>education</th>\n",
       "      <th>marital-status</th>\n",
       "      <th>occupation</th>\n",
       "      <th>relationship</th>\n",
       "      <th>race</th>\n",
       "      <th>sex</th>\n",
       "      <th>native-country</th>\n",
       "      <th>class</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>30</td>\n",
       "      <td>61081</td>\n",
       "      <td>14</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>35</td>\n",
       "      <td>Local-gov</td>\n",
       "      <td>Masters</td>\n",
       "      <td>Never-married</td>\n",
       "      <td>Adm-clerical</td>\n",
       "      <td>Not-in-family</td>\n",
       "      <td>White</td>\n",
       "      <td>Female</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>34</td>\n",
       "      <td>38639</td>\n",
       "      <td>9</td>\n",
       "      <td>99999</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>Private</td>\n",
       "      <td>HS-grad</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Machine-op-inspct</td>\n",
       "      <td>Husband</td>\n",
       "      <td>Black</td>\n",
       "      <td>Male</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&gt;50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>27</td>\n",
       "      <td>99695</td>\n",
       "      <td>13</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>Local-gov</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>Never-married</td>\n",
       "      <td>Adm-clerical</td>\n",
       "      <td>Not-in-family</td>\n",
       "      <td>White</td>\n",
       "      <td>Female</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   age  fnlwgt  education-num  capital-gain  capital-loss  hours-per-week  \\\n",
       "0   30   61081             14             0             0              35   \n",
       "1   34   38639              9         99999             0              40   \n",
       "2   27   99695             13             0             0              40   \n",
       "\n",
       "   workclass  education      marital-status         occupation   relationship  \\\n",
       "0  Local-gov    Masters       Never-married       Adm-clerical  Not-in-family   \n",
       "1    Private    HS-grad  Married-civ-spouse  Machine-op-inspct        Husband   \n",
       "2  Local-gov  Bachelors       Never-married       Adm-clerical  Not-in-family   \n",
       "\n",
       "    race     sex native-country  class  \n",
       "0  White  Female  United-States  <=50K  \n",
       "1  Black    Male  United-States   >50K  \n",
       "2  White  Female  United-States  <=50K  "
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = plot_stacked_bars(dataset, config, baseline)\n",
    "# df = data['real']\n",
    "df = data[baseline]\n",
    "df.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         Female      Male\n",
      "<=50K  0.377692  0.373358\n",
      ">50K   0.124851  0.124099\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([0, 1]), [Text(0, 0, '<=50K'), Text(1, 0, '>50K')])"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGjCAYAAAAPeU55AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA480lEQVR4nO3de1yUdf7//ycMgyAYmJp4SssCTaFIxLJPu6kUKJaHQrHU1NR1Pa2ZX7fSssP6EdPc3TTtoNYaRcWmiVquRm3bnrDyAJnCZrnlAXQ9kKODA8P8/vA384mdAbkQ5ZJ53G83bun7fb3f87riGnj6vq65rgCXy+USAACAiQU2dAEAAADnQ2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmF9TQBdSXiooKlZaWqkmTJgoMJIcBAHA5qKys1NmzZxUREaGgoOpjSaMJLKWlpdq/f39DlwEAAOqgU6dOatGiRbX9jSawNGnSRNK5HQ4NDW3ganCxOZ1OFRUVKTo6WhaLpaHLAVCPeH/7F7vdrv3793t+j1en0QQW92mg0NBQNW3atIGrwcXmdDolSU2bNuUHGtDI8P72T+e7nIOLPQAAgOkRWAAAgOkRWAAAgOkRWAAAgOkRWAAAgOk1mk8JAQDMxeVyeb6McH9KyP1fXF4CAgI8X/WJwAIAqFd2u13Hjh2TzWYzHFakc0EnKChI33zzTb3/0sOlERAQoPDwcLVo0aLe7o1GYAEA1Bu73a7vv/9ekZGR6tSpk6xWq+E5XC6X7Ha7QkNDCSyXqfLycpWWlur777/X1VdfXS+hhcACAKg3x44dU2RkpFq3bl3nOVwulwIDA2WxWAgslymLxaKQkBBJ546J9u3bX/CcXHQLAKgXLpdLNptNERERDV0KTCIiIqLOpwb/G4EFAFAv3BfY1uU0EBonq9VapwuvfSGwAADqRX38UkLjRGABAAB+gcCCy9b5nuwJAKidtWvXKiYmRnl5eQ1dSrX4lFAj4HJWKMDiX99Ki8Wi+Pj4hi6jQfjj9xsws7y8PI0ePbra/gULFmjo0KGXsKLGiZ96jUCAJUjOV2ZJDntDl4KLLThUlomLG7oKoM4qKp0KCrTUuE1AQIDCwsJMU09tJScnq1+/fl7tN998c73M7+8ILI2Fwy45yhq6CgCoUVCgRb/OW6cyZ3lDl6IQi1ULew2pt/m6dOmiQYMG1dt8qIrAAgC4pMqc5SpzVjR0GZfc119/rZdeekmff/65Tp06pdatW6t///6aMmVKlTvBPvroo1q3bp3y8vK0aNEiffzxxyorK1N8fLyefPJJderUSbm5uVq+fLm++eYbXXHFFRo5cqR+8YtfVHm9/Px8ZWVlafv27SopKZEkde7cWffff7/uvffeWtXscDj0hz/8QTk5Ofr3v/+toKAgxcXFacqUKerZs2f9/c+pBQILAAD1oKysTMePH6/SZrVa1axZM/3lL3/RlClT1KZNG40cOVItW7bU3r179frrr2v79u1as2aNgoKq/koeP368WrZsqalTp+rIkSN67bXXNG7cOP3qV7/SwoULlZ6erqFDh+qDDz7QkiVL1K5dOw0cONAzfuvWrfrXv/6llJQUtW3bVqdOndKHH36oxx9/XMePH9eECRNq3J+KigpNnDhRn3/+uVJTU5Wenq6ysjLl5OTowQcf1Isvvqg+ffrU3//A8yCwAABQD15++WW9/PLLVdq6deumrKwsPf744+rSpYvefPNNBQcHe/pvueUWTZ8+XRs2bNCQIVVPT91www165plnPH9v3ry5FixYoKeeekobNmzw3O4+LS1Nffr0UWZmZpXA8stf/lKPPPJIlTnHjRunUaNG6eWXX9aYMWNqvMnfm2++qX/84x9atmyZ7rzzTk/76NGjNWzYMP3mN78hsAAAcLkZOnSo7r777ipt4eHh+vvf/66jR49q8uTJstlsVfp79uyp0NBQ/fWvf/UKLOPGjavy98TERElS3759qzybJzg4WHFxcdq+fXuV7Zs2ber5c1lZmex2u1wul26//XZ98cUX+u677xQdHV3t/qxfv17t2rVTjx49vFaO+vbtq2XLlum7777TNddcU+0c9YnAAgBAPejQoYN69+7t1b5y5UpJ0tNPP62nn37a59j//Oc/Puf7qSuuuMJnu3TumT0nT56s0nb8+HG98MIL+uijj3T06FGvMaWlpb535P/37bffym6369Zbb612m2PHjhFYAABoDCorKyVJDz/8sOLi4nxu4w4jP2Wx+P64dXXtP+VyuTR+/HgVFRVp5MiRio2N1RVXXCGLxaJPP/1Ur7/+uqeumuq+5ppr9OSTT1a7zfXXX3/eWuoLgQUAgIvIvQLRpEkTnyswF0NhYaF2796t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vp07d0qSYmNjjUzp8d1330mSWrZsWafxAACg8TIUWJKSkhQWFqbs7GzZbDZP+6FDh7R582YlJiaqTZs2ks5d77Jv3z4dOXKkyhwnTpzwmreiokJLlizxvAYAAMBPGTolFBERodmzZ2vevHkaMWKEhg8fLofDoczMTEnSnDlzPNvm5+dr9OjRGjJkiDIyMjztd999t3r06KHo6GhdddVVKikp0QcffKB9+/YpNTVVd955Zz3tGgAAaCwM35o/PT1dkZGRWrVqlRYtWiSr1aqEhATNmDFDXbp0Oe/4u+++W9u2bdM///lP2Ww2hYaGKiYmRgsWLNCQIUMUEBBQpx0BAACNV50efpiSkqKUlJQat+nVq5cKCwu92n/961/X5SUBAIAfq/sd2gAAAC4RAgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADC9OgWWLVu2aNiwYbrpppvUs2dPTZo0SUVFRXUqYM+ePerWrZtiYmK0fv36Os0BAAAaN8OBJTs7W9OmTZPdbtesWbM0adIkFRYWKj09XYWFhYbmqqio0Jw5cxQcHGy0DAAA4EcMBZbS0lJlZGQoKipKWVlZGjlypB566CG9+eabcrlcmj9/vqEXX716tfbv368JEyYYGgcAAPyLocCSm5srm82mtLQ0hYeHe9rbtm2r5ORk5eXl6fDhw7Wa67vvvtOyZcv08MMPKyoqyljVAADArxgKLLt27ZIkxcfHe/W52woKCs47j8vl0pw5c9SlSxc98MADRkoAAAB+KMjIxiUlJZLkc0XE3VZcXHzeed566y3l5+frvffeU2Bg/X5Qyel0yul01uucZmexWBq6BFxi/naMw7+4j2+Oc/9Q2++zocBit9slyedFsu62srKyGuc4dOiQnn/+eY0bN04xMTFGXr5W6vpppctVYGCgzxUvNG75+fmqrKxs6DKAi6o2K/bwH4YCS2hoqCTJ4XB49bnbQkJCapzjySef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vn/d7133Nj81duxY7dmzR++//74qKir03HPP8XDdyxxXDuKCrFixQgMGDNB3332nIUOG6J577tHLL7+sH3744bxjT58+raNHj9b6q7bat2+viooKnTx50tMWFRWlEydO+PyhV1JS4tnmv91222165ZVX5HQ6NW7cOH3xxRe1rgPwJw6HQx9//LEeeeQR9e7dW0uXLtU111yjGTNm+Lz1gC/ua8+OHz/uaXO/L93v059ynwry9d4NDg7W0qVLdeedd2rjxo16+OGHa7y4F+bHCgsuSN++fdW3b1+dPn1aW7du1caNG/XCCy9oyZIluvHGGzVgwAD179/f5/nn1atXX9A1LNXZv3+/rFZrlfs7xMXF6dtvv9WuXbu87r+wY8cOXX311V4X3Lr16tVLK1eu1IQJEzR+/HitWLFCt956a63rBhorp9OpvLw8bdy4UVu3btWPP/6oNm3aaMSIEbrnnnsMfyJn//79klTl4lj3J4N27Njhtf3OnTurbPPfgoOD9bvf/U6zZs3Shx9+qIqKCv3ud7/j/kmXKQIL6kVYWJgGDx6swYMH6/jx4/rggw+0YcMGLViwQAsXLlRCQoKmTZumxMREz5gLuYblxIkTXjecks59hHH37t3q06dPlR9KgwYN0vvvv6/Vq1dXCSxbtmzRwYMHNW3atBpfr0ePHnrttdc0fvx4TZo0ScuWLdPtt99ep9qBxuCZZ57R5s2bdezYMUVGRqp///4aOHCgevbs6fMie7eKigrZ7Xavi3HtdruWLl0qSerXr5+nvUOHDrr55pu1bds2ffXVV+revbtnnjfeeEPNmjVT3759q329oKAgPf/887JarZ6bzS1btsxzuhiXDwIL6t2VV16pkSNHauTIkfrhhx+0YcMGbdq0SXl5eVUCy4Vcw7JixQpt375dt9xyi9q0aaPy8nJt375dW7ZsUatWrTRnzpwq2/fu3VsDBw7Uxo0bNWnSJPXr108HDhzQ66+/ruuuu87r/iy+3HjjjXr99dc1btw4TZ48WS+88IL69OlTp/qBy917772nvn37auDAgfrZz34mq9Vaq3FnzpzxrMx27txZV155pQ4ePKh169apuLhYEyZM8IQSt7lz52rkyJF66KGHNGbMGDVv3lzr16/X7t27NX/+fJ+fRPopi8WihQsXymq16r333tOkSZO0fPlyn9e+wLwCXC6Xq6GLgH84ffq0wsLC6mWu3NxcZWVl6V//+pdOnDghl8uldu3a6Y477tCECRPUokULrzHl5eVavXq11q5dq4MHDyoyMlJ9+/bVjBkzvO7xMmrUKH355Zf6+uuvvebZu3evxo4dq1OnTmnJkiW666676mWfgMtJXd/PDodDzzzzjPLz81VcXCybzaZmzZqpe/fuGjFihJKSknyO27t3r37729/qyy+/VHl5uaKjozVhwgSv919eXp5Gjx6tX/3qV5o8eXKVPpfLpaefflpZWVlKTEzUSy+9VG8/k3DxEVgAAIDp8SkhAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgev8feOVNvrkqRA4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# stacked bar plot\n",
    "import seaborn as sns\n",
    "\n",
    "# target col\n",
    "target_col = 'class'\n",
    "# sensitive col\n",
    "sens = ['sex', 'race']\n",
    "\n",
    "# count df\n",
    "count = {}\n",
    "for s in sens:\n",
    "    count[s] = {}\n",
    "\n",
    "for s in sens:\n",
    "    # count[s] = df.groupby([target_col, s]).size().unstack().fillna(0).to_dict()\n",
    "    # norm \n",
    "    count[s] = df.groupby([target_col, s]).size().unstack().fillna(0).apply(lambda x: x/len(df), axis=0).to_dict()\n",
    "\n",
    "import pandas as pd\n",
    "\n",
    "print(pd.DataFrame(count['sex']))\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "pd.DataFrame(count['sex']).plot(kind='bar', stacked=True, ax=ax)\n",
    "\n",
    "# rotate x-axis labels\n",
    "plt.xticks(rotation=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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PdGqVSsAT+e7ZGZmwtraGnZ2dgCAgQMH6uyBSUpKwo4dOxASEgIPDw907ty5usdFREREDYhegcXGxgaLFi3CsmXLMH78eAQGBqK0tBRRUVEAgCVLlqjXTUlJQWhoKAICAhAREQEAaNu2Ldq2bau136KiIgBPe2f8/PyqfDBERETUMOkVWAAgKCgItra22Lx5M1auXAmpVAoPDw/MmzcPLi4utVEjERERGTm9AwsA+Pn5vbQnxMvLq9L3Fho1ahRGjRpVlVKIiIjICNTsVduIiIiIagEDCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJHgMLERERCR4DCxEREQkeAwsREREJnklVNjp8+DA2bdqE9PR0SKVS9OzZEwsWLICTk9NLtz1+/Dh27tyJtLQ05ObmQiQSwdHREb6+vggNDUXjxo2rUhIRERE1YHoHlpiYGCxduhROTk5YuHAhSkpKEBUVhaCgIERHR8PZ2bnC7a9duwYAGDVqFOzs7FBWVobU1FR8++23OHDgAHbv3g1LS8uqHQ0RERE1SHoFlvz8fERERMDe3h7R0dGwsrICAAwZMgTDhg3DihUrsG3btgr3MWXKFEyZMkWrvUOHDli1ahUOHz6MkSNH6lMWERERNXB6zWFJSEhAQUEBxo4dqw4rAODg4ABfX18kJibi3r17VSrE0dERAPD48eMqbU9EREQNl149LBcuXAAAuLu7ay1zd3dHfHw8UlNT0apVq5fuq7CwECUlJSgqKsLly5exatUqSKVS9OvXT5+StMjlcsjl8mrto76RSCSGLoHqmLE9x8m4qJ7ffJ4bh8r+nvUKLFlZWQAAe3t7rWWqtvv371dqX8uXL0d8fLz6+44dO2L9+vXo0KGDPiVpSU9Pr9b29Y1YLNYZIKlhS0lJgUKhMHQZRLUqNTXV0CWQgOgVWGQyGQDA1NRUa5mqrbi4uFL7mjJlCt566y3k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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.DataFrame(count['race']).plot(kind='bar', stacked=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ai",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
