{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.3.0+cu121\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import torch\n",
    "import warnings\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from constant import EXPS_PATH, DB_PATH\n",
    "from lib import load_json\n",
    "\n",
    "# disable warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# torch version\n",
    "print(torch.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'adult'\n",
    "methods = [\n",
    "    'codi',\n",
    "    'fair-smote',\n",
    "    'fair-tab-ddpm',\n",
    "    'fair-tab-gan',\n",
    "    # 'goggle',\n",
    "    'great',\n",
    "    'smote',\n",
    "    'stasy',\n",
    "    'tabddpm',\n",
    "    # 'tabsyn',\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_score(dataset, method, exp_dir=EXPS_PATH):\n",
    "    exp_dir = os.path.join(exp_dir, dataset, method)\n",
    "    \n",
    "    # if best exists use it otherwise use many-exps\n",
    "    best_exp_dir = os.path.join(exp_dir, 'best')\n",
    "    if os.path.exists(best_exp_dir):\n",
    "        exp_dir = best_exp_dir\n",
    "    else:\n",
    "        exp_dir = os.path.join(exp_dir, 'many-exps')\n",
    "    \n",
    "    score_file = os.path.join(exp_dir, 'metric.json')\n",
    "    score = load_json(score_file)\n",
    "    return score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'CatBoost': [0.8452744385802621, 0.008282790545036436]}"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "read_score(dataset, 'codi')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# read all scores\n",
    "scores = {}\n",
    "for method in methods:\n",
    "    scores[method] = read_score(dataset, method)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'codi': {'CatBoost': [0.8452744385802621, 0.008282790545036436]},\n",
       " 'fair-smote': {'CatBoost': [0.907525586183441, 0.0012483818714813146]},\n",
       " 'fair-tab-ddpm': {'CatBoost': [0.8918966734489052, 0.0009141151834793541]},\n",
       " 'fair-tab-gan': {'CatBoost': [0.8963132044906436, 0.0023986151127191363]},\n",
       " 'great': {'CatBoost': [0.9151733240945673, 0.0015614463640945347]},\n",
       " 'smote': {'CatBoost': [0.9240111484286359, 0.0003638549790596148]},\n",
       " 'stasy': {'CatBoost': [0.8890867670152236, 0.0038861689251143937]},\n",
       " 'tabddpm': {'CatBoost': [0.9053126278614677, 0.0011767087455055436]}}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test AUC')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHeCAYAAABzHrSYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB07klEQVR4nO3dd1iV5f8H8PcBZIg4EGQoCqKimBtE3APBEc7UxInbxBQylURxk1qODEfmSqW01K+VphKKudJcWc6cuMCJIMg8n98f/HjyCBoocIDzfl3XuS7O/dzPfe7ncMbn3FMlIgIiIiIiHaKn7QoQERERFTQGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOMdB2BQojtVqNu3fvwszMDCqVStvVISIiohwQEcTHx8PW1hZ6eq9v42EAlI27d+/Czs5O29UgIiKiN3Dr1i1UqlTptXkYAGXDzMwMQMYTWLp0aS3XhoiIiHIiLi4OdnZ2yvf462g9AAoNDcWCBQsQHR2NevXqYenSpWjcuHG2eVNTUxESEoL169fjzp07cHJywrx589ChQwclz/Tp0zFjxgyN85ycnHDx4sUc1ymz26t06dIMgIiIiIqYnAxf0eog6M2bNyMgIADBwcE4deoU6tWrBy8vL9y/fz/b/EFBQVi5ciWWLl2K8+fPY9SoUejevTtOnz6tka927dq4d++ecjt06FBBXA4REREVEVoNgBYuXIjhw4fD19cXzs7OWLFiBUqWLIk1a9Zkm3/Dhg345JNP0KlTJ1StWhWjR49Gp06d8Pnnn2vkMzAwgLW1tXKzsLAoiMshIiKiIkJrAVBKSgpOnjwJDw+PfyujpwcPDw8cPXo023OSk5NhbGyskWZiYpKlheeff/6Bra0tqlatin79+iEqKuq1dUlOTkZcXJzGjYiIiIovrQVADx8+RHp6OqysrDTSraysEB0dne05Xl5eWLhwIf755x+o1WqEh4dj27ZtuHfvnpLHzc0N69atw+7du7F8+XJcv34dLVq0QHx8/CvrEhISgjJlyig3zgAjIiIq3orUQohLlixB9erVUbNmTRgaGsLPzw++vr4ac/07duyIXr16oW7duvDy8sKuXbsQGxuLLVu2vLLcwMBAPH36VLndunWrIC6HiIiItERrAZCFhQX09fURExOjkR4TEwNr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sbFB165dISJQq9X5WUciIiKiPJWrafAmJiYYNGgQDhw4gL/++gu1a9eGlZUVmjVrBh8fH2zbti2/6klERESUZ954HaDq1atj7ty5uHXrFjZu3IjExET07ds3L+tGRERElC/eah0gANDT04O3tze8vb1x//79vKgTERERUb7Kk5WgM1WoUCEviyMiIiLKF3kaABEREREVBQyAiIiISOcwACIiIiKdk+sAqGrVqnj06FGW9NjYWFStWjVPKkVERESUn3IdAN24cQPp6elZ0pOTk3Hnzp08qRQRERFRfsrxNPgff/xR+XvPnj0oU6aMcj89PR0RERGwt7fP08oRERER5YccB0DdunUDAKhUKgwaNEjjWIkSJWBvb4/PP/88TytHRERElB9yHABl7vfl4OCAP/74AxYWFvlWKSIiIqL8lOuVoK9fv54lLTY2FmXLls2L+hARERHlu1wPgp43bx42b96s3O/VqxfMzc1RsWJF/Pnnn3laOSIiIqL8kOsAaMWKFbCzswMAhIeH49dff8Xu3bvRsWNHfPzxx3leQSIiIqK8lususOjoaCUA+vnnn9G7d294enrC3t4ebm5ueV5BIiIioryW6xagcuXK4datWwCA3bt3w8PDAwAgItmuD0RERERU2OS6BahHjx7w8fFB9erV8ejRI3Ts2BEAcPr0aVSrVi3PK0hERESU13IdAC1atAj29va4desW5s+fj1KlSgEA7t27hw8++CDPK0hERESU13IdAJUoUQITJkzIku7v758nFSIiIiLKb2+0G/yGDRvQvHlz2Nra4ubNmwCAxYsXY8eOHXlaOSIiIqL8kOsAaPny5QgICEDHjh0RGxurDHwuW7YsFi9enNf1IyIiIspzuQ6Ali5dilWrVmHKlCnQ19dX0l1cXPDXX3/laeWIiIiI8kOuA6Dr16+jQYMGWdKNjIyQkJCQJ5UiIiIiyk+5DoAcHBxw5syZLOm7d+9GrVq18qJORERERPkqx7PAZs6ciQkTJiAgIABjxoxBUlISRATHjx/Ht99+i5CQEHz99df5WVciIiKiPJHjAGjGjBkYNWoUhg0bBhMTEwQFBSExMRE+Pj6wtbXFkiVL8P777+dnXYmIiIjyRI4DIBFR/u7Xrx/69euHxMREPHv2DBUqVMiXyhERERHlh1wthKhSqTTulyxZEiVLlszTChERERHlt1wFQDVq1MgSBL3s8ePHb1UhIiIiovyWqwBoxowZKFOmTH7VhYiIiKhA5CoAev/99zneh4iIiIq8HK8D9F9dX0RERERFRY4DoBdngREREREVZTkOgNRqdb50f4WGhsLe3h7GxsZwc3PD8ePHX5t/8eLFcHJygomJCezs7ODv74+kpKS3KpOIiIh0S663wshLmzdvRkBAAIKDg3Hq1CnUq1cPXl5euH//frb5w8LCMHnyZAQHB+PChQtYvXo1Nm/ejE8++eSNyyQiIiLdo9UAaOHChRg+fDh8fX3h7OyMFStWoGTJklizZk22+Y8cOYJmzZrBx8cH9vb28PT0RN++fTVaeHJbJgAkJycjLi5O40ZERETFl9YCoJSUFJw8eRIeHh7/VkZPDx4eHjh69Gi25zRt2hQnT55UAp5r165h165d6NSp0xuXCQAhISEoU6aMcrOzs8uLSyQiIqJCSmsB0MOHD5Geng4rKyuNdCsrK0RHR2d7jo+PD2bOnInmzZujRIkScHR0ROvWrZUusDcpEwACAwPx9OlT5Xbr1q23vDoiIiIqzLTaBZZbkZGRmDt3LpYtW4ZTp05h27Zt2LlzJ2bNmvVW5RoZGaF06dIaNyIiIiq+crUQYl6ysLCAvr4+YmJiNNJjYmJgbW2d7TlTp07FgAEDMGzYMABAnTp1kJCQgBEjRmDKlClvVCYRERHpHq21ABkaGqJRo0aIiIhQ0tRqNSIiIuDu7p7tOYmJidDT06yyvr4+gIx1it6kTCIiItI9WmsBAoCAgAAMGjQILi4uaNy4MRYvXoyEhAT4+voCAAYOHIiKFSsiJCQEAODt7Y2FCxeiQYMGcHNzw5UrVzB16lR4e3srgdB/lUlERESk1QCoT58+ePDgAaZNm4bo6GjUr18fu3fvVgYxR0VFabT4BAUFQaVSISgoCHfu3IGlpSW8vb0xZ86cHJdJREREpNUACAD8/Pzg5+eX7bHIyEiN+wYGBggODkZwcPAbl0lERERUpGaBEREREeUFBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOqdQBEChoaGwt7eHsbEx3NzccPz48Vfmbd26NVQqVZZb586dlTyDBw/OcrxDhw4FcSlERERUBBhouwKbN29GQEAAVqxYATc3NyxevBheXl64dOkSKlSokCX/tm3bkJKSotx/9OgR6tWrh169emnk69ChA9auXavcNzIyyr+LICIioiJF6y1ACxcuxPDhw+Hr6wtnZ2esWLECJUuWxJo1a7LNb25uDmtra+UWHh6OkiVLZgmAjIyMNPKVK1euIC6HiIiIigCtBkApKSk4efIkPDw8lDQ9PT14eHjg6NGjOSpj9erVeP/992FqaqqRHhkZiQoVKsDJyQmjR4/Go0ePXllGcnIy4uLiNG5ERERUfGk1AHr48CHS09NhZWWlkW5lZYXo6Oj/PP/48eP4+++/MWzYMI30Dh064JtvvkFERATmzZuHAwcOoGPHjkhPT8+2nJCQEJQpU0a52dnZvflFERERUaGn9TFAb2P16tWoU6cOGjdurJH+/vvvK3/XqVMHdevWhaOjIyIjI9GuXbss5QQGBiIgIEC5HxcXxyCIiIioGNNqC5CFhQX09fURExOjkR4TEwNra+vXnpuQkIDvvvsOQ4cO/c/HqVq1KiwsLHDlypVsjxsZGaF06dIaNyIiIiq+tBoAGRoaolGjRoiIiFDS1Go1IiIi4O7u/tpzv//+eyQnJ6N///7/+Ti3b9/Go0ePYGNj89Z1JiIioqJP67PAAgICsGrVKqxfvx4XLlzA6NGjkZCQAF9fXwDAwIEDERgYmOW81atXo1u3bihfvrxG+rNnz/Dxxx/j999/x40bNxAREYGuXbuiWrVq8PLyKpBrIiIiosJN62OA+vTpgwcPHmDatGmIjo5G/fr1sXv3bmVgdFRUFPT0NOO0S5cu4dChQ9i7d2+W8vT19XH27FmsX78esbGxsLW1haenJ2bNmsW1gIiIiAhAIQiAAMDPzw9+fn7ZHouMjMyS5uTkBBHJNr+JiQn27NmTl9UjIiKiYkbrXWBEREREBY0BEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOYQBEREREOocBEBEREekcBkBERESkcxgAERERkc5hAEREREQ6hwEQERER6RwGQERERKRzGAARERGRzmEARERERDqHARARERHpHAZAREREpHMYABEREZHOKRQBUGhoKOzt7WFsbAw3NzccP378lXlbt24NlUqV5da5c2clj4hg2rRpsLGxgYmJCTw8PPDPP/8UxKUQERFREaD1AGjz5s0ICAhAcHAwTp06hXr16sHLywv379/PNv+2bdtw79495fb3339DX18fvXr1UvLMnz8fX3zxBVasWIFjx47B1NQUXl5eSEpKKqjLIiIiokJM6wHQwoULMXz4cPj6+sLZ2RkrVqxAyZIlsWbNmmzzm5ubw9raWrmFh4ejZMmSSgAkIli8eDGCgoLQtWtX1K1bF9988w3u3r2L//3vfwV4ZURERFRYaTUASklJwcmTJ+Hh4aGk6enpwcPDA0ePHs1RGatXr8b7778PU1NTAMD169cRHR2tUWaZMmXg5ub2yjKTk5MRFxencSMiIqLiS6sB0MOHD5Geng4rKyuN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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# box plot for all methods\n",
    "fig, ax = plt.subplots()\n",
    "for method, score in scores.items():\n",
    "    mean = score['CatBoost'][0]\n",
    "    std = score['CatBoost'][1]\n",
    "    ax.bar(method, mean, yerr=std, capsize=5)\n",
    "    \n",
    "    # show values mean\n",
    "    ax.text(method, mean + 0.01, f'{mean:.4f}', ha='center', va='bottom')\n",
    "\n",
    "# rotate x labels\n",
    "ax.set_xticklabels(methods, rotation=30, ha='center')\n",
    "\n",
    "# set ylim\n",
    "min_value = min([score['CatBoost'][0] for score in scores.values()])\n",
    "max_value = max([score['CatBoost'][0] for score in scores.values()])\n",
    "ax.set_ylim(min_value - 0.15, max_value + 0.03)\n",
    "\n",
    "# set x and y labels\n",
    "ax.set_xlabel('Methods')\n",
    "ax.set_ylabel('Test AUC')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_all_methods(dataset, methods, exps_path=EXPS_PATH):\n",
    "    results = {}\n",
    "    for method in methods:\n",
    "        print(f'evaluating {method}...')\n",
    "        exp_dir = os.path.join(exps_path, dataset, method, 'best')\n",
    "        if not os.path.exists(exp_dir):\n",
    "            exp_dir = os.path.join(exps_path, dataset, method, 'many-exps')\n",
    "        \n",
    "        result = evaluate_syn_data(\n",
    "            os.path.join(DB_PATH, dataset),\n",
    "            exp_dir,\n",
    "            2024, 3, ['CatBoost'],\n",
    "        )\n",
    "        results[method] = result\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating codi...\n",
      "evaluating fair-smote...\n",
      "evaluating fair-tab-ddpm...\n",
      "evaluating fair-tab-gan...\n",
      "evaluating great...\n",
      "evaluating smote...\n",
      "evaluating stasy...\n",
      "evaluating tabddpm...\n"
     ]
    }
   ],
   "source": [
    "results = evaluate_all_methods(dataset, methods)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'codi': {'CatBoost': {'AUC': (0.8452744385802621, 0.008282790545036436),\n",
       "   'DPR': (0.2977469329623258, 0.021138623321720843),\n",
       "   'EOR': (0.2814875546818649, 0.024410727999117116)}},\n",
       " 'fair-smote': {'CatBoost': {'AUC': (0.907525586183441, 0.0012483818714813146),\n",
       "   'DPR': (0.26812189573730827, 0.005785909227049049),\n",
       "   'EOR': (0.20953125369749379, 0.012551385499209974)}},\n",
       " 'fair-tab-ddpm': {'CatBoost': {'AUC': (0.8918966734489052,\n",
       "    0.0009141151834793541),\n",
       "   'DPR': (0.643225937790688, 0.021503808329416976),\n",
       "   'EOR': (0.7289239964952982, 0.009819257489331837)}},\n",
       " 'fair-tab-gan': {'CatBoost': {'AUC': (0.8963132044906436,\n",
       "    0.0023986151127191363),\n",
       "   'DPR': (0.4504862317681316, 0.01839435470811548),\n",
       "   'EOR': (0.5800302134557668, 0.04090673083367308)}},\n",
       " 'great': {'CatBoost': {'AUC': (0.9151733240945673, 0.0015614463640945347),\n",
       "   'DPR': (0.2607877887450787, 0.012551699844100974),\n",
       "   'EOR': (0.20971573750492603, 0.02396696926173745)}},\n",
       " 'smote': {'CatBoost': {'AUC': (0.9240111484286359, 0.0003638549790596148),\n",
       "   'DPR': (0.31747639600923677, 0.0004875149049191182),\n",
       "   'EOR': (0.27860211831934206, 0.005062249884806131)}},\n",
       " 'stasy': {'CatBoost': {'AUC': (0.8890867670152236, 0.0038861689251143937),\n",
       "   'DPR': (0.21719117291188902, 0.02854598225249406),\n",
       "   'EOR': (0.14749109307788824, 0.025293329407707447)}},\n",
       " 'tabddpm': {'CatBoost': {'AUC': (0.9053126278614677, 0.0011767087455055436),\n",
       "   'DPR': (0.26129083467384123, 0.008844552747838557),\n",
       "   'EOR': (0.18590166580308456, 0.01723187928811004)}}}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Results on Adult Dataset (Our Method vs Baselines)\n",
      "-------------------------------------------------------------------------------------\n",
      "codi----------- AUC: 0.8453 +- 0.0083 | DPR: 0.2977 +- 0.0211 | EOR: 0.2815 +- 0.0244\n",
      "fair-smote----- AUC: 0.9075 +- 0.0012 | DPR: 0.2681 +- 0.0058 | EOR: 0.2095 +- 0.0126\n",
      "fair-tab-gan--- AUC: 0.8963 +- 0.0024 | DPR: 0.4505 +- 0.0184 | EOR: 0.5800 +- 0.0409\n",
      "great---------- AUC: 0.9152 +- 0.0016 | DPR: 0.2608 +- 0.0126 | EOR: 0.2097 +- 0.0240\n",
      "smote---------- AUC: 0.9240 +- 0.0004 | DPR: 0.3175 +- 0.0005 | EOR: 0.2786 +- 0.0051\n",
      "stasy---------- AUC: 0.8891 +- 0.0039 | DPR: 0.2172 +- 0.0285 | EOR: 0.1475 +- 0.0253\n",
      "tabddpm-------- AUC: 0.9053 +- 0.0012 | DPR: 0.2613 +- 0.0088 | EOR: 0.1859 +- 0.0172\n",
      "-------------------------------------------------------------------------------------\n",
      "fair-tab-ddpm-- AUC: 0.8919 +- 0.0009 | DPR: 0.6432 +- 0.0215 | EOR: 0.7289 +- 0.0098\n"
     ]
    }
   ],
   "source": [
    "print('Results on Adult Dataset (Our Method vs Baselines)')\n",
    "print('-------------------------------------------------------------------------------------')\n",
    "for method, result in results.items():\n",
    "    # method, auc: 4f +- 4f, dpr: 4f +- 4f, eor: 4f +- 4f\n",
    "    if method == 'fair-tab-ddpm':\n",
    "        continue\n",
    "    n_slash = 15 - len(method)\n",
    "    print(f'{method}{\"-\" * n_slash} AUC: {result[\"CatBoost\"][\"AUC\"][0]:.4f} +- {result[\"CatBoost\"][\"AUC\"][1]:.4f} | DPR: {result[\"CatBoost\"][\"DPR\"][0]:.4f} +- {result[\"CatBoost\"][\"DPR\"][1]:.4f} | EOR: {result[\"CatBoost\"][\"EOR\"][0]:.4f} +- {result[\"CatBoost\"][\"EOR\"][1]:.4f}')\n",
    "    \n",
    "print('-------------------------------------------------------------------------------------')\n",
    "method = 'fair-tab-ddpm'\n",
    "n_slash = 15 - len(method)\n",
    "print(f'{method}{\"-\" * n_slash} AUC: {results[method][\"CatBoost\"][\"AUC\"][0]:.4f} +- {results[method][\"CatBoost\"][\"AUC\"][1]:.4f} | DPR: {results[method][\"CatBoost\"][\"DPR\"][0]:.4f} +- {results[method][\"CatBoost\"][\"DPR\"][1]:.4f} | EOR: {results[method][\"CatBoost\"][\"EOR\"][0]:.4f} +- {results[method][\"CatBoost\"][\"EOR\"][1]:.4f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ai",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
