{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "218b4295-ae1e-4e3c-ab3a-62311a3b8317",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "parent_dir = os.path.abspath('../..')\n",
    "sys.path.append(parent_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a5bfd914-6e35-4bc4-b5ef-7097040fbef7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from eval_utils import _calculate_dcr\n",
    "from sdv.metadata import SingleTableMetadata\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9564dfea-10c0-4202-a473-fa0cec4c99a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_train = pd.read_csv(\"../sample/ATACH/data100.csv\")\n",
    "data_test = pd.read_csv(\"../sample/ATACH/data_test.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "f3b06458-7eea-4974-8052-50351e418da6",
   "metadata": {},
   "outputs": [],
   "source": [
    "metadata = SingleTableMetadata()\n",
    "metadata.detect_from_dataframe(data_train)\n",
    "meta_data = metadata.to_dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9dbb0699-f8b0-4459-8617-65708b7706c1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'columns': {'treatment': {'sdtype': 'categorical'},\n",
       "  'age': {'sdtype': 'numerical'},\n",
       "  'ICH volume': {'sdtype': 'numerical'},\n",
       "  'ICH Location': {'sdtype': 'categorical'},\n",
       "  'IVH volume': {'sdtype': 'numerical'},\n",
       "  'GCS score': {'sdtype': 'categorical'},\n",
       "  'NIHSS score': {'sdtype': 'numerical'},\n",
       "  'Systolic blood pressure': {'sdtype': 'numerical'},\n",
       "  'Diastolic Blood Pressure': {'sdtype': 'numerical'},\n",
       "  'Hypertension': {'sdtype': 'categorical'},\n",
       "  'Hyperlipidemia': {'sdtype': 'categorical'},\n",
       "  'Type I Diabetes': {'sdtype': 'categorical'},\n",
       "  'Type II Diabetes': {'sdtype': 'categorical'},\n",
       "  'Congestive heart failure': {'sdtype': 'categorical'},\n",
       "  'Atrial Fibrillation': {'sdtype': 'categorical'},\n",
       "  'PTCA': {'sdtype': 'categorical'},\n",
       "  'Peripheral Vascular Disease': {'sdtype': 'categorical'},\n",
       "  'Myocardial fraction': {'sdtype': 'categorical'},\n",
       "  'Anti-diabetic': {'sdtype': 'categorical'},\n",
       "  'Antihypertensives': {'sdtype': 'categorical'},\n",
       "  'White blood count': {'sdtype': 'numerical'},\n",
       "  'Hemoglobin': {'sdtype': 'numerical'},\n",
       "  'Hematocrit': {'sdtype': 'numerical'},\n",
       "  'Platelet count': {'sdtype': 'numerical'},\n",
       "  'APTT': {'sdtype': 'numerical'},\n",
       "  'INR': {'sdtype': 'numerical'},\n",
       "  'Glucose': {'sdtype': 'numerical'},\n",
       "  'Sodium': {'sdtype': 'numerical'},\n",
       "  'Potassium': {'sdtype': 'numerical'},\n",
       "  'Chloride': {'sdtype': 'numerical'},\n",
       "  'CD': {'sdtype': 'numerical'},\n",
       "  'Blood urea nitrogen': {'sdtype': 'numerical'},\n",
       "  'Creatinine': {'sdtype': 'numerical'},\n",
       "  'race': {'sdtype': 'categorical'},\n",
       "  'sex': {'sdtype': 'categorical'},\n",
       "  'ethnicity': {'sdtype': 'categorical'},\n",
       "  'mRS score after 30 days': {'sdtype': 'categorical'}},\n",
       " 'METADATA_SPEC_VERSION': 'SINGLE_TABLE_V1'}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "meta_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e0f21f2f-3277-4287-a5ef-b41f58d52387",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_val = _calculate_dcr(data_train, data_test, meta_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "eff7aa92-69ac-44ed-84b4-ae96427cb497",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_72697/848251320.py:11: UserWarning: No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n",
      "  plt.legend(fontsize=12)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABVq0lEQVR4nO3dfXxP9f/H8ednV5/ZzGyuJzZJhSVifaWJUiMsIl0gl4VU36/oipaJX4Skb31F+eaikoSUSVrKQiSxrlwmG7Jc25aZzbbz+8Nt57uPbWzOZxef7XG/3T6327l4f855neN85vP8nHPex2YYhiEAAAAAsMCtrAsAAAAA4PoIFgAAAAAsI1gAAAAAsIxgAQAAAMAyggUAAAAAywgWAAAAACwjWAAAAACwjGABAAAAwDKCBQAAAADLCBYASk1ISIhsNtsVvRITE0u8vgULFjisc8KECSW+zopo0KBBRdqPcXFxDu1CQkKcVkNiYqLDsjt27Fis919c26BBg5xWm6uZMGFCvs+jh4eHfHx8VLduXd144426//77NXv2bKWmphZ5uTt37tRzzz2nW2+9VXXr1pXdbpePj48aNWqke+65R2+++aaOHz/u8J6OHTsW+PfBzc1NVatW1TXXXKP77rtPn3zyiQzDcPauAHAZBAsAACqgiwNeXFyc05adnZ2t9PR0HT16VL/88ouWLl2qkSNHKigoSNOmTbvkl/qUlBT17dtXoaGhmjZtmjZt2qSjR48qMzNT6enpSkxMVExMjP75z3+qc+fORarHMAylpaXpjz/+0PLly9W7d2/dd999hAuglHmUdQEAKo+uXbvq2LFjDtN27typXbt2mePBwcFq06ZNvvf6+vqWeH0hISHq3bu3Od6sWbMSXyfganI/oxkZGfrzzz/166+/Kjs7W5KUlpam5557Ttu3b9fixYtls9kc3nvy5Endeuut2rNnj8P0GjVq6KabbpLdbldSUpJ++eUXZWVlKScn55K1tGnTRsHBwTp79qzi4+N15MgRc94nn3yixYsXq2/fvk7acgCXQ7AAUGreeuutfNMmTJigl156yRzv2LGjFixYUIpV/U/Hjh2LfckMUNlc/Bn966+/NG7cOIdpS5YsUWhoqKKiohze+8ADDziECi8vL82cOVPDhw+Xu7u7OT05OVnz58/XqlWrLlnL448/bl6mlpGRoTvuuEObNm0y569evZpgAZQiLoUCUO4VdO9DQkKCBg0apPr168vDw8P8cnHy5ElNmjRJvXv3VvPmzR2u3W7YsKHuueceLVq0qMBfQi93j8XF13cnJibqm2++Ubdu3RQYGChvb281b95cM2fOLNYlGNOnT3dYbkEBLCcnR1dddZXZJiAgQOnp6Zdd9q5du/TYY4+pefPm8vPzk4eHh2rUqKHrrrtOPXv21P/93/9p3759Ra61LCQnJ2v69Onq0KGDatasKU9PTwUGBio8PFwzZ85UWlraFS03KytLr7/+ulq0aCFvb2/VrFlTvXr1Unx8vFPrP3nypCZPnqzw8HCz/oCAALVp00Zjx47VoUOHCnzf5e4/KexSp9zpCxcudGh/++23l8ilUfXq1dP8+fM1ZMgQh+lTp07ViRMnzPHVq1fr66+/dmjz3//+VyNHjnQIFZJUvXp1PfXUU1q9enWR67Db7brvvvscpuVdP4CSxxkLAC4nPj5eM2fOLPBG0YSEBI0fP77A9x06dEiHDh1STEyM3n//fcXExMjT0/OK64iOjtZ7773nMG3nzp0aPXq0Dhw4oNdff71Iyxk0aJCioqKUmZkpSXrvvfc0cuRIhzbffPONDh8+bI73799fVapUueRyN27cqLvuukvnzp1zmH7q1CmdOnVKe/fu1Weffabq1avriSeeKFKtpW3jxo3q06ePwyUuknT69Gl99913+u677zR79mytWrVK1157bZGXm5WVpR49ejh8cc3IyNCKFSu0atWqfPv/Sn399dd68MEH833BTU5O1rZt27Rt2za98cYbmjt3rsv/sj5lyhR98MEH5nF85swZffbZZxo6dKgkafHixQ7tW7RooYcffviSy7Tb7cWq4eJAHxQUVKz3A7CGYAHA5axcuVKSdNVVV+mGG27QyZMn8/3iWbduXQUHBysgIEBeXl46ceKE4uPjzV/5v/zyS82aNUujRo264jree+89Va1aVTfffLMOHjzo8Mv/m2++qTFjxqhBgwaXXU6tWrXUs2dPffzxx5KkLVu26Pfff1eTJk3MNu+//77De4YNG3bZ5U6aNMkhVLRq1UoNGjRQcnKykpKSlJCQYF4bX5I+/vhj/fbbb/mmX9zjz8X++OMPdevWzSFAhoaGKiQkRAkJCdqxY4ck6ffff9fdd9+tX3/9VT4+PkWqaerUqfl+DW/RooVq1aqlH374Qf/+97+LtJxL2b17t3r06OFwRiUoKEg33HCDfv/9d+3fv1+SdPbsWQ0YMED169dXhw4dLK83LCxMZ86c0Y8//qgDBw6Y02+77TbVqlXLHM877Ay1a9dW69attXnzZnPad999ZwaL7777zqF9165dnbr+c+fOaenSpQ7T7r33XqeuA8BlGABQhqKjow1J5mvgwIH52syfP9+hjSTjueeeM7Kzs802586dMwzDMJKTk429e/cWuK4jR44Yvr6+5jL+8Y9/XHI90dHRDvM7dOjgMD84ONhITEw0DMMwzp8/b3Tq1Mlh/sKFC4u8H9auXevw3qioKHNeWlqaUbVqVXNe27Zti7TMJk2amO8ZMmRIvvmnT582li5damzevLnIdRbFwIED8/17FeUVHBzssJz+/fs7zF+8eLHD/MmTJzvMf/XVV815CQkJDvM6dOhgzsvIyDACAwMv+d569epd9ri8nAcffNBhGffcc4+Rnp5uGIZhZGdnG8OGDXOYf/G/66X2TUH7ed26dcWaX1RF+YzmeuCBBxzadu3a1Zzn4+PjMG/OnDnFruXiz2CbNm2M3r17G3fffbdRp04dh3mPPvrolWwuAAs4YwHA5Vx77bV6+eWX5eb2v9vEci+Z8Pf3159//ql//vOf2rBhgxITE3XmzBllZWXlW87u3bst1fH8888rODhYkuTh4aGuXbs6XEOe99Kly7njjjt0zTXXmGc9PvjgA02cOFE2m00rVqzQmTNnzLZFOVshXei95/fff5ckrVmzRtOmTVOzZs3UuHFjNW7cWNWrV893TXp5kZOTY56Zki7c5Lts2TItW7bMnPb33387vCcmJkZjxoy57LK3b9+uU6dOmeP169d3OHMVEhKixx9/PN+Nx7l27Nih6OjoAufdfvvtevzxx5WTk6PPP//cYd7UqVPl7e0tSXJzc9PUqVO1YMEC89KhLVu26Pjx404/k1CaLr536eJeofIynNAV7I8//qgff/zRYZqvr6/++9//6sEHH7S8fADFQ7AA4HLat2+f79KnXB9//LH69etXYJC4WEpKiqU6wsLCHMb9/f0dxjMyMoq8LJvNpkceeUTPP/+8pAsPeNuwYYNuu+02h8ug/P399cADDxRpmVFRUdqwYYMyMjKUlJSk5557zpzn5eWl1q1bq2/fvho2bJi8vLyKXGtxRUdH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rl3VtWtXh2lNmjRRq1atJEl///23JOmHH35QfHy8JKlp06aaM2eObDabwsLCVL9+fRmGoXfffVeTJ0+Wp6dnqdUPAAAAVESW77EoLFQU1PWss+Xk5CgpKUlvv/22Oe3222+XJG3cuNGc1rZtW7OWevXqKSQkRJJ0+vRp7dixo0RrBAAAACoDS2cs1q1bl29aRkaGfv/9d82aNUt79uxRt27d9PTTT1tZTYHatm2rLVu2mOM2m03dunXTu+++K0lKTEw059WpU8fhvbVr11ZCQoIkKSEhQS1btixwHRkZGcrIyDDHueEbAAAAKJilYNGhQ4cCp0dERKh///4KDQ3V6tWrNWzYMCurKRI3Nzd5eHgoJydHkpSWlmbO8/Lycmibdzxvu4tNmTJFL730kpMrBQAAACoep3U3ezF/f3/deuutMgxDr7zyitOX/8477yguLk7vv/++2rVrp+zsbH366aeKjIyUJPn6+ppt8551kKTMzExzOG+7i40dO1YpKSnm69ChQ07eCgAAAKBicMrN2wVJTU3VDz/8IEn66aefnL78Fi1amMO9evVSjRo1dO7cOf3444/au3eveR+FJB09etThvUeOHDGHGzVqVOg67Ha77Ha784oGAAAAKihLweKOO+7IN80wDKWnp2vPnj3mPQne3t5WVuMgPT1dVapUyTc9743iycnJCg8PN8c3b94swzBks9l0+PBh8/kbAQEBat68udNqAwAAACorS8EiLi6u0J6fcr/I22w2RUREWFmNgzZt2qht27YKDw9Xw4YNdezYMb311ltKT0+XJFWpUkVNmzaVn5+fWrVqpfj4eO3Zs0fDhw9X9+7dNWPGDLMnq6FDh9LVLAAAAOAEli+FutQzLAzDUJMmTfTqq69aXY0pLS1N8+bN07x58wqc/+qrr5pP0543b546duyolJQUzZ07V3PnzjXbtWzZUuPHj3daXQAAAEBlZilYDBw4sMDpbm5uql69usLCwnTvvfc69T6Fp59+WjExMdq5c6eOHz8uwzAUFBSkW265RY899pjat29vtm3ZsqW2bt2qCRMmaO3atUpOTlb9+vXVp08fvfDCC2YAAQAAAGCNpWAxf/58Z9VRZE888YSeeOKJIrdv0qSJFi1aVIIVAQAAACix7mYBAAAAVB6WzlisX7/+it972223WVk1AAAAgHLEUrDo2LFjob1CXYrNZlNWVpaVVQMAAAAoR5zygLxL9QyVl81mK3JbAAAAAK7D8j0Wuc+rKMjF0wkVAAAAQMVkKVjs379fkZGRMgxDjz76qL799lvt3r1b3377rR555BEZhqHu3btr//79SkhIMF/79+93Vv0AAAAAygFLl0J9+eWXWrVqlXr16qW3337bnH7ttdeqffv2OnnypD799FN16dJFI0eOtFwsAAAAgPLJ0hmLN998U5IUGhpa4PwbbrhBhmFo1qxZVlYDAAAAoJyzFCz++OMPSdKqVat0/vx5h3nnz59XTEyMJHHpEwAAAFDBWboUqlatWjp8+LDi4+MVGhqq3r17q3bt2jp27JiWL1+uffv2me0AAAAAVFyWgsVDDz2k6dOny2az6ffff9fUqVPNebk9QNlsNvXt29dalQAAAADKNUuXQkVHR6tdu3aX7HL2lltuUXR0tJXVAAAAACjnLAULHx8fxcXFaerUqWrSpIkMwzBf1113naZNm6a4uDhVqVLFWfUCAAAAKIcsP3nbw8NDzzzzjJ555hmdOXNGKSkp8vf3V9WqVZ1RHwAAAAAXYDlY5FW1alUCBQAAAFAJWboUKtfmzZt13333KSgoSJ6ennrttde0adMmTZw4URMnTlR6erozVgMAAACgnLJ8xuKNN97Q6NGjzXsrcm/irl69uiZMmCCbzaZrr71WDz74oOViAQAAAJRPls5YfP/99w6hIq9mzZrp+uuvlyR98cUXVlYDAAAAoJyzFCxee+015eTkSJK6du2ab/6tt94qwzD0448/WlkNAAAAgHLOUrDYuHGjbDabunTpolWrVuWbHxwcLEk6dOiQldUAAAAAKOcsBYuTJ09KunBmoiC5ZzPOnTtnZTUAAAAAyjlLwSK3a9nDhw8XOH/btm2SpICAACurAQAAAFDOWQoWoaGhMgxDixYt0rfffmtOT09P19tvv63PP/9cNptNLVq0sFwoAAAAgPLLUnezffr00YYNG/T333/rjjvukCQZhqHx48ebwzabTX369LFeKQAAAIByy9IZi2HDhunGG280u5q12Wyy2WwOXc+2bNlSQ4YMsVYlAAAAgHLNUrDw8vLSV199pYiICPNZFrmhwjAM3XXXXVqzZo08PCw/hw8AAABAOWb5G3/NmjW1Zs0a/frrr/ruu+906tQpBQYGql27dtxbAQAAAFQSVxws/v77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19ccvvgG7czMzALb5TV27FiNHj3aHM/JydGpU6dUo0YN2Ww2J1dbuNTUVDVo0ECHDh1StWrVSm29FQ370TnYj9axD52D/egc7Efr2IfOwX50DmfvR8Mw9PfffysoKOiybSt0sAgJCTGHT548qaysLHl4XNjkI0eOmPMaNWpU4PvtdrvsdrvDtOrVqzu9zqKqVq0aHzQnYD86B/vROvahc7AfnYP9aB370DnYj87hzP3o7+9fpHYV+ubtwMBANW3aVNKF51ls3brVnLd582ZzuH379qVeGwAAAFCRVOhgIUkjRowwhx999FF98sknioqKUmxsrCTpqquuUvfu3cuqPAAAAKBCqNCXQknSyJEjtXLlSn399dfasWOHevfubc6z2+1asGBBvsudyhu73a7o6OhyX2d5x350DvajdexD52A/Ogf70Tr2oXOwH52jLPejzTCK0neUa8vIyNCMGTP0/vvvKyEhQb6+vgoPD1d0dLRuuummsi4PAAAAcHmVIlgAAAAAKFkV/h4LAAAAACWPYAEAAADAMoIFAAAAAMsIFmUsLi5ONput0NeECRMc2m/btk09evRQjRo15O3trWbNmmnKlCkOTxKvjEJCQi65H202m+Li4iRJgwYNumS7xMTEMt2W0nDq1CmNHTtWHTp0kI+Pj7ntgwYNKrB9cY67jIwMTZ48Wc2aNZO3t7dq1Kihnj17avv27SW8VaWvqPsxMzNTb7/9tu6//35df/31qlatmqpUqaJmzZpp/PjxSktLc2ifmJh4yWO0sH8nV1Wc47Fjx46X3DcXqyzHY1H34YIFCy77t7Jjx45m+8p0LMbHx+v5559Xu3btVL9+fXl5ealWrVqKjIzUhg0b8rXft2+f+vXrpzp16shut6tx48Z67rnnlJqamq9tTk6OZs+erVatWsnHx0f+/v6688479fXXX5fGppWq4uzH999/XwMHDlTz5s0VEBAgu92ua665Rv/617904sSJfMsu6nFbERRnPxb3e02JHo8GytS6desMSYW+oqOjzbZffvml4eXlVWC7iIgIIysrq+w2pIwFBwdfcj9KMjZu3GgYhmEMHDjwku0SEhLKdmNKQXx8fIHbPnDgwHxti3PcnT9/3ujUqVOBbe12u7F27dpS3MqSV9T9+Ndff13ymAsLCzMyMjLM9gkJCZdsX9C/kysrzvHYoUOHS+6bvCrT8VjUfTh//vzL/q288847zfaV6VgcPnx4odvp5uZmLF++3Gz7008/Gf7+/gW2bdmypZGamuqw7ML+37HZbMbChQtLe1NLVHH2o91uL7Rto0aNjJMnTzos+1LHYocOHUp5S0tWcfZjcb/XlOTxWOGfY+FK3njjDbVq1cphWsOGDSVJ6enpGjx4sPkLcVRUlFq1aqXo6Gj99ttvio2N1Zw5c/T444+Xet3lwbJly3Tu3DmHabt379ajjz4qSapXr55uvvlmh/l169bV0qVL8y2rXr16JVdoOeHl5aXbbrtN7dq107FjxzRv3rwC2xX3uHvrrbfMXzxCQ0P10ksvKT4+Xv/3f/+njIwMDRo0SPv27aswfZQXdT9KF35p69Klix544AHVq1dPsbGxmjFjhiRp69atWrRokQYPHpzvfePGjdPdd9/tMK1OnTrO3ZAyVpz9mKtly5Z68803L9mmMh2PRd2HXbt2LfDX92effVabN2+WJPXs2bPA91aGY7Fu3boaOnSowsPDdfr0ab300kvas2ePcnJyNHr0aPXq1UuSNHjwYKWkpEiShg0bpm7dumnGjBlav369fvrpJ02cOFHTp0+XJK1cuVILFy6UJAUFBem1117TX3/9pWeeeUZZWVl6/PHH1blz5wq1L4u6H202m8LDw9W/f381btxY33//vSZNmqTMzEwlJCTo3//+t1566aV8yx88eLCGDBniMM3f379Utq00FXU/5m1/ue81JX48WoolsCzvGYt169YV2m7JkiVmu86dO5vTN2/ebE4PDQ0thYpdxxNPPGHum7xnfnKTenBwcJnVVp7Mnj270F8fi3vcNW3a1Jy+efNmc3rnzp3N6cuWLSvxbSoLl9qPqampxqZNm/K9p2fPnuZ7HnvsMXN63l+J58+fX8KVly+X2o+G8b8zFkX5dbKyHo+X24cX++uvvwxPT09DkuHn5+fwa3tlOhY3bNhgpKWlOUz76aefHH7RPXr0qLFlyxZzvGnTpkZOTo5hGIaRlJRk2Gw2Q5IREBBgZGZmGoZhGHfffbfZfvHixeay8/4i/eqrr5behpawou5Hw7hwRvxio0aNMtvdfffdDvMK+j+9oirOfizO95qSPh65x6Ic6devn+x2uwICAhQREaG1a9ea8zZu3GgOt2vXzhxu06aNPD09JUm//fabTp8+XXoFl2NpaWl67733JEkeHh4aNmxYvjZ//fWX6tWrJy8vLwUHB+uxxx7TX3/9VdqllmvFOe5OnTqlXbt2SZI8PT0VFhZW4HsL+rW0ovPz89Mtt9ySb3qTJk3MYV9f3wLfO3bsWFWpUkXVqlVTeHi4Pv744xKr05Vs27ZNNWvWlN1uV5MmTfTss886XNvO8Vh0c+fO1fnz5yVJDz/8sPz8/ApsV9GPxfDwcPn4+DhMy/sZlSQfHx+Hv4tt27Y17+2pV6+eQkJCJEmnT5/Wjh07ZBiGvvvuO7N93mOvoh6HRd2PkhQREZHv/UX5u/jWW2/J19dXvr6+at26tWbPni2jgj2WrTj7MdflvteUxvFIsChHkpKSlJmZqeTkZH311VeKiIjQggULJMnhxpu8p6c8PDwUGBhojleGG4+L4oMPPjC/ZNx7770KCgrK1yYzM1NHjhzR+fPndfDgQc2ZM0dhYWFKSkoq7XLLreIcd3nb1qhRQ+7u7uZ47dq1zeGEhISSKdbFnD9/XjExMeb4xZeY5Dpy5IjOnTunv//+W999950eeOCBAi8NqGzOnDmjkydPKjMzU/v27dP06dMVHh6uM2fOSBLHYxFlZ2frnXfeMcdHjhxZaNvKeCwuX77cHG7fvr2qVq1a6N9FKf+xdfr0aYfAm7d9ZToOC9qPhfnkk0/M4cL+Lh4/flxnz57V2bNntX37do0cOTLfpVEV0eX24+W+15TG8UiwKGPu7u66/fbb9eabb+qLL77Q4sWL1aZNG0kXkuWoUaOUlpbm0GuMl5eXwzLyjl/cu0xl9dZbb5nDF993Ur16dT3yyCP64IMPFBsbq6lTp6patWqSpMOHD2v8+PGlWmt5VpzjjmO06HJycvTII49o9+7dkqTevXvrjjvuMOfbbDbdfPPNevXVV7Vq1SotX77c4Ze9SZMmVdofEerWratRo0bpo48+0po1axQVFWUeX7/++qtef/11ScU7diuzzz77TH/++aekCz1uNW/e3GF+ZT4Wt23bpieffFKSZLfbNXPmTElX/nfx4vmV5TgsbD8WJCoqyrwvqm3bthowYIDD/GbNmmnSpEn69NNPFRMTo4ceesict2DBAoezSRXNpfZjUb/XlMbxyM3bZax9+/b65ptvHKZ16dJFISEhSklJUUpKijZt2uRwOjAjI8Ohfd4uPws7bViZbNy4Ub/88oskqXnz5urQoYPD/NwvHrnuuusu1apVy/y144svviiVOl1BcY67vKehOUYLd/78eT388MNasmSJpAt/A3Iv28sVHBysLVu2OEyLjIxUs2bNtG/fPmVnZ+urr74yOyeoTD766COH8c6dO8vNzU0TJ06UdOHzGxUVxd/MIrrUjzBS5T0WN27cqG7duik1NVUeHh5avHixWrduLal4fxcvPr4yMjLk7e1dYNuK6FL78WJPP/202aHF9ddfr5UrV8rDw/Fr6o4dOxzGu3fvrsOHD2v9+vWSLnz+w8PDS2BLytbl9mNRv9eUxvHIGYtyqHr16g7X0R0/fty8blOSjh49ag5nZWXp5MmT5njedpXV5f6jLEjeHqOOHz/u9JpcVXGOu7xtT548qaysLHP8yJEj5nCjRo1KplgXcO7cOfXq1csMFZ06ddIXX3yR7zrZgnh6eqply5bmOMfp/xT0+eV4vLy9e/eaP2wFBQUV2hvUxSr6sRgbG6vOnTsrNTVVdrtdy5Yt07333mvOL+zvopT/2AoICDB/Ob64fUU/Di+3H3Pl5ORo+PDhZqho0aKF4uLiVKtWrSKtp6L//13U/XixgvZLaRyPBIsytm3btnzTkpOTtXfvXnO8Tp06Dgl806ZN5vDWrVvN/zBDQ0MVEBBQgtWWf8eOHTOvQaxWrZoefvhhh/mpqan6/fff870v7y9yFanLP6uKc9wFBgaqadOmki4Ej61bt5rtc7uxlC78Ql8ZnTlzRt26ddOqVaskST169NDnn39e4C9DP/30k7Kzsx2mnT9/XvHx8eZ4ZTxOk5KSCuxgoaDPL8fj5b311lvmmcbhw4fn+3VYqnzH4ooVKxQZGamzZ8/K19dXn3/+uXr06OHQJu/fxc2bN5v78PDhwzp48KCkC1/gmjdvLpvNpltvvdVsn/fvaEU+DouyH6ULn82HH37YvM+nbdu2iouLK/CY2rFjR75u5SXphx9+MIcr0rEoFW0/Fud7TWkcj1wKVcbGjBmj5ORkDRgwQC1atNCJEyc0Y8YM8+aamjVrmnfqBwUFKSkpSbGxsXrhhRfUunVrh/sBRowYUSbbUJ7MnTvXPJ03YMCAfDc2nTp1Ss2bN1evXr0UGRmpOnXqaPv27Xr55ZfNNgX98atozp49q9WrV0uSwxeEAwcOaNmyZZKksLAwRUZGFuu4GzFihP71r39Jkh599FFNnDhR27dvV2xsrCTpqquuUvfu3Ut8+0pLUfdj7dq1ddddd+n777+XdOEXuVGjRjl82a1Tp455pvL111/Xxo0bNXjwYLVp00Znz57VnDlz9Mcff0i6cH1tly5dSmUbS0NR92NCQoK6deumhx56SJ07d5a/v782bNigadOmme/J+/mtTMdjUfdhcHCw2T63cxBPT88Ce86TKtexuHTpUj300EPKzs6WzWZTdHS07Ha7w3X7YWFhuvnmm9WqVSvFx8drz549Gj58uLp3764ZM2aYIWPo0KFmz3kjRowwL0UZM2aMbDabjhw5onfffVeSVLVqVfXv37+Ut7bkFHU/2u129e7dWytXrpQkNWjQQBMmTHC43Mnf31833HCDudx33nlHgwcP1q233qqcnBx9+OGH5mVQknTPPfeU0laWvKLux+J+rynx4/GKO6qFU1zqKbKenp7GihUrzLY8efvSsrKyjIYNG5r7ZOfOnfnaXO4pstddd51x4sSJMqi+dF1uPyhPn/U8ebtwRd2PRWmX93kDl3qKqs1mM958882y2+gSUNT9mPe5PwW9wsPDjfT0dHO5lel4LM5n2jAM45133jGnP/DAA4UutzIdi5d7erH0vycYx8fH8+TtQhRnP16uXd7n1URHR1+y7dNPP102G1xCirofr+R7TUkejwSLMvbDDz8Yo0aNMlq0aGHUqFHD8PDwMIKCgowHH3zQ2L59e772P/74oxEZGWkEBAQYdrvdaNq0qTF58mQjIyOjDKovXz799FPzw3HHHXcU2CYzM9N4//33jV69ehmNGzc2fHx8jCpVqhihoaHGiy++mO8/g4qquF9CinPcnTt3znj55ZeN66+/3rDb7UZgYKBxzz33GNu2bSvFLSwdJRUsdu7caYwbN85o06aNUbt2bcPDw8OoVauWcc899xjffPNN2W1wCSnqfvz777+Nt99+27j77ruNkJAQw9vb2/D19TVat25tvPrqq5X6eCzuZ7pVq1bm9PXr1xe63Mp0LBbnC7FhGMbevXuNvn37GrVr1za8vLyMRo0aGc8++6yRkpKSb9nZ2dnGrFmzjJYtWxre3t5GtWrVjE6dOlWocJurpILFgQMHjJdfftlo166dUa9ePcPT09MICAgw7rzzTmP58uVls7ElqKj78Uq+15Tk8WgzjAr2RBEAAAAApY6btwEAAABYRrAAAAAAYBnBAgAAAIBlBAsAAAAAlhEsAAAAAFhGsAAAAABgGcECAAAAgGUECwAAAACWESwAAAAAWEawAAAAAGAZwQIAAACAZQQLAAAAAJYRLAAAAABYRrAAAAAAYBnBAgAAAIBlBAsAAAAAlhEsAAAAAFhGsAAAAABgGcECAOB0cXFxstlsDi8vLy/5+/vr6quv1p133qmXXnpJhw4duuRyUlJS9Nprr6lz584KCgqS3W6Xj4+PmjRpor59+2rp0qU6f/682b5jx4751muz2eTt7a2GDRuqR48eWrFiRUlvPgBUSjbDMIyyLgIAULHExcXp9ttvv2w7d3d3vfjii3rxxRfl5ub4W9cnn3yiRx55RKdPn77kMtatW6eOHTtKuhAsvv3228uud9y4cXr55Zcv2w4AUHQeZV0AAKDie+CBB9SmTRulpKRo+/bt+vLLL5Wdna3s7GxNmDBBR44c0ezZs832S5Ys0UMPPaS8v33deeeduuWWW2S325WYmKi1a9cqMTGx0HUGBARo3LhxysrK0t69e7Vo0SJlZmZKkqZOnaoxY8YoMDCwxLYZACobggUAoMR16dJFgwYNMsd37dqlbt26KSEhQZI0Z84c9ejRQ126dNHx48c1bNgwM1T4+Pjo008/1V133eWwTMMwtHz5ctWqVavAdVarVk1PP/20OV67dm1NnTpVkpSdna29e/eqbdu2ztxMAKjUuMcCAFDqmjZtqiVLljhMmzlzpiRp3rx5Sk1NNadPmjQpX6iQJJvNpvvuu0/Nmzcv0jrr16/vMF6zZs3ilg0AuASCBQCgTISFhenGG280x9evX6/s7Gx9/fXX5jSbzeZwpuNKZGdna9euXZo3b5457aabbtI111xjabkAAEdcCgUAKDPXXXedfv75Z0nSuXPndOrUKR0+fNicX7t27Su+D+LAgQOy2Wz5poeFhWnp0qVXVjAAoFCcsQAAlJnS7piwdu3amjRpkoKDg0t1vQBQGRAsAABlZu/eveawt7e3atSo4XAvxLFjxy7b3WxhAgICNH36dD3zzDOqU6eOubxu3brpm2++sVY4ACAfggUAoEz8+OOP5mVQktShQwe5ubmpU6dO5jTDMLRw4cIrWn5ur1DTpk3Txo0b5evrK+nCPRcjR45UVlaWtQ0AADggWAAASt2ePXv04IMPOkwbPXq0JGnIkCHy8/Mzp0dFRRV4hiG3u9kdO3Zcdn3XXHONQ9eze/bs0aJFi660fABAAbh5GwBQ4tasWaMTJ04oNTVV8fHxWrNmjcMZg8cff1wRERGSpFq1amnOnDnq37+/DMNQWlqa7rzzTvMBeV5eXjpw4IC++uorJSYmat26dUWq4V//+pdmzJihM2fOSJJeeeUVPfzww/me+A0AuDIECwBAiVuyZEm+51ZIkoeHh6KjozVu3DiH6X379pWHh4eGDRumlJQUGYahr776Sl999dUV1xAQEKARI0bo1VdflSTt3r1by5Yt0/3333/FywQA/I/NKO0uOQAAFV5cXJxuv/12h2nu7u7y8fFRzZo1dfXVV+u2227T0KFD8z24Lq/Tp09r3rx5WrNmjX799VedPn1abm5uuuqqq3Trrbfq/vvvV0REhDw8LvxO1rFjR3377beSpODgYCUmJjos78iRIwoJCVFGRoYk6cYbb1R8fHyB3dICAIqHYAEAAADAMi4sBQAAAGAZwQIAAACAZQQLAAAAAJYRLAAAAABYRrAAAAAAYBnBAgAAAIBlBAsAAAAAlhEsAAAAAFhGsAAAAABgGcECAAAAgGUECwAAAACWESwAAAAAWEawAAAAAGDZ/wMZBNYP+LV7zAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(train_val[\"DCR\"], bins=10, color='#394D59', edgecolor='white')  # Adjust bins and color as needed\n",
    "# Adding title and labels\n",
    "plt.title('Train v.s. Held-out DCR', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "52abf5ec-490f-4fa1-ae74-0b01efb41d35",
   "metadata": {},
   "source": [
    "## MALLM-GAN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "4f30bf09-0bc5-48a6-81d7-eb24b0568755",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"../mallm_exp_updates/gen/atach/100/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn1 = pd.concat(data_lst)\n",
    "syn1.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "3e6bce80-14ab-45d6-9324-fa9e192da031",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcr_train1 = _calculate_dcr(data_train, syn1, meta_data)\n",
    "dcr_test1 = _calculate_dcr(data_test, syn1, meta_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "8315efab-aa1b-448d-ad3d-e42d80350c77",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABdWUlEQVR4nO3de1gWdf7/8ddwuhEUBFQUMzHX8kBurtpXDQ9loWakWWa2llp5yE6ubW26ppmZVlrtuhnV95talllaeTbMpDTLzMNutXbQQMtDIig3gpzn9wc/Jm45CA5w38DzcV33dd0z87ln3jOOer/uz8xnDNM0TQEAAACADV7uLgAAAABA7UewAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAD2QYRonXAw88UGb7+fPnl/qZpKSkMj+Tm5urZs2alfjMv/71r3JrGzNmjEv7J554okL79MQTT7h8bsyYMRX63JIlS0rdtz179pT5mcsvv7xE+379+lVoe+U5deqU/vGPf2jo0KFq06aNgoKC5OPjo+DgYLVv315DhgzRM888o++///686xo6dGiJGm+55ZZyP1Pasbj33ntLbRsZGVnhcwEAqgLBAgBqiaVLl8rpdJaYn5+ff94wUJp169YpOTm5xPwlS5ZcSHk17h//+Eep87ds2aJvv/22Srdlmqaee+45tWrVSpMnT9bq1auVlJSk9PR05efny+l06ocfftCaNWv02GOPqUOHDvr555/LXF9ycrI2bNhQYv7atWuVmppaqdr+7//+TwcPHqz0PgFAVSNYAEAtkZ6ersWLF5eYv3r1ah06dKjS6ysrQOzevbvKv5hXhxUrVujEiRMl5pcVOC6UaZq6/fbb9eijjyojI8Oa7+3trS5duig2NlYDBgxQ+/bt5eX1+3+rBQUFZa5z2bJlys3NLTE/JydHb7/9dqXqy83N1YwZMyr1GQCoDgQLAKhF/vWvf8k0TZd5F/JFOjk5WRs3brSmfX19XZbXhl6L7OxsvfLKKy7zDh48qPXr11fpdubMmaN33nnHZd6f//xn/fLLL9qzZ4/WrFmjTZs2af/+/UpOTtarr76qjh07lrvOpUuXWu+9vb1lGIY1fSHHfvny5frPf/5T6c8BQFUiWABALdCyZUtJ0oEDB1wuodm3b58+++wzSVKDBg0UEhJSofWd+4v5o48+qoCAAGv6rbfeUl5eXlWUXuWKjoUkxcXFuezHwoULrZ6C4u0uVHJysubNm+cy74477tCyZcvUokWLEu1DQ0M1btw4ffPNN4qMjCx1nXv37tW///1va/raa69V7969rekL6TEyTVPTpk2r1GcAoKoRLACgFih+g27xHooXX3zRej9q1CgFBQVVaH3n/ip+zz33KDY21po+fvy4Nm3adGHFVrP+/fvr0ksvlSQdPXpU7733niTJ6XTq9ddft9pNmjTJ9rZWr17tcvmTr6+vnn322fN+zsvLSz4+PqUuO/dytpEjR2rkyJEu8yraa9GrVy9rO+vXr9fnn39eoc8BQHUgWABALTBhwgT5+/tLkj7++GPt379fJ06ccLlE58EHH6zQuvbs2eNy2UzPnj0VGRl5wV9ua9q5I2T985//lFT4hT09PV2S1K1bN/Xq1cv2tnbs2OEy3bVrVzVv3vyC15ebm6vly5db0/7+/rrpppt0yy23uASRivYYtWvXTnfddZc1PXXq1AuuDQDsIlgAQC3QpEkT3X777ZIKL3tZuHCh4uLilJ2dLanwV/yoqKgKrevcwFC03kGDBqlx48bW/AsZoaimjBkzRsHBwZKknTt36ssvv9TChQut5Q899FCVbOe3335zmW7dunWJNtHR0aUOh1va8LZr167VyZMnrenBgwcrKChITZo0UUxMjDW/Mj1GM2fOVIMGDSRJ27ZtK3W0KQCoCQQLAKglivdIvPHGG1q0aJE1XdEv0ueOOuTt7a3hw4dLkvz8/HTzzTeX2daTNGzY0OWX+lGjRllDrjZv3ly33nrreddxyy23lPqqikuoynJuqCveS3ShPUYRERG6//77rem///3vJW7wB4CaQLAAgFrij3/8o/UreEZGhvVretu2bTV48OAKrWPt2rVKSUmxpq+55hqFh4db07XlcihJuv/++63hXYs/x+Hee++Vn5/feT+/atWqUl/Ff/Evfmwk6fDhwyXWc/XVV+vmm29Wnz59yt3eb7/95jISV1BQkMuf29ChQ62eB6lyPUaPPfaY1YOzb98+rVixokKfA4CqRLAAgFqktPsoin/BPp9zg8KXX36piy66yHrdeeedLss9+ZkWl1xyiW644QaXeX5+fpowYUKVbePc+zR2797tcimTJM2ePVsr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nKznn39ezz//vLp166a77rpLI0eOVFBQUJUUDHi8nCwpN9s92za8pIJ8KT+v8HWu///3FAAAoKoZpmn/m8auXbv07rvvWiHDZQOGIX9/f910002677771LNnT7ubqxWcTqeCg4OVlpZGqKpvMtKk77+UsjNqftuOQCU3aaf/e/MdpaSkuC7z8ZMCGknOFKmglNBRg8LCwnT3Hber6bH/FM74Y38pMNitNQEAgJIq8522Si6F6t69u5577jklJibqyy+/1F/+8hf5+/vLMAyZpqmzZ89q+fLlio6O1siRI5Wd7aZfc4Gakp0hnT1T86/sDKmgoDA4nPsyPev+J8PLS3IEFr4MBqgDAKC2s3Up1LmOHz+uLVu2aM2aNVZ4KAoXRR0j7777ri655BLNmTOnKjcNoBZpEBAgr8AgJatd4YyMLOlsrnuLKkMDf381DAxwdxkAAHg828HCNE2tX79e//u//6sNGza4jAplmqb8/f11++23q127dpo/f75SUlL09ttvEyyAeszhcCgrJ1er125S2unTUqMQybtKf+eoEsFBjXTL4BiCBQAAFWDrf/Lp06dr6dKlOnr0qCSp+O0aF198se69916NGzdOoaGhkqTmzZtr7Nix+vXXX+1sFkAdkXb6tFJOpUp5XpI88MbyggJ3VwAAQK1hK1g8/fTT1qVORfr166cHHnhAQ4YMkZeX63XTrVu3liQV8J81gCKGl2QWSBmnJU96Do63txTS2N1VAABQa1TJpVABAQH685//rAceeEBRUVFltu3QoYMWL15sd5MA6qL8fLePVgUAAC6crWDRpk0bTZo0SXfffbcaN2583vbh4eEaPXq0nU0CAAAA8EC2gsWBAwdkGEZV1QIAAACglrIVLJKSkvTNN99Iknr16qUmTZpYy5KTk/XFF19IkqKionTJJZfY2RQAAAAAD2YrWMyePVtLly5VWFhYiSduN2rUSPfee6+OHz+uO++8k3srAAAAgDrM1uNuP//8c0lSbGysGjRo4LLM399fN9xwg0zT1Pbt2+1sBgAAAICHsxUsip5f0aZNm1KXt2rVSlLhE7kBAAAA1F22LoUqeh7FuZdBFSmaz3MrUK8YXpIj0D3bdgRKXgyoAAAAap6tYBEREaGDBw/qnXfe0WOPPaa2bdtay4rmG4ahiIgI24UC7nYmI1Nns7LO37AgX2rSzi1P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3333XYnh4iXpq6++st578vnHpVDV5L333tPIkSOVn58vwzA0c+ZMORwOl+viunfvrtTUVHXq1EnDhg1TbGyswsPDtWfPHs2ZM8dqV9pJWtc9/PDDOn36tO6880517txZJ0+e1IIFC6ybwpo0aWKNMBEREaGjR48qPj5ef//739W1a1eX+wImTpzoln3wBK+99prV/XznnXeWuJGM80/KzMzUhg0bJMnli8OhQ4e0cuVKSYV/V2NjYyt1rk2cOFEPPfSQJGncuHF68skntWfPHsXHx0uSLrroIt1www3Vvn/VraLHr1mzZrruuuv05ZdfSir8tW7y5MkuX3zDw8OtXskXX3xR27dv19ixY9WtWzdlZmYqLi5OBw8elFR4DfPAgQNrZB+rS0WPXWJiogYPHqyRI0dqwIABCg4O1rZt2/Tss89anyn+95Rzz/X4tW7d2mpfNPCHr69vqaPjSfXj3JMq/j3lyiuvVJcuXbR371798MMPmjBhgm644QYtWLDAChl33323NTrexIkTrUtoH374YRmGoePHj+v//u//JEkNGzbUqFGjanhvq15Fj5/D4dDNN9+sNWvWSJJatWqlJ554wuVyp+DgYF1++eXWel999VWNHTtWV111lQoKCvT2229bl0FJ0o033lhDe3kB3DjUbZ12vqcZS4VPND7fEz4vu+wy8+TJk+7enRpX3lNmfX19zQ8++MBqy5O3S5eXl2defPHF1rH473//W6IN59/5j4GKjWXPk7dLqujxq0i74s8fKO/fUMMwzIULF7pvp6tIRY9d8ef6lPaKjo42z549a62Xc6/k313TNM1XX33Vmj9ixIgy11sfzj3TrPj3FNMsfMo5T952VZnjd752xZ9PM3PmzHLb/vWvf3XPDlcQwaKaVPSEy8nJMd98801z2LBhZtu2bc2AgACzQYMGZlRUlPn444+X+MtaX3z11Vfm5MmTzc6dO5thYWGmj4+PGRERYd52223mnj17SrT/+uuvzdjYWDMkJMR0OBxmhw4dzKefftrMzs52Q/We4cMPP7TOtWuuuabUNpx/lf9yUplzLSsry5wzZ47Zvn170+FwmKGhoeaNN95o7t69uwb3sHpVV7D473//a06bNs3s1q2b2axZM9PHx8ds2rSpeeONN5qffPKJ+3a4ClX02KWnp5uvvPKKOWjQIDMyMtL09/c3AwMD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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test1[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train1[\"DCR\"], bins=10, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "# Adding title and labels\n",
    "plt.title('MALLM-GAN', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "61057a33-a16e-4945-82dc-8ba3174312b1",
   "metadata": {},
   "source": [
    "## SMOTE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "46f30fad-6029-498d-9044-a4a25ba1695c",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"gen/ATACH/100/SMOTE/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn2 = pd.concat(data_lst)\n",
    "syn2.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7a18c895-a253-4fad-8d40-12f5c55b5646",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcr_train2 = _calculate_dcr(data_train, syn2, meta_data)\n",
    "dcr_test2 = _calculate_dcr(data_test, syn2, meta_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1a4bfcf2-738c-4948-9c99-44d56854e671",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABY80lEQVR4nO3deVhWdf7/8ddhuxEQRAxSUzHHTKXUjMbcy9IcJc2ybSzXzHKmcbJMzdG0UlvUZsqyvHJpKlu0xjXF3NLUIsO+LVqZgKZpCnjfguyc3x/+OHELKniQ+waej+u6r+ssn/uc9+0HkBefcz7HME3TFAAAAADY4OPpAgAAAABUfQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwDAWWVkZOjFF19U165dVa9ePfn7+yssLEzR0dG67rrrNHToUM2ePVsHDhxwe59hGCVef//73896nhdffLHU9yQnJ5/1Pd9//70ee+wxXXfddYqMjFRAQIDCw8PVqlUrDR8+XGvXri31fd27dy/1XGV5bd68WZI0ZMiQMr+nf//+5f1nB4Aqyc/TBQAAvNPPP/+sm2++WSkpKW7bXS6XXC6XUlJSlJCQIEmKjIzUoEGDznm8xYsX69lnn1VoaKjb9oKCAr3yyitlruvUqVMaPXq0Fi9eLNM03fadOHFCJ06c0J49e7RgwQL9+c9/1pIlS9S0adMyHx8AcGEIFgCAEkzT1N133+0WKurVq6c2bdooJCREqamp+uGHH5SWllbmY548eVILFy7UP/7xD7fty5cvLxFeziY7O1s9evTQzp073ba3aNFCV1xxhY4ePaqvvvpKhYWFkqQvvvhC1113nXbu3KlmzZpJkrp166Z69eq5vT8lJUVfffWV22ft1q1bifNfcsklpdbVsmVLtWrVqtR91113XZk+GwBUdQQLAEAJu3fv1tdff22t9+vXT0uXLpWfn1+Jdh988EGJX9TP5pVXXtEjjzwiwzCsbf/+97/LXNdjjz3mFipq1aqld9991+1yox9++EFxcXHav3+/JOn48eMaMGCAEhMT5ePjo6lTp5Y47qJFizR06FBrvXXr1lq6dGmZ67rzzjv11FNPlbk9AFRH3GMBACjhp59+clvv1q1biVAhSW3bttX06dN1yy23nPN4DRs2lCTt27dPa9assbbv3r1bn332maTTISE8PPysxzh48KDeeOMNt20vvPBCiXsYWrVqpY8++kg+Pn/8F/d///d/+vDDD89ZIwDAHoIFAKCEgIAAt/UZM2bolVde0b59+y7oeA899JC1XHyE4qWXXrKWBw0aVOL+i+JWrlypvLw8a7127doaPnx4qW3btGmjG2+80W3bRx99VN6yAQDlwKVQAIASOnToID8/P+Xn50uSjh07Zs3qVKdOHV1zzTXq0qWLbr/9dl111VXnPd6DDz6oZ555RtnZ2fr000+1Z88eRURE6L333rPaPPLII4qPjz/rMb744gu39WuvvVaBgYFnbd+pUyd9+umn1vqXX3553jov1AcffKDvvvuu1H1Tp05V69atL9q5AcBbECwAACXUr19fEydO1LRp00rsO3HihDZu3KiNGzdq6tSpiouL05tvvnnWG5ul0zdD33vvvVqwYIFM09TLL7+sSy+9VDk5OZKkHj16KCYm5pw1HTt2zG390ksvPe9nKO73338/Z3s79uzZoz179pS6729/+9tFOy8AeBMuhQIAlGrq1KlasGCBmjRpcs52K1euVL9+/UpM/XqmRx55xFp+66239Oqrr1rrZ84UVRHOVw8AoGIRLAAAZzV06FAlJSVpx44dmjlzpvr166e6deuWaLdjxw7t2LHjnMdq06aNunfvLknKzMzU0aNHJUnNmjVTnz59zlvLmSMiv/322znbHzlyxG09MjLyvOe4UFOmTJFpmqW+ij4zAFR3BAsAwDkZhqEOHTroiSee0P/+9z8dO3ZMK1asUEhIiFu7s10KVFzxUYsif/vb39xmcDqbM58HsWvXLmVnZ5+1/eeff+62Hhsbe95zAAAuHMECAFCC0+nUqVOnSt3n4+OjuLg43XzzzW7b/f39z3vcW2+9VdHR0dZ67dq1NWzYsDLVFBcX5zbl7cmTJ7VgwYJS23777bfauHGj27YBAwaU6TwAgAtDsAAAlPDtt9+qcePGmjhxYqmzHR04cKDE06/LMvORr6+v/vnPfyoiIkIRERF68MEHzznFbHGNGzfWiBEj3LY99thjWrFihdu2PXv2aMCAAdbTtyUpJiZGd955Z5nOAwC4MMwKBQAoVWpqqmbMmKEZM2aoXr16at26tcLCwpSWlqYvvvjC7ZkS7dq10zXXXFOm4z7yyCOlXhJVFrNnz9auXbuUkJAgScrKylK/fv105ZVXqnnz5vr999+VkJDgFirq1q1b4oF5Fe1c081GRka63agOANUVwQIAUIJhGG7rx48f15YtW0pt27hxY7333nsl3nMx1KpVSxs3btRDDz2kt99+29q+d+9e7d27t0T72NhYLVmyRM2aNbuodZ1rutnzzaoFANUFwQIAUEKnTp20e/duxcfH64svvtDevXt16NAhZWRkyMfHR+Hh4WrdurX69u2rBx54oMSN3BdTSEiI/vvf/2rcuHFauHChPvvsMyUnJ8vpdCo4OFj169dXhw4dNHDgQP3lL3+ptLoAoKYzTCb6BgAAAGATN28DAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2P08XUF0VFhbq8OHDql27tgzD8HQ5AAAAQLmZpqmTJ0+qQYMG8vE595gEweIiOXz4sBo1auTpMgAAAADbDh48qMsuu+ycbQgWF0nt2rUlne6E0NBQD1cDAAAAlJ/L5VKjRo2s323PhWBxkRRd/hQaGkqwAAAAQJVWlkv7uXkbAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbN28DAADUYKZpqqCgQPn5+Z4uBZXIz89Pvr6+Ffq8NYIFAABADWSapk6cOKFjx46poKDA0+XAA3x9fRUZGamwsLAKCRgECwAAgBroyJEjOnHihDU1vp+fX4X+9RreyzRN5efny+Vy6bffflNWVpbq169v+7gECwAAgBqmoKBATqdTl1xyierVq+fpcuAhtWvXlsPh0PHjxxUZGSlfX19bx+PmbQAAgBomLy9PpmkqODjY06XAw4KDg2WapvLy8mwfi2ABAABQQ3HpEyrya4BgAQAAAMA2ggUAAAAA2wgWAAAAQBkNGTJE0dHR522XnJwswzC0aNGii16TtyBYAAAAoFpZtGiRDMPQV199Ver+7t27KyYmppKrqjzvvvuuXnrppUo/L9PNAgAAwF1utpSX49ka/B1SQKBna6ii3n33XX333XcaM2ZMpZ6XYAEAAAB3eTnS3p1STqZnzu8Ilq7sQLCoYrgUCgAAACXlZEpZGZ55eSjQvP3222rfvr1q1aqlunXr6u6779bBgwfP+74TJ05oyJAhCgsLU506dTR48GCdOHGizOfdv3+/Bg4cqLp16yooKEgdOnTQ6tWr3doUXd6VnJzstn3z5s0yDEObN2+WdPoyr9WrVyslJUWGYcgwjDLdE1IRGLEAAABAteR0OnX8+PES20t7GNyzzz6rf/3rX7rzzjs1YsQIHTt2TC+//LK6du2qxMRE1alTp9RzmKapfv36adu2bRo1apRatmypjz/+WIMHDy5TjUePHlXHjh116tQpPfLII4qIiNDixYt16623aunSpbrtttvK9ZmffPJJOZ1O/frrr5ozZ44kKSQkpFzHuFAECwAAAFRLN91001n3tW7d2lpOSUnRlClT9Mwzz2jixInW9gEDBqhdu3Z69dVX3bYXt2LFCn322Wd6/vnn9fjjj0uSHnroId1www1lqnHmzJk6evSotm7dqs6dO0uSHnjgAV199dV69NFH1a9fP/n4lP0io5tvvlkNGzZUenq6Bg0aVOb3VQSCBQDv5Q03DxbhJkIAqHLmzp2rK664osT2sWPHqqCgwFr/6KOPVFhYqDvvvNNthOPSSy9V8+bNtWnTprMGizVr1sjPz08PPfSQtc3X11d///vftXXr1vPWuGbNGl133XVWqJBOjzCMHDlSEyZM0A8//FBlZrAiWADwXp6+ebAINxECQJV03XXX6dprry2xPTw83C1A/PzzzzJNU82bNy/1OP7+/mc9R0pKiurXr1/icqMWLVqUqcaUlBT9+c9/LrG9ZcuW1n6CBQBUhKKbBwEAuEgKCwtlGIY++eQT+fr6lthfWfconIthGKVuLz7y4mkECwAAANRozZo1k2maatq0aamXTp1LkyZNtGHDBmVkZLgFkB9//LHM7y+t7d69e6390ulRFkklZptKSUkp8d6zhZCLjelmAQAAUKMNGDBAvr6+mjp1qkzTdNtnmqZSU1PP+t6//OUvys/P12uvvWZtKygo0Msvv1ymc//lL3/Rl19+qR07dljbMjMz9cYbbyg6OlqtWrWSdDr8SNJnn33mdp433nijxDGDg4PldDrLdP6KVCWDRVpamiZMmKBu3bopKCjI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qVNHsbGxuu222+RwOOycBgAAAICXsxUsFi5cWFF1XFQ7d+7U888/r507d+rYsWPy9/dXs2bN1L9/f40bN061a7s/22DXrl2aNm2atm3bpszMTF1++eW67777NHbsWAUEBHjoUwAAAADey/alUN5u06ZN6tmzp/Lz861t+fn5+u677/Tdd9/p008/1fbt2617ReLj4xUXF6fc3Fyr/Z49ezRx4kRt3rxZa9aska+vb6V/DgAAAMCb2QoWn3322QW/t2vXrnZOXWYvv/yyFSpuvPFGjRs3Tvv379c//vEP5eXlaefOnfr666/Vvn17ZWVlaejQoVaomDRpktq1a6cpU6bou+++U3x8vObNm6fRo0dXSu0AAABAVWErWHTv3v2ss0Kdi2EYbiMIF5PT6bSWH330UfXq1UuStGDBAn311VeSZNWycuVKHT58WJLUq1cvPf3005KkBg0a6Prrr5ckggUAAABQigq5FOpcM0MVZxhGmdtWlO7du2vjxo2SpNmzZ8vf31+//PKLvvnmG0lSq1atdM0110iStm3bZr2vY8eO1vK1114rf39/5eXl6bvvvlN6errCw8Mr8VMAAAAA3q1Cpps9W2A4c3tlhwpJGjdunFJSUrRo0SJt3LjRChmSdP/99+uFF16Qv7+/JCk5OdnaFxUVZS37+fmpbt26Onr0qNXuzGCRk5OjnJwca73o4YAAAABATeBj58379+9XXFycTNPUAw88oC1btmjv3r3asmWLRowYIdM01bdvX+3fv19JSUnWa//+/RVV/3kFBASoRYsWqlOnTol98fHx+uKLL6z1zMxMt/edeZzS2hWZMWOGwsLCrFejRo0qoHoAAACgarAVLNatW6dVq1ZpwIABev3119WlSxddccUV6tKli9544w3ddtttWr16tdasWaMmTZq4vSrL1KlTNW7cOKWmpuqRRx6Ry+XS7t27FRUVpSNHjuiOO+6wRiqCg4Ot9xUffZDkNktU8XZFJkyYIKfTab0OHjx4cT4QAAAA4IVsBYuXX35ZkhQTE1Pq/quuukqmaWru3Ll2TmPL/PnzreUnn3xStWvXVps2bTRgwABJpwPDmjVrJEnR0dFW26LLnqTTN3enpqZa68XbFXE4HAoNDXV7AQAAADWFrWDxyy+/SJJWrVqlvLw8t315eXlauXKlJFXqpU9nOn78uLWckZFhLZ88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AAAAANhGsAAAAABgG8ECAAAAgG01Llj06dNHhmFYr71797rt37dvn/76178qKipKDodDzZo10xNPPCGXy+WhigEAAADv5+fpAirTO++8ozVr1px1/zfffKNu3brJ6XRa2/bv36/nn39e8fHx+uyzz1S7du3KKBUAAACoUmrMiMXx48c1ZswYGYahgICAUtsMHTrUChUjR47U8uXL1bVrV0nS7t27NW3atEqrFwAAAKhKasyIxZgxY3T8+HGNHDlS69atU0pKitv+L7/8UomJiZKkli1bat68eTIMQ7GxsWrYsKFM09Sbb76p6dOny9/f3xMfAagxDB8fKSBQMnwkR7Bni8nP8+z5AQCoImpEsFi7dq3eeecdNWjQQM8//7zWrVtXos22bdus5Q4dOsgwDElS/fr1FR0draSkJKWnp+v7779X27ZtK6t0oMapFRQkn+BQHfP1k07lSvWaS4WFnqvHTwpJO+Cx8wMAUFVU+2CRkZGhUaNGSZJeffVVhYWFldouOTnZWo6KinLbFxkZqaSkJElSUlJSqcEiJydHOTk51jo3ewMXxuFwKDs3T8tXrpUzJ1/KOCEV5nuklrDwcN3Rt7dCfKr9j0oAAGyr9v9bPvnkk0pJSdHAgQPVr1+/s7bLzMy0ls+8B6P4evF2xc2YMUNTp061WS2AIk6nU6lZeZIr1WPBAgAAlF21vnl77969euWVVxQeHq6XX375nG2Dg/+4jrv4yIMk5ebmltquuAkTJsjpdFqvgwcP2qgcAAAAqFqq9YjFkSNHVFhYqPT0dF166aWltmnZsqXatGmj+++/39p29OjREscp0rRp01KP43A45HA4KqBqAAAAoOqp1iMW5dG5c2dreceOHTJNU5J06NAhHThw+sbN8PBwtW7d2iP1AQAAAN6sWo9Y/OlPf9KcOXNKbJ82bZrS09Mlnb6EqXXr1rruuuvUrl07JSYm6scff9SDDz6ovn37atasWVbIGD58OFPNAgAAAKWo1sHisssu05gxY0psf+mll6xgcf/99+vKK6+UJC1YsEDdu3eX0+nU/PnzNX/+fOs9bdu21eTJkyulbgAAAKCq4VKoYtq2bauEhATde++9ioyMVEBAgJo2bapx48Zpy5Ytql27tqdLBAAAALxStR6xOJviz6w4U/PmzfXOO+9UXjEAAABANcCIBQAAAADbCBYAAAAA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aMOGDfr+++/dnlfhcDi0aNEir384nsPh0JQpU7y+TlQs+r3moc9rJvq9ZqLfa6aq1u+GWZa5o2qYnJwczZo1S//973+VlJSk4OBgde7cWVOmTNE111zj6fIAAAAAr0OwAAAAAGAb91gAAAAAsI1gAQAAAMA2ggUAAAAA2wgW1UhOTo6mT5+uVq1aKTAwUBEREerfv7++/vprT5cGmzZv3izDMM76euqpp9za79q1S/369VNERIQCAwPVqlUrzZgxw+0J8vAeaWlpmjBhgrp166agoCCrX4cMGVJq+/L0Lz8XvFd5+r179+7n/BlwJvrdOyUmJmr8+PHq2LGjGjZsqICAAF1yySWKi4vT1q1bS7Tft2+f/vrXvyoqKkoOh0PNmjXTE088IZfLVaJtYWGhXnvtNbVr105BQUEKCwvTTTfdpA0bNlTGR8M5lKffhwwZcs7v9eTkZLf2XtfvJqqFvLw8s0ePHqakEi+Hw2F++umnni4RNmzatKnUvi16TZkyxWq7bt06MyAgoNR2PXv2NPPz8z33QVCqxMTEUvtr8ODBJdqWp3/5ueDdytPv3bp1O+fPgOLod+/14IMPnrUPfXx8zGXLllltd+/ebYaFhZXatm3btqbL5XI79uDBg0ttaxiGuXjx4sr+qCimPP1+tn4seiUlJbkd29v6nRGLauLVV1+10mlMTIyWLVumSZMmSTr9l6shQ4YoJyfHkyWigvznP//R1q1b3V7Dhg2TJGVlZWno0KHWX64nTZqkZcuWKSYmRpIUHx+vefPmeax2lC4gIEBdu3bV+PHjrb4sTXn7l58L3q2s/V5c27ZtS3z/n/kXT/rdu1166aV68skn9cknn+jdd99VixYtJJ3+y/Ojjz5qtRs6dKicTqckaeTIkVq+fLm6du0qSdq9e7emTZtmtV2xYoUWL14sSWrQoIHee+89zZkzR35+fjJNU6NHj9bRo0cr6yOiFGXt9+LtS/ter1+/vtXGK/u90qMMLoqWLVtaKXXHjh3W9l69elnbly5d6sEKYUfxEYtNmzadtd37779vtevVq5e1fceOHdb2mJiYSqgYF+q1114761+uy9u//FyoOs7V76b5x4hFt27dznss+t17bd261czMzHTbtnv3bre/NB89etT84osvrPWWLVuahYWFpmma5uHDh03DMExJZnh4uJmbm2uapmn27t3b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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test2[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train2[\"DCR\"], bins=10, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "\n",
    "# Adding title and labels\n",
    "plt.title('SMOTE', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f9dad789-93b8-4efa-b53b-a2c88753d7aa",
   "metadata": {},
   "source": [
    "# tabddpm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "e177ce90-d34b-4e01-a0f5-2715cf394e0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"gen/ATACH/100/tabddpm/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn3 = pd.concat(data_lst)\n",
    "syn3.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "18e1d9b8-cdaf-4bd8-8131-2b39fa421825",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcr_train3 = _calculate_dcr(data_train, syn3, meta_data)\n",
    "dcr_test3 = _calculate_dcr(data_test, syn3, meta_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "9184a390-39bf-4881-9224-6aa4e2bf5d1b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABTZ0lEQVR4nO3df3xP9f//8fvZr9d+mBlC5MfyVg0VoeS3FBVLKf1UKvlVn368FSWiVFSS3h8lpUK/9AMlEZP8jEpM3xRKNkITM6/9sJ+vne8f++y897LNNue1vV7bbtfL5XXpnOd5vs55vF5nR7vvnPM8hmmapgAAAADABj9vFwAAAACg6iNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWABANdOiRQsZhnFGr4SEhHJvr1evXrbWcer7DcNQYGCgwsPD1bRpU3Xu3FnDhg3TkiVLlJubW+J65s+fX2Q9/v7+CgkJUYMGDdS2bVtdf/31evnll3XkyJHT1nS67ygkJETNmzfXoEGDtHjxYpmmWabPdNFFF5W4vW3bthW7rfnz55f5ewQAbyNYAAB8Tm5urtLS0nTw4EH98MMPevfdd3XjjTcqKipKK1euLPN68vLylJmZqaNHj+rXX3/V0qVLNXbsWDVr1kyPPfaYcnJyyl1bZmamDhw4oM8//1w33XST+vbtq/T09FLf98svv2jt2rXFLnv11VfLXQcA+JoAbxcAAPCsa6+9Vv/8849b22+//aZdu3ZZ882bN1fHjh2LvDcsLKzC6ytNx44d1bx5c6WlpWnv3r36888/rWUHDx7Utddeq1mzZumBBx447Xrq16+vnj17KicnR4mJidqxY4eys7MlSdnZ2ZoxY4a2bt2qVatWKTg4+LTruuaaaxQaGqrs7Gz9v//3/7R//35r2TfffKPRo0frvffeK/Wz/e///q969+7t1paYmKhPP/201PcCgM8zAQDV3uTJk01J1mvo0KEeW3fPnj3d1h0fH2/r/fPmzXNbHhcXZ1522WVuffz8/Mx169a59Zs3b55bn549e7otT05ONseNG2cahuHWb9iwYUVqKrz81M+Uk5Nj3nXXXW7LDcMwExMTS/xMBS9/f38zISHBbVuTJk0qtm9x3wUA+DIuhQIAaNOmTfr3v/+t3r17q2XLloqMjFRAQIAiIiJ04YUXavTo0fr555/LvL5169bp6quvVt26dRUaGqqOHTvq7bffLvZ+hNK0a9dOa9euVdu2ba22vLw8Pf744+VaT506dfTiiy/qmWeecWufN2+efvvttzKvJyAgQE8//bRbm2ma2rp1a4nvadKkiSTJ5XLptddes9qzsrI0Z86cIv0AoCoiWAAA9PHHH+vVV1/VunXrtG/fPp04cUIul0spKSnauXOn5syZow4dOujdd98tdV2vv/66rrjiCq1atUrJycnKyMjQtm3bNHz4cN1zzz1nVF9ISIieffZZt7YffvhB+/btK/e6xo0bpwYNGljzeXl5WrhwYbnW0bBhwyJtqampJfYfPXq0Nf3222/r5MmTkqSFCxdal62dd9556tOnT7nqAABfQrAAAEiS/Pz8dMEFF6h79+667rrrdM011yg6Otpa7nK59MADD+jvv/8+7Xpefvll1alTR1dddZUuuOACt2ULFizQ22+/fUb19e3bV/7+/m5tmzZtKvd6HA5HkV/gv/vuu3KtY/v27UXazj777BL7d+3aVR06dJAknThxwrof4z//+Y/V56GHHpJhGOWqAwB8CcECAKBHHnlEx48f165du7RhwwYtXbpUK1as0G+//eZ26U5mZqaWLl162nW1bt1ae/bsUWxsrHbt2qUnnnjCbfm0adPOqMbQ0FDVr1/fra20YWNL0qxZszNaT3Z2tr7//nuNHDnSrb1OnTq6/PLLT/vehx9+2JqeNWuW1q9frx07dkiSIiIiNHTo0DLVAAC+imABANC5556rVatW6cYbb1TLli0VFhYmPz8/GYah//mf/3Hru3v37tOua/z48TrrrLOs+UmTJik8PNya37dvn9tIT+WRl5fnNn+mf+Ev73qioqJkGIYcDocuv/zyIvdkvPDCC3I4HKddxy233GJdQvXbb79p2LBh1rJhw4apVq1a5fkIAOBzCBYAUMOZpqkbb7xRt9xyi5YsWaJ9+/bp5MmTJd5o7XQ6T7u+Ux8EFxISopYtW7q1FR6utazS0tJ0/Phxt7bi7nUoi1O3f6brCQ8P1+zZs4ucwShOUFCQ270WBeHKz8+vSHgDgKqI51gAQA23ePFiffHFF25tF154oaKiohQYGKijR49qw4YN1rIzGdnJE1atWiWXy+XW1rVr13KvJzMzU99++2251lPw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f4ZhxIgRGj9+vH777bcqM4IVwQIAgAqSkZmpRctj5UxJ9XYpHhNRO1w39e9LsECVcOmll6pjx45F2iMjI90CxB9//CHTNNWqVati1xMYGFjiNvbv36+zzz67yOVG559/fplq3L9/vy677LIi7dHR0dZyggUAAJAzJVVJySe8XQaA08jLy5NhGPr666/l7+9fZHll3aNwOoZhFNte+MyLtxEsAAAAUKO1bNlSpmkqKiqq2EunTqd58+Zas2aN0tLS3ALInj17yvz+4vru3r3bWi7ln2WRVGS0qf379xd5b0khpKIx3CwAAABqtEGDBsnf31/PPPOMTNN0W2aappKSkkp877XXXqvc3Fy98cYbVpvL5dKsWbPKtO1rr71WP/74o7Zs2WK1paen66233lKLFi3UunVrSfnhR5I2bNjgtp233nqryDrDwsLkdDrLtH1P4owFAAAAarSWLVvqueee0/jx45WQkKDrr79e4eHhio+P1+eff64RI0boscceK/a9MTEx6tq1q5544gklJCSodevWWrJkSZl/sX/iiSe0cOFCXXPNNXrooYdUt25dLViwQPHx8Vq8eLE1IlSbNm3UuXNnjR8/XsePH1fdunX18ccfKzc3t8g6O3TooE8++URjxoxRp06dVKtWLcXExJz5F1RGBAsAAAAU5QirUdt+4okndN5552nmzJl65plnJElNmzZV3759dd1115X4Pj8/P3355Zd65JFH9MEHH8gwDF133XWaMWOG2rdvX+p2GzZsqM2bN+vxxx/XrFmzlJmZqYsuukjLli1T//793fp++OGHGjlypF544QXVqVNHw4YNU+/evXXVVVe59bv//vu1Y8cOzZs3TzNnzlTz5s0rJVgY5qnne+ARKSkpioiIkNPpVO3atb1dDgDAC44mHdc7CxdXq5u360XW0bDbbtRZ9ep6uxTYkJmZqfj4eEVFRSk4OLhoh+xMKSer8gsrLNAhBRVTGzyqtJ+F8vxOyxkLAAAAuAsK5pd6lBs3bwMAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAABQTnfffbdatGjh7TJ8CsECAAAA1YZhGGV6rVu3ztulVjsB3i4AAAAAviUt/aQyMjO9WkNIcLBqhYWW+33v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lkVBqDBNU1dddZVWrlypgADbz+EDAAAA4MNs/8Zfv359rVy5Ur/88ou+++47HT9+XHXr1lWXLl24twIAAACoIc44WKSmpmry5MmSpBYtWuihhx7ShRde6LHCAAAAAFQdZxwswsPD9dprr8nlcunf//63J2sCAAAAUMXYuseiadOmkqSwsDCPFAMAAACgarIVLG699VaZpqnVq1d7qh4AAAAAVZCtYDFx4kR1795dP/zwg26++WbFxcUpIyPDU7UBAAAAqCJsjQpVq1YtSflDyy5evFiLFy8utp9hGMrNzbWzKQAAAAA+zNYZi8IPxiuYL+nlK/r37289yM8wDO3evdtt+d69e3XHHXeoYcOGcjgcatmypR5//HGlpKR4qWIAAADA99l+joUvhYbSfPjhh1qxYkWJy3/++Wf17NlTTqfTatu3b59eeuklxcbGasOGDQoPD6+MUgEAAIAqxVawmDdvnqfqqHDHjh3TI488IsMwFBgYqOzs7CJ97rnnHitUjBgxQv3799eMGTO0YcMG7dixQ1OmTNH06dMru3QAAADA55U7WNx7772S8keEGjp0qCTp4MGD2rdvnySpR48eHizPcx555BEdO3ZMI0aM0KpVq7R//3635T/++KPi4uIkSdHR0ZozZ44Mw1CnTp3UpEkTmaapd955R1OnTlVgYKA3PgIAAADgs8p9j8X8+fO1YMEC7dy502r75JNP1Lt3b11xxRUeLc5TVq5cqQ8//FCNGzfWSy+9VGyfTZs2WdOdO3e27hs5++yz1aJFC0lScnKyfv311wqvFwAAAKhqbN28XZiv3aRdIC0tTaNGjZIkzZ49WxEREcX2S0hIsKYbNmzotqxBgwbWdHx8fLHvz8rKUkpKitsLAABUHQV/VARwZmzfvO3rJkyYoP3792vw4MEaOHBgif3S09Ot6aCgILdlhecL9yts2rRpeuaZZ2xWCwAAvCEkNFR+/gE6mnTc26V4XEhwsGqFhXq7DNQA1TpY7N69W6+99poiIyM1a9as0/YNCwuzprOystyWFb7Ru3C/wsaPH68xY8ZY8ykpKWratOmZlA0AACqZwxGkzKxsLY39Vs6UVG+X4zERtcN1U/++BAtUimodLBITE5WXl6fk5GQ1atSo2D7R0dG6+OKLddddd1ltR44cKbKeAlFRUcWux+FwyOFweKBqAADgLc6UVCUl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n3++eezYsTKtm31UPoXHby/u9frrr1t9OY68p6z7iWPJ95T0jASOJ99R3D7iWPovgoUHlDVYpKammm+++aZ5zTXXmC1atDCDg4PNsLAws0OHDubLL79sZmVlFVl3Zmam+fzzz5sXXHCB6XA4zLp165rXXXeduW3bNi980qqrPMHCNE3z999/N2+//XazQYMGZlBQkBkVFWWOGzfOdDqdRdbtcrnM119/3WzXrp0ZHBxs1q5d2+zTpw/Br5zKuo+ys7PN999/3xw0aJDZsmVLMzQ01AwJCTHbtm1rPvXUU0X+B2ua7CNPmTVrltm3b1/znHPOMR0OhxkUFGS2aNHCvO2228wNGzYU6c9x5B1l3U8cS76npGBhmhxPvqK4fcSx9F+Gaf7feTQAAAAAOEPcvA0AAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAIBKs27dOhmG4fYKCgpSRESEzj33XF155ZV65pln9Ndff512PU6nU6+88or69eunxo0by+FwKDQ0VK1atdLtt9+uzz77TDk5OVb/Xr16FdmuYRgKDg5Ws2bNNHDgQH3++ecV/fEBoFozTNM0vV0EAKBmWLdunXr37l1qP39/fz311FN66qmn5Ofn/jewJUuW6L777lNycvJp17F27Vr16tVLUn6wWL9+fanbffLJJ/X888+X2g8AUFSAtwsAANRct9xyizp27Cin06nt27dr1apVcrlccrlcevrpp5WYmKg33njD6v/JJ5/otttuU+G/iV155ZW6/PLL5XA4lJCQoG+++UYJCQklbjMyMlJPPvmkcnNz9fvvv+vDDz9Udna2JOnFF1/Uo48+qrp161bYZwaA6opgAQDwmquvvlp33323Nb9r1y71799f8fHxkqQ5c+Zo4MCBuvrqq3X06FGNGDHCChWhoaH64osvdNVVV7mt0zRNLV68WGeddVax26xdu7Yee+wxa75BgwZ68cUXJUkul0u///67Onfu7MmPCQA1AvdYAAB8RnR0tD755BO3tpkzZ0qS3n33XaWkpFjtzz77bJFQIUmGYeimm25SmzZtyrTNJk2auM3Xr1+/vGUDAESwAAD4mE6dOuniiy+25jds2CCXy6U1a9ZYbYZhuJ3pOBMul0u7du3Su+++a7Vdcskl+te//mVrvQBQU3EpFADA55x//vn6+eefJUmZmZk6fvy4Dh06ZC1v0KDBGd8HsX//fhmGUaS9U6dO+uyzz86sYAAAZywAAL6nsgcsbNCggZ599lk1b968UrcLANUJwQIA4HN+//13azo4OFj16tVzuxfin3/+KXW42ZJERkZq+vTpGjt2rBo2bGitr3///vr222/tFQ4ANRjBAgDgU3766SfrMihJ6tmzp/z8/NSnTx+rzTRNLViw4IzWXzAq1EsvvaRNmzYpLCxMUv49F/fff79yc3PtfQAAqKEIFgAAn7Fnzx7deuutbm1jxoyRJN17770KDw+32idOnFjsGYaC4WZ//fXXUrf3r3/9y23o2T179ujDDz880/IBoEbj5m0AgNesXLlSx44dU0pKiuLi4rRy5Uq3MwYPPPCA+vbtK0k666yzNGfOHA0ZMkSmaSo9PV1XXnml9YC8oKAg7d+/X6tXr1ZCQoLWrl1bphoefvhhzZgxQ2lpaZKkF154QXfeeWeRJ34DAE6PYAEA8JpPPvmkyHMrJCkgIECTJ0/Wk08+6dZ+++23KyAgQCNGjJDT6ZRpmlq9erVWr159xjVERkZq1KhRevnllyVJu3fv1qJFi3TzzTef8ToBoCYyzMoeegMAUGOtW7dOvXv3dmvz9/dXaGio6tevr3PPPVc9evTQsGHDijy4rrDk5GS9++67WrlypX755RclJyfLz89P55xzjrp27aqbb75Zffv2VUBA/t/PevXqpfXr10uSmjdvroSEBLf1JSYmqkWLFsrKypIkXXzxxYqLiyt2WFoAQPEIFgAAAABs4wJSAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALb9f2IMRNmoPINbAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test3[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train3[\"DCR\"], bins=10, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "\n",
    "# Adding title and labels\n",
    "plt.title('TabDDPM', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a88eea0-7d2c-42a5-bde3-c75c6e819947",
   "metadata": {},
   "source": [
    "# CTGAN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "06c4c969-0c35-453f-8dc8-f47b7cd4c975",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"gen/ATACH/100/CTGAN/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn4 = pd.concat(data_lst)\n",
    "syn4.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "149dfc71-cf84-454a-89b8-5ec5c07420a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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772Kjo72SsEAUGEFGJIMyZ3j9VWHhQQpwDB0/PjxC1yDIQV4/7G7sNBQRUaEe329AAD/YytYzJgxQzNmzND27dv173//2woZ+bZv365vv/1Wo0eP1m233aaHHnpI1157re2iAaBCMgIkM1dKPyV5+bZRR60YZWZmaOmnS+VMPlm6hQMDpPAYKdDWfxIKiYmO0h09EggWAFBFeOW/Im3btlXbtm01Y8YMbdu2TQsXLtQbb7whl8sl0zSVkZGhBQsWaMGCBbrrrrs0b948ORwOb2waACoet1vK9fJVi1y3ZErO5JNKPn60dMsGBEkxpteDBQCgavHqde8jR45o3bp1WrZsmVwul6S/7vk1TVOmaerf//63pkyZ4s3NAgAAAPAx28HCNE2tWLFCt956qy6++GJNmDBB+/bts+Y5HA4NHjxY06ZNU40aNWSapj788EPbhQMAAADwH7aue0+YMEHvvvuuDh8+LEnWA9ySdPHFF+vBBx/U0KFDVb16dUlS3bp1NWjQIP3xxx92NgsAAADAz9gKFs8995wMw/AIFF26dNHDDz+s3r17K+CsHkYaNWokScrNzbWzWQAAAAB+xvaTeqZpKjw8XPfff78efvhhxcfHF9u2WbNmmjt3rt1NAgAAAPAztoJF48aNNXLkSA0ZMkTVqlU7b/s6depowIABdjYJVE1ZmVK2y9dVeDICpAJXKwEAQNVmK1js3buXN70C5SHbJf30teRK93Ulf4mqKcUVf4USAABULbaCRVJSkv773/9Kktq3b6+aNWta844fP66tW7dKkuLj43XJJZfY2RQAV7qUcdrXVfzFEeHrCgAAgB+xFSymTp2qd999VzVq1PB447YkRUVF6cEHH9SRI0fUv39/nq0AAAAAKjFb77H46quvJEm9evVSWFiYx7zQ0FD17NlTpmlq8+bNdjYDAAAAwM/ZChb5769o3LhxkfMbNmwoKe+N3AAAAAAqL1vBIv99FGffBpUvfzrvrQAAAAAqN1vBon79+jJNUx999JF+++03j3m//fabPvroIxmGofr169sqEgAAAIB/s/XwdqdOnfTbb78pPT1drVq1Uv/+/dW4cWPt379f77//vtLT02UYhjp16uStegEAAAD4IVvBYuTIkXr33XclSadPn9Ybb7xhzTP/98VZhmFo5MiRdjYDAAAAwM/ZuhWqTZs2mjRpkkzT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06mXXnpJ3bt3V/369eVwOBQeHq6mTZvqvvvu08cff6zs7GyrfZcuXQpt1zAMhYaG6uKLL1bv3r31ySeflPXuA0ClZpimafq6CABA1bBx40Zdf/31520XGBiop556Sk899ZQCAjx/A1uyZIkeeOABpaSknHMdGzZsUJcuXSTlBYsvvvjivNsdN26cnn322fO2AwAUFuTrAgAAVdfdd9+tNm3ayOl0aufOnfrss8/kdrvldrv19NNP68iRI3rjjTes9gsXLtS9996rgr+J3Xjjjbr22mvlcDiUlJSktWvXKikpqdhtxsbGaty4ccrJydEvv/yi+fPnKysrS5L0wgsv6NFHH1X16tXLbJ8BoLIiWAAAfOamm27SwIEDrfEff/xRPXr00P79+yVJs2fPVu/evXXTTTfp+PHjGjZsmBUqwsPD9emnn6pbt24e6zRNU4sXL1atWrWK3GZ0dLQee+wxa7x27dp64YUXJElut1u//PKL2rVr583dBIAqgWcsAAB+o1mzZlq4cKHHtJdfflmS9M477yg1NdWaPnXq1EKhQpIMw9Add9yhFi1alGibDRo08BivWbNmacsGAIhgAQDwM23bttVVV11ljW/atElut1vr1q2zphmG4XGl40K43W79+OOPeuedd6xpV199tf72t7/ZWi8AVFXcCgUA8DuXXXaZvvvuO0lSZmamTp48qUOHDlnza9eufcHPQRw4cECGYRSa3rZtW3388ccXVjAAgCsWAAD/U94dFtauXVtTp05Vo0aNynW7AFCZECwAAH7nl19+sYZDQ0NVo0YNj2chjh07dt7uZosTGxurGTNm6PHHH1edOnWs9fXo0UPr16+3VzgAVGEECwCAX/n222+t26AkqXPnzgoICFDXrl2taaZp6t13372g9ef3CjV9+nRt3rxZERERkvKeuRg5cqRycnLs7QAAVFEECwCA3/j55591zz33eEwbPXq0JGnw4MGKioqypk+YMKHIKwz53c1+//33593e3/72N4+uZ3/++WfNnz//QssHgCqNh7cBAD6zZs0anThxQqmpqdq1a5fWrFnjccXgoYceUkJCgiSpVq1amj17tvr27SvTNJWenq4bb7zRekFeSEiIDhw4oM8//1xJSUnasGFDiWp45JFHNHPmTJ0+fVqS9Pzzz6tfv36F3vgNADg3ggUAwGcWLlxY6L0VkhQUFKRJkyZp3LhxHtPvu+8+BQUFadiwYXI6nTJNU59//rk+//zzC64hNjZWI0aM0IsvvihJ+umnn7Ro0SLdddddF7xOAKiKDLO8u94AAFRZGzdu1PXXX+8xLTAwUOHh4apZs6YuueQSXXfddRoyZEihF9cVlJKSonfeeUdr1qzRf//7X6WkpCggIEAXXXSROnTooLvuuksJCQkKCsr7/axLly764osvJEmNGjVSUlKSx/qOHDmiuLg4uVwuSdJVV12lXbt2FdktLQCgaAQLAAAAALZxAykAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2/4/QjLmwYDvHNkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dcr_train4 = _calculate_dcr(data_train, syn4, meta_data)\n",
    "dcr_test4 = _calculate_dcr(data_test, syn4, meta_data)\n",
    "\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test4[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train4[\"DCR\"], bins=15, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "\n",
    "# Adding title and labels\n",
    "plt.title('CTGAN', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a143eeda-ee00-4456-9767-1569afe6457b",
   "metadata": {},
   "source": [
    "# TVAE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "6dd66d80-45c9-492e-bbab-18a4dfea2319",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"gen/ATACH/100/TVAE/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn5 = pd.concat(data_lst)\n",
    "syn5.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "a96ee28b-e086-410f-b8e7-2cd41a86d895",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABVzklEQVR4nO3deVwVdf///+ewHQQBQROXVMwsF0pNLTO3tDBT0yxbzaXFzD5Xl5dm5ZKWXWlZ2ud2lUv5za2svMpKUTPMxDK1rLRfmnZd5ZrmhnBAZD1nfn/wYeIIKDjAOcDjfrudW7O8z8xrziTwPO+Z9ximaZoCAAAAABv8vF0AAAAAgMqPYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABALAlJiZGhmHYfvXs2fO8+3E6napRo4bHe3bt2uXR5uTJkwoKCiq07dWrV5932z169ChxnWPGjLH7kQFAlUSwAAB4TUBAgDWdmJiow4cPF9v2ww8/VGZmpjXfvn17xcbGerR59913lZOTU+i9ixcvtl8sAOC8Ai7cBACA4t166606ceKEx7JffvlFe/bsseabNGmiDh06FHpvRkaG1q5dK0kyTVPLli3TM888U+R+3nnnHY/54cOHF2qzZMmSIt8bHx+v06dPKyoq6rzHkq9Dhw5q0qRJkevatm1bom0AQHVjmKZpersIAEDV8txzz+n555+35ocNG1Zkr8GKFSt05513WvOtWrXS7t27C7U7ePCgmjZtqvxfWUFBQfrzzz89gsKOHTt0zTXXWPOBgYEevRevv/66/ud//qfIenv06KFNmzZZ84sWLSoyuAAAiselUAAAr+nfv79q165tzf/yyy/68ccfC7V79913VfB7sP79+xfqfTg3uDz33HPnXQ8AKFsECwCA1wQFBenee+/1WHbuJU9FLTu3NyEnJ0fvvfeeNR8aGqoxY8bouuuus5b98MMPhW72BgCUHYIFAMCrzg0J77//vlwulzW/fft2/frrr9Z8vXr1dMstt3i8Jz4+XqdOnbLmb7vtNoWEhBQKLSXttZgzZ47uvPPOIl8nT54s4ZEBQPVCsAAAeFX79u111VVXWfPHjx9XQkKCNX9ub8X999/vMZqUVDgw3HfffZKku+++W35+f/2qW7ZsmXJzcy9Y0/fff68VK1YU+UpPTy/xsQFAdUKwAAB43bm9FkuXLpWUd4nTBx98cN62x48f12effWbNR0VFqXfv3pLyejduvPFGa92xY8e0bt26MqwcAJCPYAEA8LohQ4Z49EKsXLlSaWlpWrduncelR8U9u6JgL8Qdd9yhwMBAa/5iLodatGiRTNMs8hUTE1PKowOA6oHnWAAAvK5u3brq06eP4uPjJeU93+Kjjz7y6ImQSvbsig8//NB6NoakQg/MK+0zLQAAJUOPBQDAJ4wYMcJjft68eVbQkPJGkMq/dyLfDz/8oJ9//tljWUpKio4cOWK9zn14X3Z2tscIUgCAskGwAAD4hH79+qlOnTrW/Pbt25WZmWnNl+TZFSXFMy0AoOxxKRQAwCcEBgbqvvvu07/+9a8i1597GVRRPQ8///xzoXswJCk3N1f16tVTUlKSpL+eaVFUWylvuNnVq1cXua5169YeTxUHAOQhWAAAfMbw4cOLDBZFPbti1apVOn36tDXfunXrYoNCQECABg0apAULFljLFi9erFdffbXI9t9//72+//77ItcVfF4GAOAvXAoFAPAZ7dq1U5s2bQotL8mzK+65557zbvvuu+/2mC/pMy0AACVjmKZpersIAAAAAJUbPRYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALAtwNsFVFVut1tHjx5VWFiYDMPwdjkAAABAqZmmqbS0NDVo0EB+fufvkyBYlJOjR4+qUaNG3i4DAAAAsO3w4cO69NJLz9uGYFFOwsLCJOWdhPDwcC9XAwAAAJReamqqGjVqZP1tez4Ei3KSf/lTeHg4wQIAAACVWkku7efmbQAAAAC2ESwAAAAA2FYpg8Xp06c1YcIEde/eXSEhITIMQ4ZhaPjw4R7tsrOz9eabb+quu+5SixYtFB4erho1aqhVq1aaMmWK0tPTC23b7XZr3rx5ateunUJCQhQREaGbbrpJGzZsqKCjAwAAACofwzRN09tFlNbOnTvVrl27QsuHDRumxYsXW/PHjh1T/fr1i91Ox44dtXnzZgUFBVnLhg8friVLlhRqaxiGFi9erKFDh5aoxtTUVEVERMjpdHKPBQAAACql0vxNWylv3g4KClK3bt3UuXNnnThxQgsXLiy2rWEYuuWWW3T33Xerfv36SkhI0KxZsyRJ27dv17JlyzRixAhJ0qpVq6xQ0aBBA82ePVt//vmnxo8fr9zcXD3++OPq3bu3oqOjy/8gAQAAKoBpmnK5XMrNzfV2KahAAQEB8vf3L9PnrVXKYNGqVStt2rRJkjR//vxig0VoaKi++eYbXX/99dayuLg4/f777/r0008l5YWL/GAxf/58q92sWbN09913S5L27t2rN998U2fOnNG7776rcePGlcdhAQAAVBjTNJWSkqKTJ0/K5XJ5uxx4gb+/v+rWrauIiIgyCRiVMliUVFhYmEeoyNe8eXNrOjQ0VFLeP65vvvnGWt65c2eP6TfffFOS9PXXXxMsAABApXfs2DGlpKRYQ+MHBASU6bfX8F2maSo3N1epqan6888/lZGRcd7bB0qqSgeLouTk5Cg+Pt6a79OnjyQpOTlZqamp1vKClzvVrVvXmt6/f3+R283KylJWVpY1X3BbAAAAvsTlcsnpdOqSSy5RnTp1vF0OvCQsLEwOh0OnTp1S3bp15e/vb2t7lXJUqIvldrv18MMPa+/evZKkO+64Qz179pSkQiNEFbyhu+B0USNJSdKMGTMUERFhvRo1alTW5QMAAJSJnJwcmaZpXbmB6is0NFSmaSonJ8f2tqpNsMjJydF9992npUuXSpK6du1qTUsq9A+rYO9DdnZ2se3yTZgwQU6n03odPny4LMsHAAAoc1z6hGp/83ZpZWZmavDgwVq9erUkqVevXlq5cqVCQkKsNpGRkQoPD7cuYTp+/LiaNGkiKe8axHxNmzYtch8Oh0MOh6O8DgEAAADwaVW+x+LMmTPq27evFSoGDBigNWvWFOp5MAxDN9xwgzW/ZcsWa3rr1q3WdNeuXcu5YgAAAKDyqZQ9FmfPntXatWslSTt27LCWHzx4UB999JGkvIff1a1bVzfffLO2bdsmSbr66qs1ZswYbd++3XpPdHS0NUrUqFGj9Nlnn0mSxo0bJ8MwdOzYMb399tuSpJo1a2rIkCHlf4AAAADwScOHD1diYqIOHDhw3nYHDhxQ06ZNtWjRIg0fPrxCavO2ShksTpw4ocGDBxdanpiYqMTEREnSokWL1KNHDytUSNL/9//9f7rxxhs93lPwad233Xabhg0bpiVLlujPP//Uvffea7UzDENz5szh4XgAAAA+bvHixRoxYoS2b9+uDh06FFrfo0cPnTp1Srt27fJCdeXvvffe04kTJzRmzJgK3W+lDBblaeHChbr22mu1YMEC7d27V0FBQerYsaMmTJigXr16ebs8AACA8pedKeVkXbhdeQp0SEHB3q2hknrvvfe0a9cugkVJxMTEyDTNErUtabt8fn5+Gj16tEaPHn0xpQEAAFR+OVnS3m1SVtHD7Jc7R6jUohPBopKp8jdvAwAA4CJkpUsZZ7zz8lKgeffdd9W+fXvVqFFDUVFRuueee0r0CIGUlBQNHz5cERERqlWrloYNG6aUlJQS73ffvn0aPHiwoqKiFBISok6dOmnNmjUebRYvXizDMArd25GYmCjDMKzbAXr06KE1a9bo4MGDMgxDhmEoJiamxLXYUSl7LAAAAIALcTqdOnXqVKHlRT0M7sUXX9Szzz6ru+66Sw8//LBOnjyp119/Xd26ddOOHTtUq1atIvdhmqYGDBigzZs3a9SoUWrZsqU++eQTDRs2rEQ1Hj9+XJ07d9bZs2f1xBNPqHbt2lqyZIluu+02ffTRR7r99ttLdcyTJk2S0+nUH3/8oddee01S3gBEFYFgAQAAgCrppptuKnZd69atremDBw9q6tSp+uc//6mJEydaywcNGqR27dpp7ty5HssLWrVqlb766ivNnDlT48ePlyQ99thjhQYMKs5LL72k48eP6+uvv1aXLl0kSY888oiuvvpqjR07VgMGDJCfX8kvMrr55pvVsGFDJScnV/hopgQLADiPM+lnlZGZ6e0yLqhGcLBqhoZcuCEAVCNz5szRFVdcUWj5uHHj5HK5rPmPP/5Ybrdbd911l0cPR7169dS8eXNt3Lix2GCxdu1aBQQE6LHHHrOW+fv7629/+5u+/vrrC9a4du1aXXvttVaokPJ6GEaOHKkJEybol19+UWxsbImO19sIFgBwHhmZmfpoTYKcqWneLqVYEeFhurNvHMECAM5x7bXXFjncbGRkpEeA+O9//yvTNK1nm50rMDCw2H0cPHhQ9evXL3S50ZVXXlmiGg8ePKjrrruu0PKWLVta6wkWAFBFOFPTlJSc4u0yAADlxO12yzAMffbZZ/L39y+0vqLuUTgfwzCKXF6w58XbCBYAAACo1po1aybTNNW0adMiL506nyZNmmjDhg06c+aMRwD59ddfS/z+otru3bvXWi/l9bJIKjTa1MGDBwu9t7gQUt4YbhYAAADV2qBBg+Tv76/nn3++0DPQTNNUUlJSse+99dZblZubq3nz5lnLXC6XXn/99RLt+9Zbb9V3332nrVu3WsvS09P11ltvKSYmRq1atZKUF34k6auvvvLYz1tvvVVom6GhoXI6nSXaf1mixwIAAADVWrNmzfTPf/5TEyZM0IEDBzRw4ECFhYVp//79+uSTTzRy5Eg9+eSTRb63f//+uuGGG/TMM8/owIEDatWqlT7++OMS/2H/zDPP6P3331efPn30xBNPKCoqSkuWLNH+/fu1YsUKa0So1q1bq1OnTpowYYJOnz6tqKgoffDBB8rNzS20zfbt22v58uUaO3asOnbsqJo1a6p///4X/wGVEMECAAAAhTlCq9W+n3nmGV1xxRV67bXX9Pzzz0uSGjVqpLi4ON12223Fvs/Pz0+rVq3SmDFj9O6778owDN12222aNWuW2rVrd8H9RkdHa8uWLXr66af1+uuvKzMzU1dffbXi4+PVt29fj7bLli3To48+qpdeekm1atXSQw89pBtvvFE333yzR7vRo0dr586dWrRokV577TU1adKkQoKFYZ7b34MykZqaqoiICDmdToWHh3u7HAAX6WTSab39/gqfvnm7dmQtPXTvHbqkdpS3SwFQSWRmZmr//v1q2rSpgoODCzfIzpRysiq+sIICHVJQEbWhTF3o/4XS/E1LjwUAAAA8BQXzRz1KjZu3AQAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAACil4cOHKyYmxttl+BSCBQAAAKoMwzBK9EpMTPR2qVVOgLcLAAAAgG85k35WGZmZXq2hRnCwaoaGlPp977zzjsf80qVLtX79+kLLW7Zsaau+BQsWyO1229pGVUOwAAAAgIeMzEx9tCZBztQ0r+w/IjxMd/aNu6hgMWTIEI/5bdu2af369YWWn+vs2bMKCSn5/gIDA0tdW1VHsADgFb7wbdiF+Pn5ycW3UQCqKWdqmpKSU7xdRrno0aOHTp06pSVLlugf//iHvv/+e40cOVL/+7//q5UrV+qtt97Sjh07lJSUpEsvvVTDhw/XxIkT5e/vb21j+PDhSkxM1IEDByRJBw4cUNOmTfXKK68oPDxcL7/8sv744w9dffXVmjt3rjp27Oilo604BAsAXuHtb8NKolGD+rrxhmu9XQYAoBwkJSWpT58+uueeezRkyBBFR0dLkhYvXqyaNWtq7Nixqlmzpr788ktNmTJFqampeuWVVy643ffee09paWl69NFHZRiGZs6cqUGDBmnfvn1VvpeDYAHAa3z927Ba4WHeLgEAUE6OHTum+fPn69FHH/VY/t5776lGjRrW/KhRozRq1CjNnTtX//znP+VwOM673UOHDum///2vIiMjJUlXXnmlBgwYoM8//1z9+vUr+wPxIYwKBQAAgGrH4XBoxIgRhZYXDBVpaWk6deqUunbtqrNnz2rv3r0X3O7dd99thQpJ6tq1qyRp3759ZVC1b6PHAgAAANVOw4YNFRQUVGj57t27NXnyZH355ZdKTU31WOd0Oi+43caNG3vM54eM5ORkG9VWDgQLAAAAVDsFeybypaSkqHv37goPD9e0adPUrFkzBQcH68cff9TTTz9douFlC97gXZBpmrZr9nUECwAAAEBSYmKikpKS9PHHH6tbt27W8v3793uxqsqDYAGganC7JbOMh4Z1uyRTkis371Uahp/kx21sAFCZ5Pc2FOxdyM7O1ty5c71VUqVCsABQNZhu6Uyy5HKV3TbTIyTTJZ11Ss5TJX+fv79UM1KMjwEAlUvnzp0VGRmpYcOG6YknnpBhGHrnnXeqxWVMZYFgAaDqcLkkdyl7Fs7H6rFwl+12AaASiPDikNve2nft2rW1evVqjRs3TpMnT1ZkZKSGDBmiXr16qXfv3l6pqTIhWAAAAMBDjeBg3dk3zus1lIU33nhDb7zxhseyxMTEYtt37txZW7duLbT83F6LxYsXe8zHxMQU27NRXXo8CBYAAADwUDM0RDVDQ7xdBioZLgAGAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAACgmqouw6CieGX5/wDBAgAAoJrx9/eXJOXk5Hi5Enhb/v8D+f9P2EGwAAAAqGYCAwPlcDjkdDrptajGTNOU0+mUw+FQYGCg7e3xgDwAAIBqqE6dOjpy5Ij++OMPRUREKDAwUIZheLssVADTNJWTkyOn06kzZ86oYcOGZbJdggUAAEA1FB4eLkk6deqUjhw54uVq4A0Oh0MNGza0/l+wi2ABAABQTYWHhys8PFw5OTlyuVzeLgcVyN/fv0wufyqIYAEAAFDNBQYGlvkfmah+uHkbAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhWKYPF6dOnNWHCBHXv3l0hISEyDEOGYWj48OFFtv/hhx80YMAA1a5dW8HBwWrVqpVmzJih7OzsQm2zsrI0ffp0tWrVSsHBwapdu7YGDhyoH3/8sZyPCgAAAKi8ArxdwMU4dOiQXnrppRK1TUhIUP/+/T1CxJ49ezRx4kQlJiZq7dq18vf3lyTl5uaqb9++2rBhg9U2KytLK1eu1Lp167RmzRr16tWrbA8GAAAAqAIqZY9FUFCQunXrpmeeeUYPPvhgse0yMjI0YsQIK1RMnjxZK1asUGxsrKS80DF//nyr/dy5c61QERsbqxUrVmjy5MmS8gLG8OHDlZWVVV6HBQAAAFRalTJYtGrVSps2bdKMGTPUsWPHYtvFx8fr6NGjkqTevXvrhRde0KBBg7RgwQKrTcFgUXB6wYIFGjRokF544QX17t1bkvTHH39o9erVZX04AAAAQKVXKYNFSW3evNma7ty5szXdoUMHBQYGSpJ27dql5ORknT59Wnv27JEkBQYGegSWgu/9+uuvy7tsAAAAoNKplPdYlNSBAwes6ejoaGs6ICBAUVFROn78uNXONE1rfe3ata37LiSpbt261vT+/fuL3FdWVpbHZVKpqam26wcAAAAqiyrdY5Genm5NBwUFeawrOJ+enl6qtkWZMWOGIiIirFejRo1s1Q4AAABUJlU6WISGhlrT5950XXCUqNDQ0FK1LcqECRPkdDqt1+HDh23VDgAAAFQmVfpSqJiYGGs6/7InKW9Y2aSkJI92BS+FSkpKUm5urgIC8j6eY8eOWeuaNm1a5L4cDoccDkdZlQ4AAABUKlW6x6JLly7W9JYtW6zp7du3Kzc3V1LesLKRkZGKiopSy5YtJeUFj+3bt1vtt27dak137dq1vMsGAAAAKp1K2WNx9uxZrV27VpK0Y8cOa/nBgwf10UcfSZI6duyo/v37q0GDBjp69KgSEhI0adIktW/fXlOmTLHeM2rUKI/pv//975KkRx55RNOmTdOPP/6ohIQESdKll16qfv36lfvxAQAAAJVNpQwWJ06c0ODBgwstT0xMVGJioiRp0aJFGj58uBYtWmQ9eXv69Oke7ePi4jyCxejRo7Vq1Spt2LBBu3fv1h133GGtczgcWrx4MZc7AQAAAEWo0pdCSXnhYcuWLerfv78iIyPlcDjUsmVLTZ8+XfHx8R7DygYEBGjNmjV68cUX1aJFCzkcDkVFRem2227Tli1b1KtXLy8eCQAAAOC7KmWPxbk3W19I+/bttWrVqhK1dTgcmjhxoiZOnHix5QEAAADVTpXvsQAAAABQ/ggWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsCvF0AAFQ5foYkQ3LlVsz+XLmS2yWdTZNMd9FtAh1SUHDF1AMAqJYIFgBQ1gy/vD/w01Mkl6v89xdg5oWKQz9KWemF1ztCpRadCBYAgHJFsACA8uJySe4K6LVw50pud16oyDhT/vsDAKAI3GMBAAAAwDZ6LACUXnamlJN18e83/PLuCXDllt19CKZZNtsBAAAXpVoEi23btmnmzJnatm2bTp48qcDAQDVr1kwDBw7UU089pbCwMI/2P/zwg6ZNm6bNmzcrPT1dl112mR544AGNGzdOQUFBXjoKwIfkZEl7txV9PX9JOEKlOs2ltGTJmWS/noAgKSTswu0AAEC5qfLBYuPGjYqLi1Nu7l/fiubm5mrXrl3atWuXvvjiC23ZskWGYUiSEhIS1L9/f2VnZ1vt9+zZo4kTJyoxMVFr166Vv79/hR8H4HPsXs/vdv/fvQFl0GNh8m8SAABvq/L3WLz++utWqOjZs6fWrVunuXPnKjAwUFJeb8aPP/4oScrIyNCIESOsUDF58mStWLFCsbGxkvJCx/z5871wFAAAAIBvq/LBwul0WtNjx45V79699dhjj6lNmzbW8vzgER8fr6NHj0qSevfurRdeeEGDBg3SggULrLYECwAAAKCwKn8pVI8ePfTll19KkmbPnq3AwED9/vvv+umnnyRJrVq10jXXXCNJ2rx5s/W+zp07W9MdOnRQYGCgcnJytGvXLiUnJysyMrICjwIAAADwbVU+WDz11FM6ePCgFi9erC+//NIKGZI0dOhQvfLKK9ZlUQcOHLDWRUdHW9MBAQGKiorS8ePHrXbnBousrCxlZf01Sk5qamp5HA4AAADgk6r8pVBBQUG68sorVatWrULrEhIS9O2331rz6enpHu87dztFtcs3Y8YMRUREWK9GjRqVQfUAAABA5VDlg8Xzzz+vp556SklJSXriiSeUmpqqnTt3Kjo6WseOHdOdd95p9VSEhoZa7yvY+yDJY5Sogu3yTZgwQU6n03odPny4fA4IAAAA8EFVPlgUvPF60qRJCgsLU5s2bTRo0CBJeYFh7dq1kqSYmBirbf5lT1Lezd1JSX+NtV+wXT6Hw6Hw8HCPFwAAAFBdVPlgcerUKWv6zJm/xtxPS0srtLxLly7Wsi1btljT27dvt0aOio2N5cZtAAAA4BxVPli0bt3amh45cqQ+++wzzZkzRx9++KG1vG3btpKk/v37q0GDBpLy7r+YNGmSPv74Yz3yyCNW21GjRlVM4QAAAEAlUuVHhZo2bZoGDhwol8ulDRs2aMOGDR7re/XqpZtvvlmSVKNGDS1atMh68vb06dM92sbFxREsAAAAgCJU+R6Lfv36adOmTRo4cKDq1aungIAAhYSEqE2bNnrxxRe1evVqGYZhtY+Li9OWLVvUv39/RUZGyuFwqGXLlpo+fbri4+Pl7+/vxaMBAAAAfFOV77GQpBtuuEE33HBDidu3b99eq1atKseKAKBsGX5+kqPwiHWS8pYbVf57JACAl1WLYAEAVVmNkBD5hYbrpJpLbnfhBn5+UnqmlJFT8cWdo0ZwsGqGhni7DABAOSBYAEAl53A4lJmdo5Xx6+Q8fapwA78AKSxS8vfuj/yI8DDd2TeOYAEAVRTBAgCqCGdKisczdyx+AVKu4fVgAQCo2rjoFgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC22QoWsbGxmj17tk6cOFFW9QAAAACohGwFi19++UXjx49Xo0aNNHDgQK1cuVIul6usagMAAABQSZTJpVA5OTmKj4/XoEGD1LBhQ40fP16//PJLWWwaAAAAQCVgK1iMGzdOjRs3liSZpinTNHXy5EnNnj1bV111la677jq9+eabSk1NLZNiAQAAAPgmW8HilVde0f79+/Xtt99q3LhxatKkiRUwTNPU9u3bNXr0aNWvX19DhgzR1q1by6puAAAAAD6kTC6F6tixoxUytm3bpn/84x8KDg6WYRgyTVMZGRl6//331aVLF917773Kysoqi90CAAAA8BFlOtzssWPHtGHDBq1atcoKD4ZhSPrrUql///vfmjZtWlnuFgAAAICX2Q4Wpmlq9erVGjhwoBo3bqzJkydr37591jqHw6EHH3xQM2bMUO3atWWapt577z3bhQMAAADwHQF23jx58mQtWbJER48elZQXJPI1btxYjz32mB555BFFRUVJkurVq6cRI0bojz/+sLNbAAAAAD7GVrCYPn26dR9Fvh49euhvf/ubBgwYID8/zw6RJk2aSJLcbred3QIAAADwMbaChZTXSxESEqL7779ff/vb3xQbG1ts25YtW2rRokV2dwkAAADAx9gKFk2bNtXo0aP10EMPqVatWhdsHx0drWHDhtnZJQAAAAAfZCtY/Pbbb9aoTwAAAACqL1vB4sCBA/r5558lSZ07d1adOnWsdSdPnrQeiBcbG6vLLrvMzq4AAAAA+DBbweKFF17QkiVLVLt2bR08eNBjXVhYmB577DEdO3ZMQ4cO5d4KAAAAoAqz9RyLb775RpLUv39/1ahRw2NdcHCw+vXrJ9M0tXnzZju7AQAAAODjbAWL/OdXNG3atMj1jRo1kpT3RG4AAAAAVZetYJH/PIpzL4PKl7+c51YAAAAAVZutYNGgQQOZpqkPPvhAv//+u8e633//XR988IEMw1CDBg1sFQkAAADAt9m6ebtr1676/ffflZ6ernbt2mno0KFq2rSp9u/fr3feeUfp6ekyDENdu3Ytq3oBAAAA+CBbwWL06NFasmSJJOnMmTOaN2+etc40TUmSYRgaPXq0nd0AAAAA8HG2LoXq0KGDpk6dKtM0i31Q3tSpU9WhQwc7uwEAAADg42wFC0maMmWKli9frnbt2kn6q6fimmuu0b///W89++yzdncBAAAAwMfZuhQq3+DBgzV48GBlZGQoOTlZkZGRhZ5rAQAAAKDqKpNgka9GjRoECgAAAKAaKpNg8d1332n79u1KTk4u9pkVU6ZMKYtdAQAAAPBBtoJFSkqKbr/9dn311VcXbEuwAAAAAKouW8Fi/Pjx2rRpk6S8YWXzb9w+V3EjRgEAAACoGmwFi1WrVlmBws/PT3Xq1JHD4SBIAAAAANWMrWCRmpoqSbr66qu1ceNGRUZGlklRAAAAACoXW8+xuOKKKyRJAwcOJFQAAAAA1ZitYPHoo4/KNE1t3bq1rOoBAAAAUAnZuhSqT58+6tKli7744gsNHjxYo0aNUkxMjAIDAwu1bdy4sZ1dAQAAAPBhtoJFs2bNrJu3P/74Y3388cdFtjMMQ7m5uXZ2BQAAAMCHlckD8vJHgSpuuFkAAAAAVZvtYEGYAAAAAGArWGzcuLGs6gAAAABQidkKFt27dy+rOgAAAABUYraGmz1XZmamjhw5ojNnzpTlZgEAAAD4uDIJFh988IE6dOigmjVrqnHjxnrrrbeUkJCgBx98UA899JBSUlLKYjcAAAAAfJTtm7fHjx+v2bNnS8q7kTt/hKgrr7xSixcvlmEY6ty5sx566CG7uwIAAADgo2z1WHz22WeaNWuWpMKjQzVp0kTt2rWTJCUkJNjZDQAAAAAfZytYzJkzR1LecyxGjx5daH2nTp1kmqZ27NhhZzcAAAAAfJytYPHdd9/JMAwNHjxYb7zxRqH1DRs2lCQdPXrUzm4AAAAA+Dhb91g4nU5J0lVXXVXk+szMTElSTk6Ond0AAOzwMyQZkivXu3W4ciW3SzqbJgUESkHB3q0HAFCmbAWLWrVq6dSpU/rtt9+KXL9lyxZJUu3ate3sBgBgh+EnmW4pPUVyubxXR4CZFyqO7ZEua0OwAIAqxlawaNu2rdavX6/333/f42F5R48e1YQJE/Tll1/KMAy1b9/edqEAAJtcLsntxV4Ld67kdkvZGd6rAQBQbmwFiyFDhmj9+vXKzs7Wgw8+KClvdKjXXnutUDsAAAAAVZetm7eHDBmiXr16WUPNGoZhPcci30033aS7777bzm4AAAAA+DhbwcIwDMXHx2vkyJHy9/eXaZrWy8/PT4888og+/fTTMioVAAAAgK+y/eTt4OBgzZ8/XzNmzNC3336r06dPKyoqStddd50iIyPLokYAAAAAPs52sMgXGRmpW265paw2BwAAAKASsRUsDh06VOK2jRs3trMrAAAAAD7MVrCIiYkpdLN2UQzDUG6udx/MdPDgQc2YMUOff/65jh49qpo1a6pZs2a6/fbbNWHCBI+2P/zwg6ZNm6bNmzcrPT1dl112mR544AGNGzdOQUFBXjoCAAAAwHeVyaVQ+aNC+apvvvlGt956q1JTU61lp0+ftl4Fg0VCQoL69++v7Oxsa9mePXs0ceJEJSYmau3atfL396/Q+gEAAABfZ2tUKKn4UFHU0LPekJKSosGDBys1NVX+/v4aNWqUPvnkE61bt05z5sxR3759rbYZGRkaMWKEFSomT56sFStWKDY2VlJe6Jg/f75XjgMAAADwZbZ6LDZu3FhoWVZWlv773/9qzpw5+vXXX9W3b189+eSTdnZjy4IFC/Tnn39Kkp577jlNnjy52Lbx8fE6evSoJKl379564YUXJEkNGjTQ9ddfL0maP3++Hn/88XKuGgAAAKhcbAWL7t27F7k8Li5OQ4YMUWxsrNauXauRI0fa2Y0t8fHx1rTb7dZVV12l3377TXXr1tV9992nqVOnKjg4WJK0efNmq23nzp2t6Q4dOigwMFA5OTnatWuXkpOTGUoXAAAAKMD2pVDFiYiI0A033CDTNPXSSy+V124u6JdffrGmp06dql27dikzM1OHDh3SSy+9pAEDBliXcx04cMBqGx0dbU0HBAQoKirKmi/YLl9WVpZSU1M9XgAAAEB1UW7BIjU1Vd99950kaefOneW1mwtKSUmxpiMjI7V06VItXbrU6nFISEjQqlWrJEnp6elW23NHfyo4X7BdvhkzZigiIsJ6NWrUqCwPAwAAAPBpti6F6tmzZ6FlpmkqIyNDv/76q/Wtff6lRt7gcDh09uxZSdJjjz2mBx54QFLeSE8zZsyQJH3xxRcaMGCAQkNDrfdlZWV5bKfgKFEF2+WbMGGCxo4da82npqYSLgAAAFBt2AoWiYmJxY78ZJqmNTJUXFycnd3Y0rhxY+3du1eS1KRJE2t5wen8ABQTE2MtO378uDWdm5urpKQka75gu3wOh0MOh6OsygYAAAAqlTIZbraoV/66yy+/XK+++qrtQi/WDTfcYE0XfFJ4wen8noUuXbpYy7Zs2WJNb9++3XrAX2xsLDduAwAAAOew1WMxbNiwIpf7+fmpVq1a6tixo26//XavfpP/8MMPa+HChTJNU/PmzVOLFi0kyeN5FHfccYckqX///mrQoIGOHj2qhIQETZo0Se3bt9eUKVOstqNGjarYAwAAAAAqAVvBYtGiRWVVR7np1KmTnnzySb3yyis6ffq0dY9Fvqefflrt2rWTJNWoUUOLFi2ynrw9ffp0j7ZxcXEECwAAAKAI5TYqlC+ZOXOmlixZoo4dOyokJEQhISG67rrr9O677xYaCjcuLk5btmxR//79FRkZKYfDoZYtW2r69OmKj4+Xv7+/l44CAAAA8F22eiy++uqri35vt27d7Oy61IYOHaqhQ4eWqG379u2tIWgBAAAAXJitYNGjR49iR4U6H8MwrJuhAQAAAFR+toJFvvxRoC7EMIwStwUAAABQedgOFvnPqygqMJy7nFABVBGGn+Qo/KDIEnOESn6l7+0EAAC+y1aw2Ldvn/7+978rPj5ejzzyiIYMGaLo6GgdP35c77zzjv7f//t/6tevn/71r39d1CVTAErvTPpZZWRmlu9O3C6pTnPJ7b6ot/sFBMgV4MgLKAAAoEqwFSw+//xzrV69WoMGDdKbb75pLb/iiivUtWtXJSUl6dNPP9Utt9yi0aNH2y4WwIVlZGbqozUJcqamld9OXLlSWrLkvrh7pRo1aaIbb44jWAAAUIXYChavv/66pLynURflqquu0ieffKI5c+YQLIAK5ExNU1JySvntwJUrOZMuOljU4un1AABUOba+Lvz9998lSatXr1ZOTo7HupycHMXHx0vKu2QKAAAAQNVlq8fikksu0ZEjR7Rjxw7FxsbqjjvuUN26dXXixAmtWLFCv/32m9UOAAAAQNVlK1jce++9euWVV2QYhv773//q5ZdfttbljwBlGIbuu+8+e1UCAAAA8Gm2LoWaOnWqOnfubA05W5Trr79eU6dOtbMbAAAAAD7OVrAICQlRYmKiXn75ZTVv3lymaVqvK6+8UjNnzlRiYqJq1KhRVvUCAAAA8EG2H5AXEBCg8ePHa/z48Tpz5oycTqciIiJUs2bNsqgPAAAAQCVgO1gUVLNmTQIFAAAAUA2VydOptm7dqjvvvFMNGjRQYGCgZs+erS1btmjatGmaNm2aMjIyymI3AAAAAHyU7R6Lf/3rXxo7dqx1b0X+Tdy1atXSc889J8MwdMUVV+iee+6xXSwAAAAA32Srx2Lbtm0eoaKgVq1aqUWLFpKkzz77zM5uAAAAAPg4W8Fi9uzZcrvdkqRbb7210PobbrhBpmnq+++/t7MbAAAAAD7OVrDYvHmzDMPQLbfcotWrVxda36RJE0nS4cOH7ewGAAAAgI+zFSySkpIk5fVMFCW/NyMzM9PObgAAAAD4OFvBIn9o2SNHjhS5/ocffpAkRUZG2tkNAAAAAB9nK1jExsbKNE0tW7ZMmzZtspZnZGTozTff1Jo1a2QYhq6++mrbhQIAAADwXbaGmx08eLC+/vprpaWlqWfPnpIk0zQ1ZcoUa9owDA0ePNh+pQAAAAB8lq0ei5EjR6pNmzbWULOGYcgwDI+hZ9u2basHH3zQXpUAAAAAfJqtYBEUFKT169crLi7OepZFfqgwTVM333yz1q1bp4AA28/hAwAAAODDbP/FX6dOHa1bt04///yzvvnmG50+fVpRUVHq3Lkz91YAAAAA1cRFB4u0tDRNnTpVkhQTE6MnnnhCV111VZkVBgAAAKDyuOhgERYWpjfeeEMul0v/+Mc/yrImAAAAAJWMrXssGjVqJEkKDQ0tk2IAAAAAVE62gsU999wj0zS1fv36sqoHAAAAQCVkK1hMnjxZXbt21bfffqu77rpLO3bsUEZGRlnVBgAAAKCSsDUqVM2aNSXlDS27YsUKrVixosh2hmEoNzfXzq4AAAAA+DBbwSL/ydqGYVjzAAAAAKof28+xIEwAAAAAsBUsFi1aVFZ1AAAAAKjESh0sHnzwQUl5I0INGzZMkvTHH39o3759kqRu3bqVYXkAAAAAKoNSB4vFixfLMAzFxsYqLi5OkrR8+XI99dRT3KQNAAAAVFO277HIx70WAIALMfz8pKAakmFrtHMAgA8qs2ABAMD51AgJkV9ouE76NZbSM6WMHG+XVKwawcGqGRri7TIAoFIhWAAAKoTD4VBmdo5Wrl4nZ7Yp+fvmr6CI8DDd2TeOYAEApeSbP9UBAFWWMyVFSVm+GywAABfnon+qf//991q6dKk1nS9/2bmGDh16sbsCAAAA4OMuOlgsX75cy5cv91hmmqZGjBhRZHuCBQAAAFB12eqHzh8JyjAMGYbhsSx/uWma1joAAAAAVdNFBYtzh5YtbqhZhqAFAAAAqodSB4uNGzeWRx0AAAAAKrFSB4vu3buXRx0AAAAAKjEefQoAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGy7qCdvAwBw0Qwj77+uXO/WUZDhJ/nxXRsA2EGwAABUMD/JzJHSUySXy9vFSP7+Us1I0YkPAPYQLAAA3uFySW4f6rUAANhCsAAqg+xMKSfrwu0MP8ntyrvEpDwvMzHN8ts2AAColAgWQGWQkyXt3SZlpZ+/nSNUqtNcSkuWnEnlU0tAkBQSVj7bBgAAlRbBAqgsstKljDMXbud2511eUl6XmJj+5bNdAABQqXGnGgAAAADbCBYAAAAAbCNYAAAAALCt2gWLvn37yjAM67V3716P9b/99pvuv/9+RUdHy+FwqFmzZnr66aeVmprqpYoBAAAA31etbt5etmyZ1q5dW+z6n376Sd27d5fT6bSW7du3TzNnzlRCQoK++uorhYUxGg4AAABwrmrTY3Hq1CmNGTNGhmEoKCioyDYjRoywQsXIkSO1cuVKdevWTZK0c+dOTZs2rcLqBQAAACqTahMsxowZo1OnTumRRx5R/fr1C63/7rvvtGPHDklSy5YtNX/+fN1222364IMPZBiGJOntt99WTk5OhdYNAAAAVAbVIlisW7dOy5YtU4MGDTRz5swi22zevNma7tSpkxUm6tevr5iYGElScnKydu/eXe71AgAAAJVNlQ8WZ86c0ahRoyRJc+fOVURERJHtDhw4YE1HR0d7rKtbt641vX///iLfn5WVpdTUVI8XAAAAUF1U+WAxadIkHTx4UIMHD9aAAQOKbZeenm5Nn3sPRsH5gu0KmjFjhiIiIqxXo0aNbFYOAAAAVB5VOljs3btXb7zxhiIjI/X666+ft21oaKg1nZWV5bEuOzu7yHYFTZgwQU6n03odPnzYRuUAAABA5VKlh5s9duyY3G63kpOTVa9evSLbtGzZUm3atNHQoUOtZcePHy+0nXxNmzYtcjsOh0MOh6MMqgYAAAAqnyodLEqjS5cu1vTWrVtlmqYMw9CRI0d06NAhSVJkZKRat27trRJRnRl+kqPo3jIPjlDJzyj/egAAAM5RpYPF5Zdfrtdee63Q8mnTpik5OVlS3iVMrVu31rXXXqt27dppx44d+vXXX/Xoo4+qX79+mjVrlkzTlCQ99NBDCgwMrNBjgO84k35WGZmZ3tm52yXVaS653edt5hcQIFeAIy+IAAAAVKAqHSwuvfRSjRkzptDy//3f/7WCxdChQ9WiRQtJ0sKFC9WjRw85nU4tWLBACxYssN7Ttm1bTZkypULqhm/KyMzUR2sS5ExNq/idu3KltGTJnXveZo2aNNGNN8cRLAAAQIWr0sGitNq2bavt27frueee0xdffKGUlBQ1bNhQgwcP1qRJkxQWFubtEuFlztQ0JSWnVPyOXbmSM+mCwaJWZGQFFQQAAOCpWgaLgs+sOFfz5s21bNmyiisGAAAAqAK4XgIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQHeLgDwSdmZUk7WX/OGn+R2Sa7cvFdFM82K3ycAAEApECyAouRkSXu3SVnpefOOUKlOcyktWXImVWwtAUFSSFjF7hMAAKCUCBZAcbLSpYwzf8273ZI7N+9VkUz/it0fAADAReAeCwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhW5YPFjh079Mwzz6hz585q2LChgoKCdMkll6h///76+uuvC7X/7bffdP/99ys6OloOh0PNmjXT008/rdTUVC9UDwAAAFQOAd4uoLy9+eabevPNNz2WnTp1SqtXr9batWv14YcfatCgQZKkn376Sd27d5fT6bTa7tu3TzNnzlRCQoK++uorhYWFVWj9AAAAQGVQ5XssJKlevXqaNGmSPvvsM7333nu68sorJUlut1tjx4612o0YMcIKFSNHjtTKlSvVrVs3SdLOnTs1bdq0ii8eAFC+/AxJhuTK/evldkln06R0p/de2Zne/mQAoFSqfI/FkCFDNHv2bIWEhFjLWrVqpbZt20qSDh48qBMnTujAgQPasWOHJKlly5aaP3++DMNQx44d1bBhQ5mmqbffflvTp09XYGCgNw4FAFAeDD/JdEvpKZLLJQWYeaHi0I9SVrp3anKESi06SUHB3tk/AFyEKh8sunTpUmhZ8+bNPeZDQkK0efNma75Tp04yDEOSVL9+fcXExGj//v1KTk7W7t27rVACAKhCXC7Jnft/L3deqMg44+2qAKDSqBaXQp1rxYoV1nTXrl1Vs2ZNHThwwFoWHR3t0b5u3brW9P79+4vcZlZWllJTUz1eAAAAQHVR7YLFDz/8oL/97W+SJIfDoddee02SlJ7+V3d3UFCQx3sKzhdsV9CMGTMUERFhvRo1alTWpQMAAAA+q1oFi82bN6tnz55yOp0KCAjQ+++/r/bt20uSQkNDrXZZWVke78vOzramC7YraMKECXI6ndbr8OHD5XAEAAAAgG+q8vdY5EtISNDtt9+us2fPyuFwaPny5RowYIC1PiYmxpo+fvy4x3uPHTtmTTdt2rTI7TscDjkcjrItGgAAAKgkqkWPxSeffKL+/fvr7NmzCg0N1Zo1azxCheR5k/fWrVtlmqYk6ciRIzp06JAkKTIyUq1bt664wgEAAIBKosr3WHz44Ye699575XK5ZBiGpk6dKofD4TEKVMeOHXXttdeqXbt22rFjh3799Vc9+uij6tevn2bNmmWFjIceeoihZgEAAIAiVPlgsWbNGrlcLkmSaZp66qmnCrXZv3+/YmJitHDhQvXo0UNOp1MLFizQggULrDZt27bVlClTKqxuAAAAoDKp8sGiNNq2bavt27frueee0xdffKGUlBQ1bNhQgwcP1qRJkxQWFubtEgEAFcDw88t7SJ23OELzHtwHAJVIlQ8Wixcv1uLFi0vcvnnz5lq2bFn5FQQA8Gk1QkLkFxquk2qe96A8b/Dzk9IzpYyc8zarERysmqEhFVQUAJxflQ8WAACUhsPhUGZ2jlbGr5Pz9CnvFOEXIIVFSv7F/5qOCA/TnX3jCBYAfAbBAgCAIjhTUpSUlOSdnfsFSLnGeYMFAPgaLuAEAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAtgV4uwDAJxl+kiP0r3lHqORneK8eAAAAH0ewgNedST+rjMxMb5fhye2S6jSX3G5Jkl9AgFwBjrzAAQAAgEIIFvC6jMxMfbQmQc7UNG+X8hdXrpSWLLlzJUmNmjTRjTfHESwAAACKQbCAT3CmpikpOcXbZfzFlSs5k6xgUSsy0ssFAQAA+Da+fgUAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbo0IBAOBr/AxJRt4IdcVx5eY9c+dsmmS6y7+mQIcUFFz++wFQaREsAADwNYZfXlhIT5FcrqLbBJh5oeLQj1JWevnW4wiVWnQiWAA4L4IFAAC+yuWynqdTiDtXRkXWwgNCAVwAwQIAgEqoRkiI/ELDdVLNJXc5Xwrl5yelZ0oZORf19hrBwaoZGlLGRQHwNQQLAAAqIYfDoczsHK2MXyfn6VPluzO/ACksUvIv/Z8NEeFhurNvHMECqAYIFgAAVGLOlBQlJSWV7078AqRc46KCBYDqgwsmAQAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYxiM04RvcbsmV6+0q/mKa3q4AAACgUiFYwDeYbulMsuRyebsSKSBICgnzdhUAAACVCsECvsPlktw+0Gth+nu7AgAAgEqHeywAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAFCuDMPwdgkAKgAPyAMAAOWmRnCw/Pz8dDLptLdLuaAawcGqGRri7TKASotgAQAAyo0jKFCZWVla+fmXcqamebucYkWEh+nOvnEEC8AGggUAACh3ztQ0JSWneLsMAOWIeywAAAAA2EaPBQAAqHzcbsl0l932XLmS2yWdTbu47QY6pKDgsqsHqIQIFgAAoPIx3dKZZMnlKpvtBZh5oeLQj1JWeune6wiVWnQiWKDaI1gAAIDKyeWS3Lllsy13bl4vSFa6lHGmbLYJVDPcYwEAAADANnosqrAz6WeVkZlZeIXbLcms8HqK4ufnJ5fL7SvlAACK4mdIMvLuQygttyvvZ7wr9+LeXxyTXxyAryFYFCErK0uzZs3Su+++q3379ik0NFRdu3bVlClTdM0113i7vBLLyMzUR2sSCo8b7sqVzjolVxne9HaRGjVurBtvvkkkCwDwYYZf3j0N6Smlv6chPUIyXXm/d5ynyqaegCApJKxstgWgzBAszpGbm6u+fftqw4YN1rKsrCytXLlS69at05o1a9SrVy8vVlg6RY4b7srN++FeVtel2lArgl8MAFBpXMw9DVaPhbvsfu+Y/mWzHQBlinsszjF37lwrVMTGxmrFihWaPHmypLyAMXz4cGVlZXmzRAAAUA4MP7+8EZ5q1CzdyxGa16sDVHP0WJxj/vz51vSCBQvUqVMnDRo0SNu3b9fnn3+uP/74Q6tXr9Ydd9zhxSoBAEBZqhESIr/QcJ1U8/+7F7EU/Pyk9EwpI6d8iivAMAwFBgQoO6cE+/LyPZU1HA7V9NdfNfjosz6KvSfVx9QIDlbN0BBvl3FeBIsCTp8+rT179kiSAgMD1bFjR2td586d9fnnn0uSvv76a4IFAABViMPhUGZ2jlbGr5PzdCnvBfELkMIiJf/y/7OqUYP6uvGGa7Xy8y8L30N5Li/eUxlRq5bu7H+Lap76b94Qvj78rI9i70n1IRHhYbqzbxzBojI5cOCANV27dm35+/91DWfdunWt6f379xd6b1ZWlsclUk6nU5KUmppaDpWWTFpaqoIC/RUa7PBc4faXzDCfuHnbPyhYaWlpCgoKVGi4b9SkgEAp2CHpr3r8g4KVdiZNQSE1FBoW4fV6ilMhdZainuKUeZ1lUFNRLrrOcqqnOBess4LrKY5VZ3CwQuXn9Xos53w+Xv33XkxNRanQOm38P1QudZbD/9P5dWZkZykzu5T3gvi7pcyMvIBRzs6ePau0tDRlZJxVZkbG+Ru7c6XMTK/8OwvKyNCZ9HQ5st1SjiTDLaWdkVxGhddyIWlpqSX7PL0oKNBfaWmpcgRW/J/u+X/LmiUYiY1gUUB6+l9P2gwKCvJYV3C+YLt8M2bM0PPPP19oeaNGjcqwQgAAgMph3FPerqBqGefl/aelpSki4vxfDhAsCggNDbWmz71BOzs7u8h2+SZMmKCxY8da8263W6dPn1bt2rVlGL6Xzi9GamqqGjVqpMOHDys8PNzb5UCcE1/FefFNnBffwznxTZwX3+PNc2KaptLS0tSgQYMLtiVYFBATE2NNJyUlKTc3VwEBeR/RsWPHrHVNmzYt9F6HwyGHw/OSo1q1apVLnd4WHh7ODxofwznxTZwX38R58T2cE9/EefE93jonF+qpyMfYaAVERUWpZcuWkvKeZ7F9+3Zr3datW63prl27VnhtAAAAgC8jWJxj1KhR1vQjjzyijz/+WJMnT1ZCQoIk6dJLL1W/fv28VR4AAADgk7gU6hyjR4/WqlWrtGHDBu3evdtjWFmHw6HFixcXuuSpunA4HJo6dWq1PX5fxDnxTZwX38R58T2cE9/EefE9leWcGGZJxo6qZrKysjRr1iy988472r9/v0JDQ9WlSxdNnTpV11xzjbfLAwAAAHwOwQIAAACAbdxjAQAAAMA2ggUAAAAA2wgWAAAAAGwjWKBIffv2lWEY1mvv3r0e63/77Tfdf//9io6OlsPhULNmzfT0008rNTXVSxVXXQcPHtSoUaPUtGlTORwO1a5dW9dee61mzJhRqO0PP/ygAQMGqHbt2goODlarVq00Y8YMjyfHw75t27Zp0KBBatCggQIDAxUSEqKrrrpKzz77rNLS0gq157yUndOnT2vChAnq3r27QkJCrJ9Rw4cPL7J9aT77rKwsTZ8+Xa1atVJwcLBq166tgQMH6scffyzno6r8SnpesrOz9eabb+quu+5SixYtFB4erho1aqhVq1aaMmWK0tPTC23b7XZr3rx5ateunUJCQhQREaGbbrpJGzZsqKCjq5xK+28l37Zt2+Tv72+1v+eeewq14ZxcvNKeF9M0tXTpUnXr1k21atVSjRo11KRJE911113atWuXR1uf+BlmAud49913TUkerz179ljrd+7caUZERBRqI8ls27atmZqa6sXqq5bNmzeb4eHhRX7WzZo182j7+eefm0FBQUW2jYuLM3Nzc710FFXLl19+aQYEBBT5OUsyO3XqZLrdbqs956Vs7dixo8jPctiwYYXaluazz8nJMXv16lVkW4fDYX7xxRcVeJSVT0nPy59//lnsvx1JZseOHc2srCyP9wwbNqzItoZhmEuWLKnAo6xcSvNvJV9WVpbZunVrj/Z33313oXack4tXmvOSm5tr3nXXXcX+e3nnnXestr7yM4weC3g4deqUxowZI8MwFBQUVGSbESNGyOl0SpJGjhyplStXqlu3bpKknTt3atq0aRVWb1WWkpKiwYMHKzU1Vf7+/ho1apQ++eQTrVu3TnPmzFHfvn2tthkZGRoxYoT1LezkyZO1YsUKxcbGSpISEhI0f/58rxxHVfP6668rNzdXktSzZ0+tW7dOc+fOVWBgoKS8b/vyvx3ivJS9oKAgdevWTc8884wefPDBYtuV9rOfO3eu9W1rbGysVqxYocmTJ0vK+xZw+PDhysrKKq/DqvRKel4kyTAM9enTR4sXL9bnn3+ucePGWeu2b9+uZcuWWfOrVq3SkiVLJEkNGjTQBx98oNdee00BAQEyTVOPP/64jh8/Xj4HVcmV5pzkmzFjhnbv3q3g4OBi23BO7CnNeXn11Vf173//W5J05ZVXav78+Vq/fr3+/e9/68knn1T9+vWttj7zM6xC4gsqjfvvv9+UZI4cOdJs0qRJoR6Lb7/91lrWsmVL65vZo0ePmoZhmJLMyMhIMzs725uHUSXMnDnT+qxfeOGF87Zdvny51bZ3797W8q1bt1rLY2Njy7vkaqFnz57WZ7p69WpreYcOHazl27ZtM02T81Le5s2bV+y3faX97Fu2bGkt37p1q7W8d+/e1vKPPvqo3I+pKjjfeUlNTTW3bNlS6D0DBw603vPYY49Zy/v06WMtf//9963ljz76qLX81VdfLbdjqSrOd07y7d692wwKCjJr1KhhTp48udgeC85J2TnfecnIyDCjoqJMSWZ0dLR56tSp827LV36G0WMBy7p167Rs2TI1aNBAM2fOLLLN5s2brelOnTrJMAxJUv369RUTEyNJSk5O1u7du8u93qouPj7emna73brqqqusaysnTJigzMxMa33B89K5c2drukOHDtY36bt27VJycnIFVF619ejRw5qePXu2EhISNG/ePP3000+SpFatWlkP0uS8eE9pPvvTp09rz549kqTAwEB17NixyPd+/fXX5V12lRcWFqbrr7++0PLmzZtb06GhoZIk0zT1zTffWMsLngvOS9lyu916+OGHlZ2drWnTpqlZs2ZFtuOcVJwtW7bo9OnTkqSrr75ajz/+uKKjoxUaGqqePXt6nAdf+hlGsIAk6cyZMxo1apSkvO60iIiIItsdOHDAmo6OjvZYV7duXWt6//79ZV9kNfPLL79Y01OnTtWuXbuUmZmpQ4cO6aWXXtKAAQNk/t/zLYs7LwEBAYqKirLmC7bDxXnqqaf00EMPyd/fX19++aV69+6t0aNHKycnR0OHDtXGjRutP1w5L95Tms++YNvatWvL39/fmufnWvnLycnx+CKlT58+kvK+pCo4IEjB88h5KVtz5szR1q1b1b59e/3jH/8oth3npOIU/Btg/fr1Wr58uU6cOKGzZ89q48aNuvHGG7Vx40ZJ8qmfYQQLSJImTZqkgwcPavDgwRowYECx7QqO2HHuPRgF54sa2QOlk5KSYk1HRkZq6dKlWrp0qSIjIyXlXSO+atUqSZyXihQUFKQrr7xStWrVKrQuISFB3377rTXPefGe0nz2nCfvyf+mPH/kwTvuuEM9e/aUVPjzLnguOC9l59ChQ5o4caICAgL09ttve/xRei7OScUp+DeAJN17771au3at7r33Xkl5gXzs2LGSfOt3DcEC2rt3r9544w1FRkbq9ddfP2/b/C5qSYVuAio4fGPBdrg4DofDmn7sscf0wAMP6IEHHrB6liTpiy++kMR5qUjPP/+8nnrqKSUlJemJJ55Qamqqdu7cqejoaB07dkx33nmn9e0R58V7SvPZc568IycnR/fdd5+WLl0qSeratas1LRX+vAueG85L2XnmmWd05swZjR8/Xm3atDlvW85JxSn4N0BQUJAWLFigPn366K233rJ6xXfu3KmkpCSf+hlGsICOHTsmt9ut5ORk1atXzxpT+eDBg1abli1bqm3bttZ9FJIKjfpw7Ngxa7pp06blXndV17hxY2u6SZMmRU7nd0kXd15yc3OVlJRkzRdsh4uzYMECa3rSpEkKCwtTmzZtNGjQIEl5P8TXrl0rifPiTaX57Au2TUpKskb9kvi5Vl4yMzM1aNAgLV++XJLUq1cvffbZZwoJCbHaREZGKjw83JoveB45L2Xn6NGjkvJGhMr//T9ixAhr/fLly2UYhj799FPOSQUq+DdA7dq1rVBQs2ZN1a5d21qXmprqUz/DCBYolS5duljTW7duta7xP3LkiA4dOiQp75dB69atvVJfVXLDDTdY0/mf7bnTjRo1kuR5XrZs2WJNb9++3foBExsba11GhYt36tQpa/rMmTPWdMEH4+Uv57x4T2k++6ioKLVs2VJSXvDYvn271X7r1q3WdNeuXcu77GrhzJkz6tu3r1avXi1JGjBggNasWVPo21TDMDx+DhY8j5wX7+CcVJzrr7/eGiAnKSlJZ8+elZR3OVP+Td2BgYGqV6+eT/0MCyj3PcDnXX755XrttdcKLZ82bZo1Ws2ECRPUunVrXXvttWrXrp127NihX3/9VY8++qj69eunWbNmWSHjoYcesrrpcPEefvhhLVy4UKZpat68eWrRooUkeYy9f8cdd0iS+vfvrwYNGujo0aNKSEjQpEmT1L59e02ZMsVqW/ASKly81q1ba8eOHZLynuMybtw47du3Tx9++KHVpm3btpI4L+Xh7NmzVo9Q/nmQ8p5Q/9FHH0mSOnbsWOrPftSoUfr73/8uSXrkkUc0bdo0/fjjj0pISJAkXXrpperXr1+5H19lVdLzUrduXd18883atm2bpLzRbsaMGePxh1B0dLQ1StSoUaP02WefSZLGjRsnwzB07Ngxvf3225Lyvr0dMmRI+R9gJVTSc/I///M/GjhwoMd7v/vuO73//vuSpHbt2mno0KG66qqrJHFO7CrpeWnSpIl69+6tdevWKTs7WyNHjtSQIUP0zjvvWJc39enTRzVq1JDkQz/Dyn1AW1RaRT3HwjTznhrJk7crxvjx44t94ubTTz/t0ZYnPFeM+Ph409/fv9jz0qtXL568XY72799f7Gef/1q0aJFpmjx5uyKV9LyUpN254/nzlOeLU5p/K+datGhRsc+xME3OiR2lOS+///67Wa9evSLbREdHm/v377e26ys/w7gUCqXWtm1bbd++Xffdd5/q1q2roKAgNW3aVE899ZQ2bdqksLAwb5dYZcycOVNLlixRx44dFRISopCQEF133XV699139dJLL3m0jYuL05YtW9S/f39FRkbK4XCoZcuWmj59uuLj48870gdKrl+/ftq0aZMGDhyoevXqKSAgQCEhIWrTpo1efPFFrV692uq+ljgv3lSazz4gIEBr1qzRiy++qBYtWsjhcCgqKkq33XabtmzZol69ennxSKq3hQsXas6cOWrbtq2Cg4MVHh6uXr16af369Ro6dKi3y6uWOCcV47LLLtN3332nBx98UPXr11dAQIAaNGighx9+WD/88IPHvRW+8jPMMM3/u34FAAAAAC4SPRYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQCoMImJiTIMw+MVFBSkiIgIXXbZZbrpppv0/PPP6/Dhw+fdjtPp1OzZs9W7d281aNBADodDISEhat68ue677z59+OGHysnJsdr36NGj0H4Nw1BwcLAaN26sAQMG6JNPPinvwweAKs0wTdP0dhEAgOohMTFRN9544wXb+fv769lnn9Wzzz4rPz/P78A+/vhjPfzww0pOTj7vNjZu3KgePXpIygsWmzZtuuB+J06cqBdffPGC7QAAhQV4uwAAQPV19913q0OHDnI6nfrxxx/1+eefy+VyyeVy6bnnntOxY8c0b948q/3y5ct17733quB3YjfddJOuv/56ORwOHThwQF988YUOHDhQ7D4jIyM1ceJE5ebm6j//+Y+WLVum7OxsSdLLL7+scePGKSoqqtyOGQCqKoIFAMBrbrnlFg0fPtya37Nnj/r27av9+/dLkubPn68BAwbolltu0cmTJzVy5EgrVISEhOjTTz/VzTff7LFN0zS1YsUKXXLJJUXuMzw8XE8++aQ1X7duXb388suSJJfLpf/85z/q1KlTWR4mAFQL3GMBAPAZLVu21PLlyz2Wvfbaa5KkhQsXKjU11Vr+wgsvFAoVkmQYhu688061bt26RPts2LChx3ydOnVKWzYAQAQLAICP6dixo9q0aWPNf/XVV3K5XNqwYYO1zDAMj56Oi+FyubRnzx4tXLjQWnbNNdfo8ssvt7VdAKiuuBQKAOBzrrzySv3000+SpMzMTJ0+fVpHjhyx1tetW/ei74M4ePCgDMMotLxjx4768MMPL65gAAA9FgAA31PRAxbWrVtXL7zwgpo0aVKh+wWAqoRgAQDwOf/5z3+s6eDgYNWuXdvjXogTJ05ccLjZ4kRGRuqVV17R+PHjFR0dbW2vb9+++vLLL+0VDgDVGMECAOBTvv/+e+syKEnq3r27/Pz81KtXL2uZaZpasmTJRW0/f1SomTNnavPmzQoNDZWUd8/F6NGjlZuba+8AAKCaIlgAAHzGr7/+qnvuucdj2dixYyVJDz74oMLCwqzlkydPLrKHIX+42d27d19wf5dffrnH0LO//vqrli1bdrHlA0C1xs3bAACvWbdunU6dOqXU1FTt2LFD69at8+gxePzxxxUXFydJuuSSSzR//nwNGTJEpmkqPT1dN910k/WAvKCgIB08eFDr16/XgQMHtHHjxhLV8Pe//12zZs3SmTNnJEkvvfSSHnjggUJP/AYAnB/BAgDgNcuXLy/03ApJCggI0NSpUzVx4kSP5ffdd58CAgI0cuRIOZ1Omaap9evXa/369RddQ2RkpEaNGqVXX31VkrR371599NFHuuuuuy56mwBQHRlmRQ+9AQCothITE3XjjTd6LPP391dISIjq1Kmjyy67TN26ddNDDz1U6MF1BSUnJ2vhwoVat26dfv75ZyUnJ8vPz0+XXnqpbrjhBt11112Ki4tTQEDe92c9evTQpk2bJElNmjTRgQMHPLZ37NgxxcTEKCsrS5LUpk0b7dixo8hhaQEARSNYAAAAALCNC0gBAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2Pb/A4Gl2bQ7oh2mAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dcr_train5 = _calculate_dcr(data_train, syn5, meta_data)\n",
    "dcr_test5 = _calculate_dcr(data_test, syn5, meta_data)\n",
    "\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test5[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train5[\"DCR\"], bins=15, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "\n",
    "# Adding title and labels\n",
    "plt.title('TVAE', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f831ff76-2ce0-4922-b091-9b2e73d76c68",
   "metadata": {},
   "source": [
    "# BeGReaT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "7e059344-9bca-475a-9ab4-9a8a7c40560e",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_lst = []\n",
    "for i in range(5):\n",
    "    data_path = f\"gen/ATACH/100/BeGReaT/df_{i}.csv\"\n",
    "    data_temp = pd.read_csv(data_path)\n",
    "    data_lst.append(data_temp)\n",
    "syn6 = pd.concat(data_lst)\n",
    "syn6.reset_index(inplace=True, drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "6bf941aa-7fe6-4519-ac39-1f71114ed70c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABaZUlEQVR4nO3deXgUZb728buydchKCLIE2QYZZVFBCCK7okFkFUVHZVcQcWbkyLiACAIKjIh6xlFB3oGgojKCDDsGkQgIKrLouICiCSAIQshGSDpJd71/5KRMkwCBStKd5Pu5rr6seurpql+XRZK7q+opwzRNUwAAAABgg5+3CwAAAABQ+REsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLACgmjEMo8RXQECAIiMj1bJlSw0dOlTr168v91pSU1P1v//7vxo4cKCaNm2qiIgIq46rrrpKAwYM0N///nft27ev3GspS/Hx8efczxd6jRgxwtvlA8AlMUzTNL1dBACg4hiGUeq+I0eO1MKFC8u8BtM09cILL2jatGnKysoq1Xt++ukn/eEPfyjzWspDfHy8Ro4ceUnvHT58uOLj48u2IACoAAHeLgAA4F29e/dWSEiI8vLytHfvXh06dMhatmjRIg0ePFi9e/cus+2Zpql7771X7733nke7v7+/rrnmGl1++eXKzc3VwYMH9cMPP8jtdkuS9d/KoEmTJrrjjjuKtS9fvtxjvnDfFxUbG1uutQFAeeGMBQBUM2efsUhKSlKTJk0kSXl5eerSpYu++OILa/mECRP0wgsvlNn2n332WT399NMebffdd5/mzJmj+vXre7SfOnVKy5cv18svv6yVK1fqiiuuKLM6vOF8+x4AKjvusQAAWAIDA9WtWzePtuzs7BL7Zmdna968eerVq5fq1aunoKAgRUZGqn379po2bZpSUlKKvefEiROaPXu2R9vQoUP19ttvFwsVklSrVi2NHj1a//3vf4v9Ad6jRw+PexOSk5O1fPly9ejRQzVr1pRhGEpMTPR4z9atWzV8+HA1b95cYWFhCg4OVtOmTTV8+HDt3LmzxM/59ddf64knnlCvXr3UvHlzRUdHKzAwUOHh4brqqqs0fPhwbd26tcT3AkC1YgIAqhVJHq+kpCRrWW5urnn99dd7LF+0aFGxdXz33XfmH//4x2LrKvqqV6+euX37do/3LViwwKNPYGCg+euvv17S5+jevbvHuoYOHVqshs2bN5umaZp5eXnmyJEjz1uvYRjm008/XWw7c+bMOe/7Cl/PPPPMBWs+374HgMqOeywAoJobN26cQkJClJ+fr7179+rgwYPWsq5du+ree+/16J+amqq4uDj98ssvVtsVV1yhK6+8UsePH9eXX34pSTp27Jj69eunr7/+WjExMZKk7du3e6yrXbt2qlevXpl8jrfeesu6T6N+/fr69ttvrWWPPPKIFi1aZM2Hh4fr+uuvl5+fn7Zv367Tp0/LNE3NmDFDMTExGjt2bLH1X3HFFapbt66ioqLkdrt19OhRff3119a9H88884z69++vtm3blsnnAYBKx9vJBgBQsVSKb98lmc2aNTN/+umnYu+fPHmyR7/Zs2d7LH/nnXc8lv/5z3+2lt12220ey+6+++5i6+/cuXOJ9XTv3t2j39lnLGrWrGlu27bNWu52u02n02nu37/f9PPzs/p16NDBTE9Pt/odP37cbNiwobU8OjradDqd1vJDhw6Zv/32W4n7cs2aNR41PPHEExe17zljAaAq4YwFAKBEP/30k6655hqtXr1aN954o9W+YsUKj347duzQnXfeac27XC6P5atXr9Yrr7xSvsWq4Cbzzp07W/OGYSgoKEirVq3yGFEqNzdXo0aN8nivWWQck5SUFG3fvl09evSQJDVs2FAbNmzQW2+9pV27dunIkSM6c+ZMiaNUVbbnbQBAWSJYAEA1VzgykWmaOnLkiObMmaN//OMfkqSsrCwNGzZMBw4ckMPhsPoXtXLlyvOu//Dhw3K5XPL391fdunU9lhUd2rbQjTfeqHr16unEiRPasmVLqT9HYRA429n17t27V3v37j3vupKSkqz1PfLII9b+uJD09PRS9QOAqohRoQAAkgq+4b/88sv1v//7vx4jMP3yyy/67LPPLnm9brfbGlmqU6dOHst27dqlkydPerTNmDFDy5Yt07Rp0y5qO4X3cZSFwof2ffnll8VCRfPmzdW3b1/dcccdxZ7vYTKCO4BqjGABACgmMjLSY/7XX3+1pps2bWpNG4aho0ePyjTN877CwsIkSf379/d4IFxubq6mTJlSJjX7+ZX8K61ovZI0e/bsC9b75z//WZKKDSP70EMP6YcfftDq1au1bNmyYs/jAIDqjGABAPCQmJiob775xqOt6NmA/v37W9Omaerhhx9WRkZGsfV8/fXXevrppzVv3jyrrU6dOnrsscc8+r3++uv685//rLS0tDL6BJ769u3r8WC6uXPnavfu3cX6nTx5UvHx8R6jYOXl5Xn0KRqK0tPTNWnSpHKoGAAqJ568DQDVzNlPf+7du7dCQkKseyy++OILj0t6GjVqpAMHDigwMFBSwc3NrVu31rFjx6w+YWFhuu6661SzZk2lpaXpu+++sy5xmjp1qp555hmrr9vt1uDBg/XBBx941OFwONSuXTtddtllyszM1JdffukRWLp37+7xwLsePXrok08+sebP9xTrMWPGaMGCBR5t1157rRo1aiSn06nk5GQdOHBAbrdbjRs3VnJysiRpy5Yt6t69u8f7YmNjFR0drS+++EKpqake++rsGs/Gk7cBVGXcvA0A1dz69evPuaxWrVp67733rFAhSdHR0dq4caMGDRqkH3/8UZJ0+vTpc95oHRDg+avGz89P//73v/Xss89q1qxZcjqdkiSn01nsOReFDMPQVVdddVGfq6hXX31VTqdTb775ptX21Vdf6auvvjpvvd26ddOgQYM8QlDhE7r9/f01e/ZsPfHEE5dcFwBUJZyxAIBq5uxvzYsKDAxUVFSUrrzySvXq1UsPPvigateuXWLf7OxsLVmyRCtWrNDevXuVkpIit9utWrVq6YorrlDHjh112223qUePHue8/+H48eNatGiRNm/erG+//VYpKSlyuVwKCwtTw4YN1aJFC3Xt2lV9+/ZV48aNPd57MWcsCn366adauHChduzYocOHDys7O1uhoaFq1KiR2rRpo5tuukkDBw5UVFSU9Z78/Hy98MILio+P188//2w9XO+pp55SgwYNPO7h4IwFgOqMYAEAAADANm7eBgAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQHeLqCqcrvdOnr0qMLD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NC98Vsf7/8p9SFbW70kxKCjIY1nR+aL9Cs2aNUvTpk0r1t6wYcMyrBAAAFR1E7xdACrUhMe9XUHpZGZmKjIy8rx9CBZFhIb+ftOZ86wh1HJzc0vsV2jixIl69NFHrXm3261Tp04pOjq60t04lJGRoYYNG+rw4cOKiIjwdjnVCvvee9j33sO+9y72v/ew772HfV96pmkqMzNTMTExF+xLsCiiSZMm1nRKSory8/MVEFCwi44dO2Yta9q0abH3OhyOYiNF1axZs1zqrCgRERH8Y/MS9r33sO+9h33vXex/72Hfew/7vnQudKaikG+N/+ZltWrVUosWLSQVPM9i586d1rIdO3ZY0127dq3w2gAAAABfRrA4y9ixY63p0aNH64MPPtDkyZOVkJAgSbr88svVt29fb5UHAAAA+CQuhTrLuHHjtGrVKm3atEnffvutx7CyDodD8fHxVf7heA6HQ1OnTq3yn9MXse+9h33vPex772L/ew/73nvY9+XDMEszdlQ143Q6NXfuXL311ltKSkpSaGiounTpoqlTp+q6667zdnkAAACAzyFYAAAAALCNeywAAAAA2EawAAAAAGAbwQIAAACAbQSLaiYxMVGGYZzz9cwzz3j037VrlwYMGKDo6GgFBwerZcuWmjVrlseTyFE6TZo0Oe++NwxDiYmJkqQRI0act19ycrJXP4svO3XqlCZOnKju3bsrJCTE2mcjRowosf/FHONOp1MzZ85Uy5YtFRwcrOjoaA0cOFC7d+8u509VOZR23+fm5mr+/Pm66667dNVVVykiIkI1atRQy5YtNWXKFGVlZXn0T05OPu+/h3P9v61OLua479Gjx3n359k47s+vtPs+Pj7+gr8DevToYfXnuL+wPXv26Mknn1SnTp3UoEEDBQUF6bLLLlO/fv20devWYv0PHDig++67T3Xr1pXD4VCzZs30xBNPKCMjo1hft9ut119/XW3btlVISIgiIyN18803a9OmTRXx0SovE9XK5s2bTUnnfE2dOtXq++GHH5pBQUEl9ouLizPz8/O990EqocaNG59330syt23bZpqmaQ4fPvy8/ZKSkrz7YXzYnj17Stxnw4cPL9b3Yo7xvLw8s2fPniX2dTgc5kcffVSBn9I3lXbf//rrr+c9vmNjY02n02n1T0pKOm//kv7fVjcXc9x37979vPuzKI77Cyvtvl+0aNEFfwfcfPPNVn+O+wt78MEHz7l//Pz8zOXLl1t99+7da0ZGRpbYt02bNmZGRobHus/1e9gwDHPx4sUV/VErDZ5jUY394x//UNu2bT3aGjVqJEnKzs7WyJEjrW9tJ0+erLZt22rq1Kn65ptvlJCQoHnz5unhhx+u8Lorq2XLliknJ8ejbd++fRo9erQkqX79+urQoYPH8nr16un9998vtq769euXX6GVXFBQkLp166ZOnTrpt99+08KFC0vsd7HH+GuvvWZ9U9W6dWtNmzZNe/bs0bPPPiun06kRI0bowIED1XpM9NLue0kyDEO33nqr7r77btWvX18JCQmaO3euJGnnzp1asmSJRo4cWex9kyZNUu/evT3a6tatW7YfpBK6mH1fqE2bNnrllVfO24fj/sJKu+9vu+22Er9Ff/zxx7Vjxw5J0sCBA0t8L8f9udWrV0/333+/unTpotTUVE2bNk379++X2+3Wo48+qkGDBkmSRo4cqfT0dEnSmDFj1KdPH82dO1dbtmzR3r17NX36dM2ZM0eStGrVKi1evFiSFBMToxdffFG//vqrHnvsMeXn5+vhhx9Wr169+H9QEm8nG1SsomcsNm/efM5+S5cutfr16tXLat+xY4fV3rp16wqouGr785//XOLZosJvSho3buy12qqC119//Zzf7l3sMd6iRQurfceOHVZ7r169rPZly5aV+2eqLM637zMyMszt27cXe8/AgQOt9zz00ENWe9FvbhctWlTOlVd+59v3pvn7GYvu3btfcF0c9xfnQvv+bL/++qsZGBhoSjLDw8M9vjXnuL+wrVu3mllZWR5te/fu9TjDcPz4cfPzzz+35lu0aGG63W7TNE3z6NGjpmEYpiQzKirKzM3NNU3TNHv37m31f/fdd611Fz1D8sILL1TcB61EuMeiGrvvvvvkcDgUFRWluLg4ffTRR9aybdu2WdOdOnWyptu3b6/AwEBJ0jfffKPU1NSKK7iKycrK0ptvvilJCggI0JgxY4r1+fXXX1W/fn0FBQWpcePGeuihh/Trr79WdKlV0sUc46dOndL3338vSQoMDFRsbGyJ7y3p20gUFx4erhtuuKFYe/Pmza3p0NDQEt87ceJE1ahRQxEREerSpYv+/e9/l1udVd2uXbtUu3ZtORwONW/eXI8//rjHteYc9+VvwYIFysvLkyQNHTpU4eHhJfbjuC9Zly5dFBIS4tFW9OeIJIWEhHj8vO/YsaN1L1H9+vXVpEkTSVJqaqq+/fZbmaapTz/91Opf9FjnuL8wgkU1dvToUeXm5iotLU0bN25UXFyc4uPjJcnj5uCip/oCAgJUq1Yta56biC/d22+/bf0Sv/322xUTE1OsT25uro4dO6a8vDwdOnRI8+bNU2xsrI4ePVrR5VY5F3OMF+0bHR0tf39/a75OnTrWdFJSUvkUWw3k5eVp9erV1vzZl30UOnbsmHJycpSZmalPP/1Ud999t6ZNm1ZRZVYpp0+fVkpKinJzc3XgwAHNmTNHXbp00enTpyWJ476cuVwuvfHGG9b8uHHjztmX4770li9fbk137dpVYWFh5/x5LxU/llNTUz0CdtH+HPcXRrCoZvz9/XXjjTfqlVde0fr16/Xuu++qffv2kiTTNDV+/HhlZWV5jMoSFBTksY6i82eP3oLSe+2116zps+9VqVmzph544AG9/fbbSkhI0N///ndFRERIko4cOaIpU6ZUaK1V0cUc4/x7KF9ut1sPPPCA9u3bJ0m64447dNNNN1nLDcNQhw4d9MILL2jNmjVavny54uLirOUzZszgS46LUK9ePY0fP17vvfeeNmzYoMmTJ1vH8X//+1+9/PLLki7u3wgu3sqVK/XLL79IKhipq1WrVh7LOe4v3q5du/SXv/xFkuRwOPTSSy9JuvSf92cv57i/MG7erma6du2qjz/+2KPt1ltvVZMmTZSenq709HRt377d4zIEp9Pp0b/oMJznulwB57dt2zZ9/fXXkqRWrVqpe/fuHssLf7EXuuWWW3TZZZdp1KhRkqT169dXSJ1V2cUc46ZplrovLk5eXp6GDh2qpUuXSir4GVV4iWChxo0b6/PPP/do69evn1q2bKkDBw7I5XJp48aN1kAIOL/33nvPY75Xr17y8/PT9OnTJRX8fJk8eTK/B8rZ+b5ckjjuL9a2bdvUp08fZWRkKCAgQO+++67atWsn6eJ+3p99PDudTgUHB5fYF8VxxgKqWbOmxzWJJ06csK45lKTjx49b0/n5+UpJSbHmi/ZD6V3oF0pJio4YdeLEiTKvqbq5mGO8aN+UlBTl5+db88eOHbOmmzZtWj7FVlE5OTkaNGiQFSp69uyp9evXF7tmuiSBgYFq06aNNc+/CXtK+vnCcV9+fvjhB+tLvpiYmHOOBnU2jvuSJSQkqFevXsrIyJDD4dCyZct0++23W8vP9fNeKn4sR0VFWVcInN2f4/7CCBbVzK5du4q1paWl6YcffrDm69atqy5duljz27dvt6Z37txp/XJp3bq1oqKiyrHaqum3336zrgGNiIjQ0KFDPZZnZGToxx9/LPa+ot9cMcSdfRdzjNeqVUstWrSQVBA8du7cafUvHCZSKvi2HaVz+vRp9enTR2vWrJEkDRgwQGvXri3xW8C9e/fK5XJ5tOXl5WnPnj3WPP8mSufo0aMlDgBR0s8Xjvvy89prr1lnQh988EEFBBS/gITjvnRWrFihfv366cyZMwoNDdXatWs1YMAAjz5Ff97v2LHD2vdHjhzRoUOHJElRUVFq1aqVDMNQ586drf5Ffz9w3F8Yl0JVMxMmTFBaWpqGDRuma665RidPntTcuXOtG5Vq165tjXoQExOjo0ePKiEhQU899ZTatWvncW3/2LFjvfIZKrsFCxZYp1OHDRumsLAwj+WnTp1Sq1atNGjQIPXr109169bV7t279dxzz1l9zv6hid+dOXNG69atkySPX8AHDx7UsmXLJEmxsbHq16/fRR3jY8eO1SOPPCJJGj16tKZPn67du3crISFBknT55Zerb9++5f75fFlp932dOnV0yy236LPPPpMkXXPNNRo/frzHH65169a1zqS+/PLL2rZtm0aOHKn27dvrzJkzmjdvnn766SdJBddS33rrrRXyGX1Vafd9UlKS+vTpo3vuuUe9evVSZGSktm7dqueff956T9GfLxz3F1bafd+4cWOrf+FAKYGBgSWOCChx3JfG+++/r3vuuUcul0uGYWjq1KlyOBweo0DFxsaqQ4cOatu2rfbs2aP9+/frwQcfVN++fTV37lwrZNx///3WiIBjx461LjmeMGGCDMPQsWPH9K9//UuSFBYWpiFDhlTwp60kvDnWLSre+Z64GhgYaK5YscLqy5O3y15+fr7ZqFEjaz9+9913xfpc6GmrV155pXny5EkvVF85XGj/qciY8Dx5u2yVdt+Xpl/RZwCc70n0hmGYr7zyivc+tI8o7b4v+iyjkl5dunQxs7OzrfVy3F/YxfzMMU3TfOONN6z2u++++5zr5bi/sPPto8JXUlKSaZoFT0jnydvlj2BRzXzxxRfm+PHjzWuuucaMjo42AwICzJiYGPNPf/qTuXv37mL9v/zyS7Nfv35mVFSU6XA4zBYtWpgzZ840nU6nF6qv/P7zn/9YP5xuuummEvvk5uaab731ljlo0CCzWbNmZkhIiFmjRg2zdevW5tNPP13shx88Xewv+Ys5xnNycsznnnvOvOqqq0yHw2HWqlXL7N+/v7lr164K/IS+q7yCxXfffWdOmjTJbN++vVmnTh0zICDAvOyyy8z+/fubH3/8sfc+sA8p7b7PzMw058+fb/bu3dts0qSJGRwcbIaGhprt2rUzX3jhBY77S3CxP3Patm1rtW/ZsuWc6+W4v7CLCRamaZo//PCDee+995p16tQxg4KCzKZNm5qPP/64mZ6eXmzdLpfLfPXVV802bdqYwcHBZkREhNmzZ0/C9AUYpllkuBMAAAAAuATcvA0AAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAAAAAGwjWAAAAACwjWABAAAAwDaCBQAAAADbCBYAAAAAbCNYAAAAALCNYAEAAADANoIFAAAAANsIFgAAAABsI1gAAAAAsI1gAQAAAMA2ggUAAAAA2wgWAIAKk5iYKMMwPF5BQUGKjIzUH/7wB918882aNm2aDh8+fN71pKen68UXX1SvXr0UExMjh8OhkJAQNW/eXPfee6/ef/995eXlWf179OhRbLuGYSg4OFiNGjXSgAEDtGLFivL++ABQpRmmaZreLgIAUD0kJibqxhtvvGA/f39/Pf3003r66afl5+f5HdgHH3ygBx54QKmpqeddx+bNm9WjRw9JBcHik08+ueB2J02apOeee+6C/QAAxQV4uwAAQPV19913q3379kpPT9fu3bv14YcfyuVyyeVy6ZlnntGxY8f0+uuvW/2XLl2qe+65R0W/E7v55pt1ww03yOFwKDk5WR999JGSk5PPuc2oqChNmjRJ+fn5+uGHH7RkyRLl5uZKkv7+979rwoQJqlWrVrl9ZgCoqggWAACvufXWWzVixAhr/vvvv1efPn2UlJQkSZo3b54GDBigW2+9VSdOnNCYMWOsUBESEqL//Oc/uuWWWzzWaZqmli9frssuu6zEbUZEROhvf/ubNV+nTh39/e9/lyS5XC798MMP6tixY1l+TACoFrjHAgDgM1q0aKGlS5d6tL300kuSpIULFyojI8NqnzFjRrFQIUmGYejOO+9Uq1atSrXNBg0aeMzXrl37YssGAIhgAQDwMbGxsbr22mut+S1btsjlcmnTpk1Wm2EYHmc6LoXL5dL333+vhQsXWm3XXXedrrjiClvrBYDqikuhAAA+58orr9RXX30lScrJydGpU6d05MgRa3mdOnUu+T6IgwcPyjCMYu2xsbF6//33L61gAABnLAAAvqeiByysU6eOZsyYocaNG1fodgGgKiFYAAB8zg8//GBNBwcHKzo62uNeiN9+++2Cw82eS1RUlObMmaPHHntMdevWtdbXp08fffzxx/YKB4BqjGABAPApX375pXUZlCR1795dfn5+6tmzp9VmmqYWL158SesvHBXq+eef17Zt2xQaGiqp4J6LcePGKT8/394HAIBqimABAPAZ+/fv15/+9CePtkcffVSSNGrUKIWHh1vtkydPLvEMQ+Fws99+++0Ft3fFFVd4DD27f/9+LVmy5FLLB4BqjZu3AQBes2HDBp08eVIZGRnas2ePNmzY4HHG4OGHH1ZcXJwk6bLLLtO8efM0ZMgQmaaprKws3XzzzdYD8oKCgnTw4EFt3LhRycnJ2rx5c6lqeOSRRzR37lydPn1akjR79mwNHTq02BO/AQDnR7AAAHjN0qVLiz23QpICAgI0depUTZo0yaP93nvvVUBAgMaMGaP09HSZpqmNGzdq48aNl1xDVFSUxo4dqxdeeEGStG/fPi1btkx33XXXJa8TAKojw6zooTcAANVWYmKibrzxRo82f39/hYSEqHbt2vrDH/6gbt266f777y/24LqiUlNTtXDhQm3YsEH//e9/lZqaKj8/P11++eXq3Lmz7rrrLsXFxSkgoOD7sx49euiTTz6RJDVu3FjJycke6zt27JiaNGkip9MpSbr22mu1Z8+eEoelBQCUjGABAAAAwDYuIAUAAABgG8ECAAAAgG0ECwAAAAC2ESwAAAAA2EawAAAAAGAbwQIAAACAbQQLAAAAALYRLAAAAADYRrAAAAAAYBvBAgAAAIBtBAsAAAAAthEsAAAAANhGsAAAAABg2/8HK/CI9dEXJOEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dcr_train6 = _calculate_dcr(data_train, syn6, meta_data)\n",
    "dcr_test6 = _calculate_dcr(data_test, syn6, meta_data)\n",
    "\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.hist(dcr_test6[\"DCR\"], bins=15, color='#FFA07A', edgecolor='white', alpha=0.7, label = \"Held out\")\n",
    "plt.hist(dcr_train6[\"DCR\"], bins=15, color='#394D59', edgecolor='white', alpha=0.7, label= \"Train\")  # Adjust bins and color as needed\n",
    "\n",
    "# Adding title and labels\n",
    "plt.title('BeGreaT', fontsize=16, weight='bold', pad=20)\n",
    "plt.xlabel('DCR', fontsize=14, weight='bold', labelpad=10)\n",
    "plt.ylabel('Frequency', fontsize=14, weight='bold', labelpad=10)\n",
    "\n",
    "# Customizing ticks\n",
    "plt.xticks(fontsize=12, weight='bold')\n",
    "plt.yticks(fontsize=12, weight='bold')\n",
    "plt.legend(fontsize=12)\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "118f43b3-5cf8-45e1-8046-aa774fbabdd5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10",
   "language": "python",
   "name": "py3.10"
  },
  "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": 5
}
