{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9f701ef8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/mnt/hum01-home01/p88346bn/test/project/benchmarks/tabsyn'"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import os, json\n",
    "\n",
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9da07a9e",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dir = f'{os.getcwd()}/eval/combine/'\n",
    "data_name = ['uk', 'canada', 'fiji', 'rwanda', 'indonesia', 'adulta', 'churn']\n",
    "algo = ['tabddpm', 'tabsyn', 'tabsynflow_ot', 'tabsynflow_vp', 'tabvvfm_ot', 'tabvvfm_vp', 'tabtvfm_ot', 'tabtvfm_vp']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5e074cec",
   "metadata": {},
   "source": [
    "## Evaluation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae6f6244",
   "metadata": {},
   "source": [
    "### Additional measurements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "b1b6ff9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_mean = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_{j}_urisk.csv')\n",
    "        aa[['shape','trend']] = (1-aa[['shape','trend']]) * 100\n",
    "        aa = aa.mean().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        res_mean = pd.concat([res_mean,aa], axis=1)\n",
    "    \n",
    "res_mean = res_mean.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "14efad54",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_std = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_{j}_urisk.csv')\n",
    "        aa[['shape','trend']] = (1-aa[['shape','trend']]) * 100\n",
    "        aa = aa.std().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        res_std = pd.concat([res_std,aa], axis=1)\n",
    "    \n",
    "res_std = res_std.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "2fd4c31f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.9324</td>\n",
       "      <td>0.8434</td>\n",
       "      <td>0.5692</td>\n",
       "      <td>0.498</td>\n",
       "      <td>0.7817</td>\n",
       "      <td>0.498</td>\n",
       "      <td>0.0015</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9902</td>\n",
       "      <td>0.0092</td>\n",
       "      <td>0.0003</td>\n",
       "      <td>0.1705</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7</td>\n",
       "      <td>0.945</td>\n",
       "      <td>1.7909</td>\n",
       "      <td>0.9563</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.9578</td>\n",
       "      <td>0.879</td>\n",
       "      <td>0.4482</td>\n",
       "      <td>0.4855</td>\n",
       "      <td>0.7617</td>\n",
       "      <td>0.4855</td>\n",
       "      <td>0.005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9853</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0437</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8857</td>\n",
       "      <td>0.933</td>\n",
       "      <td>1.9067</td>\n",
       "      <td>0.9561</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.969</td>\n",
       "      <td>0.887</td>\n",
       "      <td>0.4793</td>\n",
       "      <td>0.4852</td>\n",
       "      <td>0.7784</td>\n",
       "      <td>0.4852</td>\n",
       "      <td>0.0033</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9873</td>\n",
       "      <td>0.0067</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1893</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.5393</td>\n",
       "      <td>0.7105</td>\n",
       "      <td>1.6598</td>\n",
       "      <td>0.9652</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.9422</td>\n",
       "      <td>0.8228</td>\n",
       "      <td>0.2676</td>\n",
       "      <td>0.4653</td>\n",
       "      <td>0.6775</td>\n",
       "      <td>0.4653</td>\n",
       "      <td>0.0061</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9856</td>\n",
       "      <td>0.0141</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0736</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7786</td>\n",
       "      <td>1.4137</td>\n",
       "      <td>3.1704</td>\n",
       "      <td>0.8801</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.9727</td>\n",
       "      <td>0.9028</td>\n",
       "      <td>0.626</td>\n",
       "      <td>0.4912</td>\n",
       "      <td>0.8338</td>\n",
       "      <td>0.4912</td>\n",
       "      <td>0.0067</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9796</td>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.337</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3429</td>\n",
       "      <td>0.5828</td>\n",
       "      <td>1.3824</td>\n",
       "      <td>0.9789</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.9757</td>\n",
       "      <td>0.9025</td>\n",
       "      <td>0.5246</td>\n",
       "      <td>0.4779</td>\n",
       "      <td>0.8009</td>\n",
       "      <td>0.4779</td>\n",
       "      <td>0.0081</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9582</td>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3014</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3357</td>\n",
       "      <td>0.6208</td>\n",
       "      <td>1.8081</td>\n",
       "      <td>0.9827</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.9487</td>\n",
       "      <td>0.8619</td>\n",
       "      <td>0.532</td>\n",
       "      <td>0.4716</td>\n",
       "      <td>0.7809</td>\n",
       "      <td>0.4716</td>\n",
       "      <td>0.0068</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.977</td>\n",
       "      <td>0.017</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1077</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>1.6878</td>\n",
       "      <td>2.9758</td>\n",
       "      <td>0.8523</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.9556</td>\n",
       "      <td>0.8774</td>\n",
       "      <td>0.5421</td>\n",
       "      <td>0.482</td>\n",
       "      <td>0.7917</td>\n",
       "      <td>0.482</td>\n",
       "      <td>0.0086</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9539</td>\n",
       "      <td>0.0195</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0438</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8786</td>\n",
       "      <td>1.9964</td>\n",
       "      <td>3.2241</td>\n",
       "      <td>0.8262</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.4382</td>\n",
       "      <td>0.3456</td>\n",
       "      <td>0.063</td>\n",
       "      <td>-0.268</td>\n",
       "      <td>0.2823</td>\n",
       "      <td>0.0189</td>\n",
       "      <td>0.3346</td>\n",
       "      <td>0.1601</td>\n",
       "      <td>0.4207</td>\n",
       "      <td>0.3723</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.5844</td>\n",
       "      <td>61.3026</td>\n",
       "      <td>0.0555</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.9193</td>\n",
       "      <td>0.787</td>\n",
       "      <td>0.4853</td>\n",
       "      <td>0.2633</td>\n",
       "      <td>0.7305</td>\n",
       "      <td>0.2633</td>\n",
       "      <td>0.0141</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8489</td>\n",
       "      <td>0.0111</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2103</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.4643</td>\n",
       "      <td>3.2982</td>\n",
       "      <td>8.0524</td>\n",
       "      <td>0.8439</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.8941</td>\n",
       "      <td>0.7507</td>\n",
       "      <td>0.4694</td>\n",
       "      <td>0.2523</td>\n",
       "      <td>0.7047</td>\n",
       "      <td>0.2523</td>\n",
       "      <td>0.0141</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.8451</td>\n",
       "      <td>0.0154</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1842</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.6024</td>\n",
       "      <td>3.742</td>\n",
       "      <td>8.7066</td>\n",
       "      <td>0.8404</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.8787</td>\n",
       "      <td>0.7128</td>\n",
       "      <td>0.334</td>\n",
       "      <td>0.2092</td>\n",
       "      <td>0.6418</td>\n",
       "      <td>0.2092</td>\n",
       "      <td>0.0154</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.0231</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7643</td>\n",
       "      <td>4.4505</td>\n",
       "      <td>8.1539</td>\n",
       "      <td>0.853</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.9441</td>\n",
       "      <td>0.8628</td>\n",
       "      <td>0.508</td>\n",
       "      <td>0.3145</td>\n",
       "      <td>0.7716</td>\n",
       "      <td>0.3145</td>\n",
       "      <td>0.0223</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.8319</td>\n",
       "      <td>0.0073</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3661</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3048</td>\n",
       "      <td>3.2173</td>\n",
       "      <td>7.119</td>\n",
       "      <td>0.877</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.9606</td>\n",
       "      <td>0.8751</td>\n",
       "      <td>0.4057</td>\n",
       "      <td>0.2938</td>\n",
       "      <td>0.7471</td>\n",
       "      <td>0.2938</td>\n",
       "      <td>0.0225</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8302</td>\n",
       "      <td>0.0066</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.4542</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.1286</td>\n",
       "      <td>3.1654</td>\n",
       "      <td>7.2878</td>\n",
       "      <td>0.8712</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.9406</td>\n",
       "      <td>0.8496</td>\n",
       "      <td>0.566</td>\n",
       "      <td>0.335</td>\n",
       "      <td>0.7854</td>\n",
       "      <td>0.335</td>\n",
       "      <td>0.0202</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.833</td>\n",
       "      <td>0.0138</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2263</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.5452</td>\n",
       "      <td>3.744</td>\n",
       "      <td>7.4079</td>\n",
       "      <td>0.8659</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.9259</td>\n",
       "      <td>0.8324</td>\n",
       "      <td>0.4608</td>\n",
       "      <td>0.3209</td>\n",
       "      <td>0.7397</td>\n",
       "      <td>0.3209</td>\n",
       "      <td>0.0198</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8379</td>\n",
       "      <td>0.0126</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2035</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.4976</td>\n",
       "      <td>3.5851</td>\n",
       "      <td>7.5016</td>\n",
       "      <td>0.877</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.16</td>\n",
       "      <td>0.1882</td>\n",
       "      <td>0.0365</td>\n",
       "      <td>0.032</td>\n",
       "      <td>0.1282</td>\n",
       "      <td>0.0558</td>\n",
       "      <td>0.3333</td>\n",
       "      <td>0.4201</td>\n",
       "      <td>0.5189</td>\n",
       "      <td>0.5079</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0211</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9306</td>\n",
       "      <td>50.7404</td>\n",
       "      <td>78.4654</td>\n",
       "      <td>0.0376</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.882</td>\n",
       "      <td>0.7515</td>\n",
       "      <td>0.4863</td>\n",
       "      <td>0.5579</td>\n",
       "      <td>0.7066</td>\n",
       "      <td>0.5579</td>\n",
       "      <td>0.0055</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.986</td>\n",
       "      <td>0.0102</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0494</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8806</td>\n",
       "      <td>1.04</td>\n",
       "      <td>1.9604</td>\n",
       "      <td>0.9763</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.8648</td>\n",
       "      <td>0.7262</td>\n",
       "      <td>0.4373</td>\n",
       "      <td>0.5513</td>\n",
       "      <td>0.6761</td>\n",
       "      <td>0.5513</td>\n",
       "      <td>0.0049</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9858</td>\n",
       "      <td>0.0101</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0562</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8722</td>\n",
       "      <td>1.0265</td>\n",
       "      <td>2.0968</td>\n",
       "      <td>0.9815</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.8253</td>\n",
       "      <td>0.6584</td>\n",
       "      <td>0.3171</td>\n",
       "      <td>0.522</td>\n",
       "      <td>0.6002</td>\n",
       "      <td>0.522</td>\n",
       "      <td>0.0069</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9837</td>\n",
       "      <td>0.0222</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0103</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9611</td>\n",
       "      <td>2.2059</td>\n",
       "      <td>3.7397</td>\n",
       "      <td>0.955</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.8765</td>\n",
       "      <td>0.7942</td>\n",
       "      <td>0.4998</td>\n",
       "      <td>0.5666</td>\n",
       "      <td>0.7235</td>\n",
       "      <td>0.5666</td>\n",
       "      <td>0.0085</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9791</td>\n",
       "      <td>0.0073</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1128</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7</td>\n",
       "      <td>0.7977</td>\n",
       "      <td>1.5561</td>\n",
       "      <td>0.9821</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.9181</td>\n",
       "      <td>0.8221</td>\n",
       "      <td>0.513</td>\n",
       "      <td>0.5561</td>\n",
       "      <td>0.7511</td>\n",
       "      <td>0.5561</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9792</td>\n",
       "      <td>0.0066</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.233</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.4472</td>\n",
       "      <td>0.753</td>\n",
       "      <td>1.5837</td>\n",
       "      <td>0.9859</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.897</td>\n",
       "      <td>0.7894</td>\n",
       "      <td>0.5309</td>\n",
       "      <td>0.5727</td>\n",
       "      <td>0.7391</td>\n",
       "      <td>0.5727</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9712</td>\n",
       "      <td>0.0146</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.049</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8611</td>\n",
       "      <td>1.484</td>\n",
       "      <td>2.3144</td>\n",
       "      <td>0.9746</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.8773</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.5708</td>\n",
       "      <td>0.5606</td>\n",
       "      <td>0.7394</td>\n",
       "      <td>0.5606</td>\n",
       "      <td>0.0087</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9802</td>\n",
       "      <td>0.0168</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.062</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.825</td>\n",
       "      <td>1.6956</td>\n",
       "      <td>2.6089</td>\n",
       "      <td>0.9737</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.5488</td>\n",
       "      <td>0.5774</td>\n",
       "      <td>0.1035</td>\n",
       "      <td>-0.339</td>\n",
       "      <td>0.4099</td>\n",
       "      <td>0.0652</td>\n",
       "      <td>0.3636</td>\n",
       "      <td>0.2709</td>\n",
       "      <td>0.4988</td>\n",
       "      <td>0.2299</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0738</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.895</td>\n",
       "      <td>24.279</td>\n",
       "      <td>45.186</td>\n",
       "      <td>0.4347</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.7628</td>\n",
       "      <td>0.7349</td>\n",
       "      <td>0.521</td>\n",
       "      <td>0.4954</td>\n",
       "      <td>0.6729</td>\n",
       "      <td>0.4954</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9828</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.0003</td>\n",
       "      <td>0.0597</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8425</td>\n",
       "      <td>0.9398</td>\n",
       "      <td>1.3748</td>\n",
       "      <td>0.9824</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.7616</td>\n",
       "      <td>0.7281</td>\n",
       "      <td>0.5194</td>\n",
       "      <td>0.4953</td>\n",
       "      <td>0.6697</td>\n",
       "      <td>0.4953</td>\n",
       "      <td>0.0036</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9804</td>\n",
       "      <td>0.0076</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.0805</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7975</td>\n",
       "      <td>0.8238</td>\n",
       "      <td>1.4298</td>\n",
       "      <td>0.9779</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>0.703</td>\n",
       "      <td>0.6755</td>\n",
       "      <td>0.3941</td>\n",
       "      <td>0.4644</td>\n",
       "      <td>0.5908</td>\n",
       "      <td>0.4644</td>\n",
       "      <td>0.0049</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.9756</td>\n",
       "      <td>0.0143</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0899</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8425</td>\n",
       "      <td>1.4467</td>\n",
       "      <td>2.1755</td>\n",
       "      <td>0.9632</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>0.8173</td>\n",
       "      <td>0.7934</td>\n",
       "      <td>0.6038</td>\n",
       "      <td>0.534</td>\n",
       "      <td>0.7382</td>\n",
       "      <td>0.534</td>\n",
       "      <td>0.0063</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9791</td>\n",
       "      <td>0.0049</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.3335</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.5619</td>\n",
       "      <td>1.0061</td>\n",
       "      <td>0.9932</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>0.839</td>\n",
       "      <td>0.8046</td>\n",
       "      <td>0.5767</td>\n",
       "      <td>0.5181</td>\n",
       "      <td>0.7401</td>\n",
       "      <td>0.5181</td>\n",
       "      <td>0.0084</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9768</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5242</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.085</td>\n",
       "      <td>0.5055</td>\n",
       "      <td>1.1381</td>\n",
       "      <td>0.9972</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>0.8403</td>\n",
       "      <td>0.8031</td>\n",
       "      <td>0.5891</td>\n",
       "      <td>0.5359</td>\n",
       "      <td>0.7442</td>\n",
       "      <td>0.5359</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9693</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3424</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.1925</td>\n",
       "      <td>0.5692</td>\n",
       "      <td>1.1247</td>\n",
       "      <td>0.987</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>0.8072</td>\n",
       "      <td>0.7807</td>\n",
       "      <td>0.5748</td>\n",
       "      <td>0.5306</td>\n",
       "      <td>0.7209</td>\n",
       "      <td>0.5306</td>\n",
       "      <td>0.0077</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9765</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.2357</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3725</td>\n",
       "      <td>0.6621</td>\n",
       "      <td>1.2472</td>\n",
       "      <td>0.9866</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>0.928</td>\n",
       "      <td>0.8782</td>\n",
       "      <td>0.5982</td>\n",
       "      <td>0.6484</td>\n",
       "      <td>0.8015</td>\n",
       "      <td>0.6484</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9968</td>\n",
       "      <td>0.0034</td>\n",
       "      <td>0.3514</td>\n",
       "      <td>0.061</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.8458</td>\n",
       "      <td>0.3439</td>\n",
       "      <td>0.6124</td>\n",
       "      <td>0.992</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>0.9457</td>\n",
       "      <td>0.8932</td>\n",
       "      <td>0.7731</td>\n",
       "      <td>0.6624</td>\n",
       "      <td>0.8707</td>\n",
       "      <td>0.6624</td>\n",
       "      <td>0.003</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9923</td>\n",
       "      <td>0.0044</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0233</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8958</td>\n",
       "      <td>0.4564</td>\n",
       "      <td>0.7837</td>\n",
       "      <td>0.9891</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>0.9711</td>\n",
       "      <td>0.9009</td>\n",
       "      <td>0.8237</td>\n",
       "      <td>0.6598</td>\n",
       "      <td>0.8986</td>\n",
       "      <td>0.6598</td>\n",
       "      <td>0.0016</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9956</td>\n",
       "      <td>0.0018</td>\n",
       "      <td>0.1022</td>\n",
       "      <td>0.401</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.2055</td>\n",
       "      <td>0.4325</td>\n",
       "      <td>0.9983</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>0.9399</td>\n",
       "      <td>0.8409</td>\n",
       "      <td>0.5691</td>\n",
       "      <td>0.6436</td>\n",
       "      <td>0.7833</td>\n",
       "      <td>0.6436</td>\n",
       "      <td>0.0022</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9905</td>\n",
       "      <td>0.0035</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0472</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8333</td>\n",
       "      <td>0.3967</td>\n",
       "      <td>0.7694</td>\n",
       "      <td>0.9887</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>0.8352</td>\n",
       "      <td>0.7502</td>\n",
       "      <td>0.4129</td>\n",
       "      <td>0.4095</td>\n",
       "      <td>0.6661</td>\n",
       "      <td>0.4095</td>\n",
       "      <td>0.0062</td>\n",
       "      <td>0.0212</td>\n",
       "      <td>0.9802</td>\n",
       "      <td>0.102</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3479</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3667</td>\n",
       "      <td>0.2866</td>\n",
       "      <td>0.7165</td>\n",
       "      <td>0.9898</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>0.8192</td>\n",
       "      <td>0.7224</td>\n",
       "      <td>0.3967</td>\n",
       "      <td>0.401</td>\n",
       "      <td>0.6461</td>\n",
       "      <td>0.401</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0212</td>\n",
       "      <td>0.9805</td>\n",
       "      <td>0.1028</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2266</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.4917</td>\n",
       "      <td>0.3687</td>\n",
       "      <td>0.9461</td>\n",
       "      <td>0.9808</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>0.8286</td>\n",
       "      <td>0.7481</td>\n",
       "      <td>0.3925</td>\n",
       "      <td>0.405</td>\n",
       "      <td>0.6564</td>\n",
       "      <td>0.405</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0211</td>\n",
       "      <td>0.9822</td>\n",
       "      <td>0.1025</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2667</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.425</td>\n",
       "      <td>0.344</td>\n",
       "      <td>0.7846</td>\n",
       "      <td>0.9886</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>0.8199</td>\n",
       "      <td>0.7388</td>\n",
       "      <td>0.3959</td>\n",
       "      <td>0.3998</td>\n",
       "      <td>0.6515</td>\n",
       "      <td>0.3998</td>\n",
       "      <td>0.0067</td>\n",
       "      <td>0.0211</td>\n",
       "      <td>0.9817</td>\n",
       "      <td>0.1033</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.6583</td>\n",
       "      <td>0.3978</td>\n",
       "      <td>0.9527</td>\n",
       "      <td>0.9828</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>0.9031</td>\n",
       "      <td>0.7461</td>\n",
       "      <td>0.343</td>\n",
       "      <td>0.4463</td>\n",
       "      <td>0.664</td>\n",
       "      <td>0.4463</td>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.9849</td>\n",
       "      <td>0.0159</td>\n",
       "      <td>0.3987</td>\n",
       "      <td>0.0374</td>\n",
       "      <td>0.4</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1.5637</td>\n",
       "      <td>3.6367</td>\n",
       "      <td>0.9427</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>0.9072</td>\n",
       "      <td>0.7795</td>\n",
       "      <td>0.592</td>\n",
       "      <td>0.4805</td>\n",
       "      <td>0.7596</td>\n",
       "      <td>0.4805</td>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9889</td>\n",
       "      <td>0.0092</td>\n",
       "      <td>0.1475</td>\n",
       "      <td>0.0725</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.73</td>\n",
       "      <td>0.9861</td>\n",
       "      <td>2.1067</td>\n",
       "      <td>0.9704</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>0.9125</td>\n",
       "      <td>0.7684</td>\n",
       "      <td>0.591</td>\n",
       "      <td>0.4656</td>\n",
       "      <td>0.7573</td>\n",
       "      <td>0.4656</td>\n",
       "      <td>0.0028</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9902</td>\n",
       "      <td>0.0071</td>\n",
       "      <td>0.3119</td>\n",
       "      <td>0.2339</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.56</td>\n",
       "      <td>0.8022</td>\n",
       "      <td>2.0677</td>\n",
       "      <td>0.9826</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>0.8792</td>\n",
       "      <td>0.7246</td>\n",
       "      <td>0.4419</td>\n",
       "      <td>0.4052</td>\n",
       "      <td>0.6819</td>\n",
       "      <td>0.4052</td>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9826</td>\n",
       "      <td>0.0132</td>\n",
       "      <td>0.0705</td>\n",
       "      <td>0.0593</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.86</td>\n",
       "      <td>1.4579</td>\n",
       "      <td>3.0163</td>\n",
       "      <td>0.9458</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>0.9349</td>\n",
       "      <td>0.839</td>\n",
       "      <td>0.5859</td>\n",
       "      <td>0.5457</td>\n",
       "      <td>0.7866</td>\n",
       "      <td>0.5457</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9755</td>\n",
       "      <td>0.0061</td>\n",
       "      <td>0.0207</td>\n",
       "      <td>0.3601</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.19</td>\n",
       "      <td>1.22</td>\n",
       "      <td>2.823</td>\n",
       "      <td>0.9639</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>0.9479</td>\n",
       "      <td>0.8391</td>\n",
       "      <td>0.5068</td>\n",
       "      <td>0.5017</td>\n",
       "      <td>0.7646</td>\n",
       "      <td>0.5017</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9768</td>\n",
       "      <td>0.005</td>\n",
       "      <td>0.0334</td>\n",
       "      <td>0.5095</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.08</td>\n",
       "      <td>1.1104</td>\n",
       "      <td>2.7543</td>\n",
       "      <td>0.9881</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>0.7896</td>\n",
       "      <td>0.6677</td>\n",
       "      <td>0.2337</td>\n",
       "      <td>0.5432</td>\n",
       "      <td>0.5637</td>\n",
       "      <td>0.5432</td>\n",
       "      <td>0.0333</td>\n",
       "      <td>0.0003</td>\n",
       "      <td>0.9318</td>\n",
       "      <td>0.0338</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>4.526</td>\n",
       "      <td>7.6053</td>\n",
       "      <td>0.6936</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>0.8918</td>\n",
       "      <td>0.7872</td>\n",
       "      <td>0.5522</td>\n",
       "      <td>0.5609</td>\n",
       "      <td>0.7437</td>\n",
       "      <td>0.5609</td>\n",
       "      <td>0.0066</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9824</td>\n",
       "      <td>0.0111</td>\n",
       "      <td>0.0273</td>\n",
       "      <td>0.145</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.61</td>\n",
       "      <td>1.3237</td>\n",
       "      <td>2.836</td>\n",
       "      <td>0.9607</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>0.934</td>\n",
       "      <td>0.8812</td>\n",
       "      <td>0.6397</td>\n",
       "      <td>0.0581</td>\n",
       "      <td>0.8183</td>\n",
       "      <td>0.0662</td>\n",
       "      <td>0.0029</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9899</td>\n",
       "      <td>0.0125</td>\n",
       "      <td>0.6761</td>\n",
       "      <td>0.2428</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.4714</td>\n",
       "      <td>1.1612</td>\n",
       "      <td>2.3848</td>\n",
       "      <td>0.9748</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>0.9744</td>\n",
       "      <td>0.9439</td>\n",
       "      <td>0.6807</td>\n",
       "      <td>0.0427</td>\n",
       "      <td>0.8663</td>\n",
       "      <td>0.063</td>\n",
       "      <td>0.0055</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9853</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.2854</td>\n",
       "      <td>0.4724</td>\n",
       "      <td>0.0625</td>\n",
       "      <td>0.1071</td>\n",
       "      <td>1.0421</td>\n",
       "      <td>2.4111</td>\n",
       "      <td>0.9957</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>0.9788</td>\n",
       "      <td>0.9517</td>\n",
       "      <td>0.7069</td>\n",
       "      <td>0.0314</td>\n",
       "      <td>0.8791</td>\n",
       "      <td>0.0566</td>\n",
       "      <td>0.0045</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9861</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.3461</td>\n",
       "      <td>0.5121</td>\n",
       "      <td>0.0125</td>\n",
       "      <td>0.0357</td>\n",
       "      <td>0.9773</td>\n",
       "      <td>2.2187</td>\n",
       "      <td>0.9949</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>0.9386</td>\n",
       "      <td>0.8755</td>\n",
       "      <td>0.6287</td>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.8143</td>\n",
       "      <td>0.0348</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0015</td>\n",
       "      <td>0.9834</td>\n",
       "      <td>0.0268</td>\n",
       "      <td>0.1934</td>\n",
       "      <td>0.2992</td>\n",
       "      <td>0.2625</td>\n",
       "      <td>0.2714</td>\n",
       "      <td>2.3132</td>\n",
       "      <td>4.6026</td>\n",
       "      <td>0.87</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>0.9785</td>\n",
       "      <td>0.9506</td>\n",
       "      <td>0.4692</td>\n",
       "      <td>0.0874</td>\n",
       "      <td>0.7994</td>\n",
       "      <td>0.094</td>\n",
       "      <td>0.0361</td>\n",
       "      <td>-0.0001</td>\n",
       "      <td>0.9355</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5934</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0071</td>\n",
       "      <td>2.7246</td>\n",
       "      <td>8.0029</td>\n",
       "      <td>0.9222</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>0.9795</td>\n",
       "      <td>0.9517</td>\n",
       "      <td>0.492</td>\n",
       "      <td>0.0816</td>\n",
       "      <td>0.8077</td>\n",
       "      <td>0.0885</td>\n",
       "      <td>0.0285</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9404</td>\n",
       "      <td>0.006</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.6025</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.5466</td>\n",
       "      <td>6.9639</td>\n",
       "      <td>0.927</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>0.9809</td>\n",
       "      <td>0.9554</td>\n",
       "      <td>0.6852</td>\n",
       "      <td>0.1183</td>\n",
       "      <td>0.8738</td>\n",
       "      <td>0.1249</td>\n",
       "      <td>0.0135</td>\n",
       "      <td>-0.0001</td>\n",
       "      <td>0.9663</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.6165</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0071</td>\n",
       "      <td>1.6025</td>\n",
       "      <td>4.3312</td>\n",
       "      <td>0.9778</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>0.9717</td>\n",
       "      <td>0.9428</td>\n",
       "      <td>0.5872</td>\n",
       "      <td>0.1391</td>\n",
       "      <td>0.8339</td>\n",
       "      <td>0.1427</td>\n",
       "      <td>0.012</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9707</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.3457</td>\n",
       "      <td>0.9375</td>\n",
       "      <td>0.1357</td>\n",
       "      <td>1.7049</td>\n",
       "      <td>3.9839</td>\n",
       "      <td>0.9662</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   ROC_uni ROC_biv     CIO    TCAP Utility    Risk      WD     MMD  KS_sim  \\\n",
       "0   0.9324  0.8434  0.5692   0.498  0.7817   0.498  0.0015     0.0  0.9902   \n",
       "1   0.9578   0.879  0.4482  0.4855  0.7617  0.4855   0.005     0.0  0.9853   \n",
       "2    0.969   0.887  0.4793  0.4852  0.7784  0.4852  0.0033     0.0  0.9873   \n",
       "3   0.9422  0.8228  0.2676  0.4653  0.6775  0.4653  0.0061  0.0001  0.9856   \n",
       "4   0.9727  0.9028   0.626  0.4912  0.8338  0.4912  0.0067     0.0  0.9796   \n",
       "5   0.9757  0.9025  0.5246  0.4779  0.8009  0.4779  0.0081  0.0001  0.9582   \n",
       "6   0.9487  0.8619   0.532  0.4716  0.7809  0.4716  0.0068  0.0001   0.977   \n",
       "7   0.9556  0.8774  0.5421   0.482  0.7917   0.482  0.0086  0.0001  0.9539   \n",
       "8   0.4382  0.3456   0.063  -0.268  0.2823  0.0189  0.3346  0.1601  0.4207   \n",
       "9   0.9193   0.787  0.4853  0.2633  0.7305  0.2633  0.0141     0.0  0.8489   \n",
       "10  0.8941  0.7507  0.4694  0.2523  0.7047  0.2523  0.0141  0.0001  0.8451   \n",
       "11  0.8787  0.7128   0.334  0.2092  0.6418  0.2092  0.0154  0.0002    0.84   \n",
       "12  0.9441  0.8628   0.508  0.3145  0.7716  0.3145  0.0223    -0.0  0.8319   \n",
       "13  0.9606  0.8751  0.4057  0.2938  0.7471  0.2938  0.0225     0.0  0.8302   \n",
       "14  0.9406  0.8496   0.566   0.335  0.7854   0.335  0.0202    -0.0   0.833   \n",
       "15  0.9259  0.8324  0.4608  0.3209  0.7397  0.3209  0.0198     0.0  0.8379   \n",
       "16    0.16  0.1882  0.0365   0.032  0.1282  0.0558  0.3333  0.4201  0.5189   \n",
       "17   0.882  0.7515  0.4863  0.5579  0.7066  0.5579  0.0055     0.0   0.986   \n",
       "18  0.8648  0.7262  0.4373  0.5513  0.6761  0.5513  0.0049     0.0  0.9858   \n",
       "19  0.8253  0.6584  0.3171   0.522  0.6002   0.522  0.0069  0.0001  0.9837   \n",
       "20  0.8765  0.7942  0.4998  0.5666  0.7235  0.5666  0.0085    -0.0  0.9791   \n",
       "21  0.9181  0.8221   0.513  0.5561  0.7511  0.5561   0.009     0.0  0.9792   \n",
       "22   0.897  0.7894  0.5309  0.5727  0.7391  0.5727   0.008     0.0  0.9712   \n",
       "23  0.8773    0.77  0.5708  0.5606  0.7394  0.5606  0.0087     0.0  0.9802   \n",
       "24  0.5488  0.5774  0.1035  -0.339  0.4099  0.0652  0.3636  0.2709  0.4988   \n",
       "25  0.7628  0.7349   0.521  0.4954  0.6729  0.4954  0.0048     0.0  0.9828   \n",
       "26  0.7616  0.7281  0.5194  0.4953  0.6697  0.4953  0.0036  0.0001  0.9804   \n",
       "27   0.703  0.6755  0.3941  0.4644  0.5908  0.4644  0.0049  0.0002  0.9756   \n",
       "28  0.8173  0.7934  0.6038   0.534  0.7382   0.534  0.0063     0.0  0.9791   \n",
       "29   0.839  0.8046  0.5767  0.5181  0.7401  0.5181  0.0084     0.0  0.9768   \n",
       "30  0.8403  0.8031  0.5891  0.5359  0.7442  0.5359  0.0094     0.0  0.9693   \n",
       "31  0.8072  0.7807  0.5748  0.5306  0.7209  0.5306  0.0077  0.0001  0.9765   \n",
       "32   0.928  0.8782  0.5982  0.6484  0.8015  0.6484  0.0012     0.0  0.9968   \n",
       "33  0.9457  0.8932  0.7731  0.6624  0.8707  0.6624   0.003     0.0  0.9923   \n",
       "34  0.9711  0.9009  0.8237  0.6598  0.8986  0.6598  0.0016    -0.0  0.9956   \n",
       "35  0.9399  0.8409  0.5691  0.6436  0.7833  0.6436  0.0022     0.0  0.9905   \n",
       "36  0.8352  0.7502  0.4129  0.4095  0.6661  0.4095  0.0062  0.0212  0.9802   \n",
       "37  0.8192  0.7224  0.3967   0.401  0.6461   0.401  0.0074  0.0212  0.9805   \n",
       "38  0.8286  0.7481  0.3925   0.405  0.6564   0.405  0.0059  0.0211  0.9822   \n",
       "39  0.8199  0.7388  0.3959  0.3998  0.6515  0.3998  0.0067  0.0211  0.9817   \n",
       "40  0.9031  0.7461   0.343  0.4463   0.664  0.4463  0.0039  0.0002  0.9849   \n",
       "41  0.9072  0.7795   0.592  0.4805  0.7596  0.4805  0.0037     0.0  0.9889   \n",
       "42  0.9125  0.7684   0.591  0.4656  0.7573  0.4656  0.0028     0.0  0.9902   \n",
       "43  0.8792  0.7246  0.4419  0.4052  0.6819  0.4052  0.0039  0.0001  0.9826   \n",
       "44  0.9349   0.839  0.5859  0.5457  0.7866  0.5457  0.0074     0.0  0.9755   \n",
       "45  0.9479  0.8391  0.5068  0.5017  0.7646  0.5017  0.0074     0.0  0.9768   \n",
       "46  0.7896  0.6677  0.2337  0.5432  0.5637  0.5432  0.0333  0.0003  0.9318   \n",
       "47  0.8918  0.7872  0.5522  0.5609  0.7437  0.5609  0.0066     0.0  0.9824   \n",
       "48   0.934  0.8812  0.6397  0.0581  0.8183  0.0662  0.0029     0.0  0.9899   \n",
       "49  0.9744  0.9439  0.6807  0.0427  0.8663   0.063  0.0055    -0.0  0.9853   \n",
       "50  0.9788  0.9517  0.7069  0.0314  0.8791  0.0566  0.0045    -0.0  0.9861   \n",
       "51  0.9386  0.8755  0.6287  0.0037  0.8143  0.0348  0.0048  0.0015  0.9834   \n",
       "52  0.9785  0.9506  0.4692  0.0874  0.7994   0.094  0.0361 -0.0001  0.9355   \n",
       "53  0.9795  0.9517   0.492  0.0816  0.8077  0.0885  0.0285    -0.0  0.9404   \n",
       "54  0.9809  0.9554  0.6852  0.1183  0.8738  0.1249  0.0135 -0.0001  0.9663   \n",
       "55  0.9717  0.9428  0.5872  0.1391  0.8339  0.1427   0.012    -0.0  0.9707   \n",
       "\n",
       "   tvd_sim KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject  \\\n",
       "0   0.0092  0.0003         0.1705            1.0                   0.7   \n",
       "1    0.009     0.0         0.0437            1.0                0.8857   \n",
       "2   0.0067     0.0         0.1893            1.0                0.5393   \n",
       "3   0.0141     0.0         0.0736            1.0                0.7786   \n",
       "4   0.0051     0.0          0.337            1.0                0.3429   \n",
       "5   0.0051     0.0         0.3014            1.0                0.3357   \n",
       "6    0.017     0.0         0.1077            1.0                   0.8   \n",
       "7   0.0195     0.0         0.0438            1.0                0.8786   \n",
       "8   0.3723     0.0            0.0            1.0                   1.0   \n",
       "9   0.0111     0.0         0.2103            1.0                0.4643   \n",
       "10  0.0154     0.0         0.1842            1.0                0.6024   \n",
       "11  0.0231     0.0         0.0951            1.0                0.7643   \n",
       "12  0.0073     0.0         0.3661            1.0                0.3048   \n",
       "13  0.0066     0.0         0.4542            1.0                0.1286   \n",
       "14  0.0138     0.0         0.2263            1.0                0.5452   \n",
       "15  0.0126     0.0         0.2035            1.0                0.4976   \n",
       "16  0.5079     0.0         0.0211            1.0                0.9306   \n",
       "17  0.0102     0.0         0.0494            1.0                0.8806   \n",
       "18  0.0101     0.0         0.0562            1.0                0.8722   \n",
       "19  0.0222     0.0         0.0103            1.0                0.9611   \n",
       "20  0.0073     0.0         0.1128            1.0                   0.7   \n",
       "21  0.0066     0.0          0.233            1.0                0.4472   \n",
       "22  0.0146     0.0          0.049            1.0                0.8611   \n",
       "23  0.0168     0.0          0.062            1.0                 0.825   \n",
       "24  0.2299     0.0         0.0738            1.0                 0.895   \n",
       "25   0.009  0.0003         0.0597            1.0                0.8425   \n",
       "26  0.0076  0.0001         0.0805            1.0                0.7975   \n",
       "27  0.0143     0.0         0.0899            1.0                0.8425   \n",
       "28  0.0049  0.0002         0.3335            1.0                  0.27   \n",
       "29   0.004     0.0         0.5242            1.0                 0.085   \n",
       "30  0.0048     0.0         0.3424            1.0                0.1925   \n",
       "31  0.0059  0.0001         0.2357            1.0                0.3725   \n",
       "32  0.0034  0.3514          0.061           0.05                0.8458   \n",
       "33  0.0044  0.0002         0.0233            1.0                0.8958   \n",
       "34  0.0018  0.1022          0.401           0.35                 0.125   \n",
       "35  0.0035     0.0         0.0472            1.0                0.8333   \n",
       "36   0.102     0.0         0.3479            1.0                0.3667   \n",
       "37  0.1028     0.0         0.2266            1.0                0.4917   \n",
       "38  0.1025     0.0         0.2667            1.0                 0.425   \n",
       "39  0.1033     0.0         0.1159            1.0                0.6583   \n",
       "40  0.0159  0.3987         0.0374            0.4                  0.83   \n",
       "41  0.0092  0.1475         0.0725           0.59                  0.73   \n",
       "42  0.0071  0.3119         0.2339           0.39                  0.56   \n",
       "43  0.0132  0.0705         0.0593           0.78                  0.86   \n",
       "44  0.0061  0.0207         0.3601           0.85                  0.19   \n",
       "45   0.005  0.0334         0.5095           0.85                  0.08   \n",
       "46  0.0338     0.0            0.0            1.0                   1.0   \n",
       "47  0.0111  0.0273          0.145           0.85                  0.61   \n",
       "48  0.0125  0.6761         0.2428            0.0                0.4714   \n",
       "49   0.008  0.2854         0.4724         0.0625                0.1071   \n",
       "50  0.0074  0.3461         0.5121         0.0125                0.0357   \n",
       "51  0.0268  0.1934         0.2992         0.2625                0.2714   \n",
       "52  0.0059     0.0         0.5934            1.0                0.0071   \n",
       "53   0.006     0.0         0.6025            1.0                   0.0   \n",
       "54  0.0059  0.0006         0.6165            1.0                0.0071   \n",
       "55    0.01   0.009         0.3457         0.9375                0.1357   \n",
       "\n",
       "      shape    trend detection       data         method  \n",
       "0     0.945   1.7909    0.9563         uk        tabddpm  \n",
       "1     0.933   1.9067    0.9561         uk         tabsyn  \n",
       "2    0.7105   1.6598    0.9652         uk  tabsynflow_ot  \n",
       "3    1.4137   3.1704    0.8801         uk  tabsynflow_vp  \n",
       "4    0.5828   1.3824    0.9789         uk     tabvvfm_ot  \n",
       "5    0.6208   1.8081    0.9827         uk     tabvvfm_vp  \n",
       "6    1.6878   2.9758    0.8523         uk     tabtvfm_ot  \n",
       "7    1.9964   3.2241    0.8262         uk     tabtvfm_vp  \n",
       "8   40.5844  61.3026    0.0555     canada        tabddpm  \n",
       "9    3.2982   8.0524    0.8439     canada         tabsyn  \n",
       "10    3.742   8.7066    0.8404     canada  tabsynflow_ot  \n",
       "11   4.4505   8.1539     0.853     canada  tabsynflow_vp  \n",
       "12   3.2173    7.119     0.877     canada     tabvvfm_ot  \n",
       "13   3.1654   7.2878    0.8712     canada     tabvvfm_vp  \n",
       "14    3.744   7.4079    0.8659     canada     tabtvfm_ot  \n",
       "15   3.5851   7.5016     0.877     canada     tabtvfm_vp  \n",
       "16  50.7404  78.4654    0.0376       fiji        tabddpm  \n",
       "17     1.04   1.9604    0.9763       fiji         tabsyn  \n",
       "18   1.0265   2.0968    0.9815       fiji  tabsynflow_ot  \n",
       "19   2.2059   3.7397     0.955       fiji  tabsynflow_vp  \n",
       "20   0.7977   1.5561    0.9821       fiji     tabvvfm_ot  \n",
       "21    0.753   1.5837    0.9859       fiji     tabvvfm_vp  \n",
       "22    1.484   2.3144    0.9746       fiji     tabtvfm_ot  \n",
       "23   1.6956   2.6089    0.9737       fiji     tabtvfm_vp  \n",
       "24   24.279   45.186    0.4347     rwanda        tabddpm  \n",
       "25   0.9398   1.3748    0.9824     rwanda         tabsyn  \n",
       "26   0.8238   1.4298    0.9779     rwanda  tabsynflow_ot  \n",
       "27   1.4467   2.1755    0.9632     rwanda  tabsynflow_vp  \n",
       "28   0.5619   1.0061    0.9932     rwanda     tabvvfm_ot  \n",
       "29   0.5055   1.1381    0.9972     rwanda     tabvvfm_vp  \n",
       "30   0.5692   1.1247     0.987     rwanda     tabtvfm_ot  \n",
       "31   0.6621   1.2472    0.9866     rwanda     tabtvfm_vp  \n",
       "32   0.3439   0.6124     0.992  indonesia        tabddpm  \n",
       "33   0.4564   0.7837    0.9891  indonesia         tabsyn  \n",
       "34   0.2055   0.4325    0.9983  indonesia  tabsynflow_ot  \n",
       "35   0.3967   0.7694    0.9887  indonesia  tabsynflow_vp  \n",
       "36   0.2866   0.7165    0.9898  indonesia     tabvvfm_ot  \n",
       "37   0.3687   0.9461    0.9808  indonesia     tabvvfm_vp  \n",
       "38    0.344   0.7846    0.9886  indonesia     tabtvfm_ot  \n",
       "39   0.3978   0.9527    0.9828  indonesia     tabtvfm_vp  \n",
       "40   1.5637   3.6367    0.9427     adulta        tabddpm  \n",
       "41   0.9861   2.1067    0.9704     adulta         tabsyn  \n",
       "42   0.8022   2.0677    0.9826     adulta  tabsynflow_ot  \n",
       "43   1.4579   3.0163    0.9458     adulta  tabsynflow_vp  \n",
       "44     1.22    2.823    0.9639     adulta     tabvvfm_ot  \n",
       "45   1.1104   2.7543    0.9881     adulta     tabvvfm_vp  \n",
       "46    4.526   7.6053    0.6936     adulta     tabtvfm_ot  \n",
       "47   1.3237    2.836    0.9607     adulta     tabtvfm_vp  \n",
       "48   1.1612   2.3848    0.9748      churn        tabddpm  \n",
       "49   1.0421   2.4111    0.9957      churn         tabsyn  \n",
       "50   0.9773   2.2187    0.9949      churn  tabsynflow_ot  \n",
       "51   2.3132   4.6026      0.87      churn  tabsynflow_vp  \n",
       "52   2.7246   8.0029    0.9222      churn     tabvvfm_ot  \n",
       "53   2.5466   6.9639     0.927      churn     tabvvfm_vp  \n",
       "54   1.6025   4.3312    0.9778      churn     tabtvfm_ot  \n",
       "55   1.7049   3.9839    0.9662      churn     tabtvfm_vp  "
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "3ce617ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "algo_mapping = {\n",
    "    'tabddpm': 'TabDDPM',\n",
    "    'tabsyn': 'TabSyn',\n",
    "    'tabsynflow_ot': 'TabSynFlow-OT',\n",
    "    'tabsynflow_vp': 'TabSynFlow-VP',\n",
    "    'tabvvfm_ot' : 'TabbyFlow-OT',\n",
    "    'tabvvfm_vp' : 'TabbyFlow-VP',\n",
    "    'tabtvfm_ot' : 'TabbyFlow-OT (T)',\n",
    "    'tabtvfm_vp' : 'TabbyFlow-VP (T)'\n",
    "}\n",
    "\n",
    "dataset_mapping = {\n",
    "    'uk': 'UK',\n",
    "    'indonesia': 'Indonesia',\n",
    "    'canada': 'Canada',\n",
    "    'fiji': 'Fiji',\n",
    "    'rwanda': 'Rwanda',\n",
    "    'adulta': 'Adult',\n",
    "    'churn': 'Churn'\n",
    "}\n",
    "\n",
    "res_mean['method'] = res_mean['method'].map(algo_mapping)\n",
    "res_std['method'] = res_std['method'].map(algo_mapping)\n",
    "\n",
    "res_mean['data'] = res_mean['data'].map(dataset_mapping)\n",
    "res_std['data'] = res_std['data'].map(dataset_mapping)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "8023c7c8",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllllll}\n",
      "\\toprule\n",
      "method & TabDDPM & TabSyn & TabSynFlow-OT & TabSynFlow-VP & TabbyFlow-OT & TabbyFlow-VP \\\\\n",
      "data &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "UK & 0.0015±0.0002 & 0.005±0.0004 & 0.0033±0.0003 & 0.0061±0.0003 & 0.0067±0.0012 & 0.0081±0.0011 \\\\\n",
      "Canada & 0.3346±0.0007 & 0.0141±0.0004 & 0.0141±0.0003 & 0.0154±0.0002 & 0.0223±0.0005 & 0.0225±0.0003 \\\\\n",
      "Fiji & 0.3333±0.0006 & 0.0055±0.0003 & 0.0049±0.0004 & 0.0069±0.0004 & 0.0085±0.0014 & 0.009±0.0014 \\\\\n",
      "Rwanda & 0.3636±0.0018 & 0.0048±0.0007 & 0.0036±0.0004 & 0.0049±0.0003 & 0.0063±0.0008 & 0.0084±0.0007 \\\\\n",
      "Indonesia & 0.0012±0.0003 & 0.003±0.0002 & 0.0016±0.0002 & 0.0022±0.0002 & 0.0062±0.001 & 0.0074±0.001 \\\\\n",
      "Adult & 0.0039±0.0002 & 0.0037±0.0002 & 0.0028±0.0001 & 0.0039±0.0001 & 0.0074±0.0004 & 0.0074±0.0004 \\\\\n",
      "Churn & 0.0029±0.0005 & 0.0055±0.0005 & 0.0045±0.0004 & 0.0048±0.0005 & 0.0361±0.0006 & 0.0285±0.0006 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "dataset_order = ['UK', 'Canada', 'Fiji', 'Rwanda', 'Indonesia', 'Adult', 'Churn']\n",
    "\n",
    "param_eval = 'WD'\n",
    "mean1 = res_mean.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "std1 = res_std.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "all_res = mean1.round(2).astype(str) + '±' + std1.round(2).astype(str)\n",
    "# all_res = mean1.round(4).astype(str)\n",
    "colna = ['TabDDPM','TabSyn','TabSynFlow-OT','TabSynFlow-VP','TabbyFlow-OT','TabbyFlow-VP']\n",
    "print(all_res[dataset_order].transpose()[colna].to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "9591b5a3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>data</th>\n",
       "      <th>Adult</th>\n",
       "      <th>Canada</th>\n",
       "      <th>Churn</th>\n",
       "      <th>Fiji</th>\n",
       "      <th>Indonesia</th>\n",
       "      <th>Rwanda</th>\n",
       "      <th>UK</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>TabDDPM</th>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.3346</td>\n",
       "      <td>0.0029</td>\n",
       "      <td>0.3333</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.3636</td>\n",
       "      <td>0.0015</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabSyn</th>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.0141</td>\n",
       "      <td>0.0055</td>\n",
       "      <td>0.0055</td>\n",
       "      <td>0.003</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabSynFlow-OT</th>\n",
       "      <td>0.0028</td>\n",
       "      <td>0.0141</td>\n",
       "      <td>0.0045</td>\n",
       "      <td>0.0049</td>\n",
       "      <td>0.0016</td>\n",
       "      <td>0.0036</td>\n",
       "      <td>0.0033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabSynFlow-VP</th>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.0154</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0069</td>\n",
       "      <td>0.0022</td>\n",
       "      <td>0.0049</td>\n",
       "      <td>0.0061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabbyFlow-OT</th>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0223</td>\n",
       "      <td>0.0361</td>\n",
       "      <td>0.0085</td>\n",
       "      <td>0.0062</td>\n",
       "      <td>0.0063</td>\n",
       "      <td>0.0067</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabbyFlow-OT (T)</th>\n",
       "      <td>0.0333</td>\n",
       "      <td>0.0202</td>\n",
       "      <td>0.0135</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>0.0068</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabbyFlow-VP</th>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0225</td>\n",
       "      <td>0.0285</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0084</td>\n",
       "      <td>0.0081</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TabbyFlow-VP (T)</th>\n",
       "      <td>0.0066</td>\n",
       "      <td>0.0198</td>\n",
       "      <td>0.012</td>\n",
       "      <td>0.0087</td>\n",
       "      <td>0.0067</td>\n",
       "      <td>0.0077</td>\n",
       "      <td>0.0086</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "data               Adult  Canada   Churn    Fiji Indonesia  Rwanda      UK\n",
       "method                                                                    \n",
       "TabDDPM           0.0039  0.3346  0.0029  0.3333    0.0012  0.3636  0.0015\n",
       "TabSyn            0.0037  0.0141  0.0055  0.0055     0.003  0.0048   0.005\n",
       "TabSynFlow-OT     0.0028  0.0141  0.0045  0.0049    0.0016  0.0036  0.0033\n",
       "TabSynFlow-VP     0.0039  0.0154  0.0048  0.0069    0.0022  0.0049  0.0061\n",
       "TabbyFlow-OT      0.0074  0.0223  0.0361  0.0085    0.0062  0.0063  0.0067\n",
       "TabbyFlow-OT (T)  0.0333  0.0202  0.0135   0.008    0.0059  0.0094  0.0068\n",
       "TabbyFlow-VP      0.0074  0.0225  0.0285   0.009    0.0074  0.0084  0.0081\n",
       "TabbyFlow-VP (T)  0.0066  0.0198   0.012  0.0087    0.0067  0.0077  0.0086"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_res"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "05c07c95",
   "metadata": {},
   "source": [
    "### Quality measurements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d638fe69",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dir = f'{os.getcwd()}/eval/combine/'\n",
    "data_name = ['uk', 'canada', 'fiji', 'rwanda', 'indonesia', 'adulta', 'churn']\n",
    "algo = ['tabddpm', 'tabsyn', 'tabsynflow_ot','tabsynflow_vp', 'tabvvfm_ot', 'tabvvfm_vp']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "3a945e6b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "resq_mean = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_{j}_quality.csv')\n",
    "        aa = (aa.mean()* 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_mean = pd.concat([resq_mean,aa], axis=1)\n",
    "    \n",
    "resq_mean = resq_mean.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1adfcfbe",
   "metadata": {},
   "outputs": [],
   "source": [
    "resq_std = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_{j}_quality.csv')\n",
    "        aa = (aa.std() * 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_std = pd.concat([resq_std,aa], axis=1)\n",
    "    \n",
    "resq_std = resq_std.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "46c2b44b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sample_seed</th>\n",
       "      <th>alpha_pr</th>\n",
       "      <th>beta_re</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>950.0</td>\n",
       "      <td>96.95</td>\n",
       "      <td>68.84</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.67</td>\n",
       "      <td>67.58</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.05</td>\n",
       "      <td>67.22</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.5</td>\n",
       "      <td>62.92</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.1</td>\n",
       "      <td>69.47</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.82</td>\n",
       "      <td>67.3</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>950.0</td>\n",
       "      <td>30.2</td>\n",
       "      <td>0.45</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.14</td>\n",
       "      <td>33.39</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.65</td>\n",
       "      <td>32.47</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.18</td>\n",
       "      <td>28.66</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.67</td>\n",
       "      <td>38.62</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.9</td>\n",
       "      <td>35.83</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>950.0</td>\n",
       "      <td>50.99</td>\n",
       "      <td>0.02</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.46</td>\n",
       "      <td>56.79</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.72</td>\n",
       "      <td>55.18</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.47</td>\n",
       "      <td>49.28</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.64</td>\n",
       "      <td>59.78</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.25</td>\n",
       "      <td>57.79</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>950.0</td>\n",
       "      <td>49.93</td>\n",
       "      <td>0.87</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>950.0</td>\n",
       "      <td>97.97</td>\n",
       "      <td>84.52</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.11</td>\n",
       "      <td>84.18</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.24</td>\n",
       "      <td>82.9</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.85</td>\n",
       "      <td>86.26</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.03</td>\n",
       "      <td>85.24</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.96</td>\n",
       "      <td>96.35</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.5</td>\n",
       "      <td>96.47</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.49</td>\n",
       "      <td>96.46</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.35</td>\n",
       "      <td>96.36</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.41</td>\n",
       "      <td>95.27</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.66</td>\n",
       "      <td>95.16</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>950.0</td>\n",
       "      <td>95.42</td>\n",
       "      <td>45.35</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.5</td>\n",
       "      <td>48.78</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.33</td>\n",
       "      <td>47.57</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.03</td>\n",
       "      <td>45.58</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.27</td>\n",
       "      <td>50.22</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>950.0</td>\n",
       "      <td>99.19</td>\n",
       "      <td>48.93</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>950.0</td>\n",
       "      <td>96.87</td>\n",
       "      <td>54.22</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabddpm</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.56</td>\n",
       "      <td>50.93</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.99</td>\n",
       "      <td>50.96</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>950.0</td>\n",
       "      <td>97.09</td>\n",
       "      <td>51.33</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.52</td>\n",
       "      <td>48.3</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>950.0</td>\n",
       "      <td>98.81</td>\n",
       "      <td>49.01</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   sample_seed alpha_pr beta_re       data         method\n",
       "0        950.0    96.95   68.84         uk        tabddpm\n",
       "1        950.0    98.67   67.58         uk         tabsyn\n",
       "2        950.0    99.05   67.22         uk  tabsynflow_ot\n",
       "3        950.0     99.5   62.92         uk  tabsynflow_vp\n",
       "4        950.0     99.1   69.47         uk     tabvvfm_ot\n",
       "5        950.0    98.82    67.3         uk     tabvvfm_vp\n",
       "6        950.0     30.2    0.45     canada        tabddpm\n",
       "7        950.0    98.14   33.39     canada         tabsyn\n",
       "8        950.0    98.65   32.47     canada  tabsynflow_ot\n",
       "9        950.0    98.18   28.66     canada  tabsynflow_vp\n",
       "10       950.0    98.67   38.62     canada     tabvvfm_ot\n",
       "11       950.0     98.9   35.83     canada     tabvvfm_vp\n",
       "12       950.0    50.99    0.02       fiji        tabddpm\n",
       "13       950.0    98.46   56.79       fiji         tabsyn\n",
       "14       950.0    98.72   55.18       fiji  tabsynflow_ot\n",
       "15       950.0    99.47   49.28       fiji  tabsynflow_vp\n",
       "16       950.0    98.64   59.78       fiji     tabvvfm_ot\n",
       "17       950.0    99.25   57.79       fiji     tabvvfm_vp\n",
       "18       950.0    49.93    0.87     rwanda        tabddpm\n",
       "19       950.0    97.97   84.52     rwanda         tabsyn\n",
       "20       950.0    99.11   84.18     rwanda  tabsynflow_ot\n",
       "21       950.0    98.24    82.9     rwanda  tabsynflow_vp\n",
       "22       950.0    98.85   86.26     rwanda     tabvvfm_ot\n",
       "23       950.0    99.03   85.24     rwanda     tabvvfm_vp\n",
       "24       950.0    98.96   96.35  indonesia        tabddpm\n",
       "25       950.0     98.5   96.47  indonesia         tabsyn\n",
       "26       950.0    99.49   96.46  indonesia  tabsynflow_ot\n",
       "27       950.0    99.35   96.36  indonesia  tabsynflow_vp\n",
       "28       950.0    99.41   95.27  indonesia     tabvvfm_ot\n",
       "29       950.0    99.66   95.16  indonesia     tabvvfm_vp\n",
       "30       950.0    95.42   45.35     adulta        tabddpm\n",
       "31       950.0     98.5   48.78     adulta         tabsyn\n",
       "32       950.0    99.33   47.57     adulta  tabsynflow_ot\n",
       "33       950.0    99.03   45.58     adulta  tabsynflow_vp\n",
       "34       950.0    99.27   50.22     adulta     tabvvfm_ot\n",
       "35       950.0    99.19   48.93     adulta     tabvvfm_vp\n",
       "36       950.0    96.87   54.22      churn        tabddpm\n",
       "37       950.0    98.56   50.93      churn         tabsyn\n",
       "38       950.0    98.99   50.96      churn  tabsynflow_ot\n",
       "39       950.0    97.09   51.33      churn  tabsynflow_vp\n",
       "40       950.0    98.52    48.3      churn     tabvvfm_ot\n",
       "41       950.0    98.81   49.01      churn     tabvvfm_vp"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "resq_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d7e0a1eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "algo_mapping = {\n",
    "    'tabddpm': 'TabDDPM',\n",
    "    'tabsyn': 'TabSyn',\n",
    "    'tabsynflow_ot': 'TabSynFlow-OT',\n",
    "    'tabsynflow_vp': 'TabSynFlow-VP',\n",
    "    'tabvvfm_ot' : 'TabbyFlow-OT',\n",
    "    'tabvvfm_vp' : 'TabbyFlow-VP',\n",
    "    'tabtvfm_ot' : 'TabbyFlow-OT (T)',\n",
    "    'tabtvfm_vp' : 'TabbyFlow-VP (T)'\n",
    "}\n",
    "\n",
    "dataset_mapping = {\n",
    "    'uk': 'UK',\n",
    "    'indonesia': 'Indonesia',\n",
    "    'canada': 'Canada',\n",
    "    'fiji': 'Fiji',\n",
    "    'rwanda': 'Rwanda',\n",
    "    'adulta': 'Adult',\n",
    "    'churn': 'Churn'\n",
    "}\n",
    "\n",
    "resq_mean['method'] = resq_mean['method'].map(algo_mapping)\n",
    "resq_std['method'] = resq_std['method'].map(algo_mapping)\n",
    "\n",
    "resq_mean['data'] = resq_mean['data'].map(dataset_mapping)\n",
    "resq_std['data'] = resq_std['data'].map(dataset_mapping)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "6d38aa61",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllllll}\n",
      "\\toprule\n",
      "method & TabDDPM & TabSyn & TabSynFlow-OT & TabSynFlow-VP & TabbyFlow-OT & TabbyFlow-VP \\\\\n",
      "data &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "UK & 68.84±0.13 & 67.58±0.15 & 67.22±0.12 & 62.92±0.15 & 69.47±0.18 & 67.3±0.25 \\\\\n",
      "Canada & 0.45±0.04 & 33.39±0.19 & 32.47±0.28 & 28.66±0.24 & 38.62±0.29 & 35.83±0.3 \\\\\n",
      "Fiji & 0.02±0.01 & 56.79±0.17 & 55.18±0.19 & 49.28±0.25 & 59.78±0.17 & 57.79±0.24 \\\\\n",
      "Rwanda & 0.87±0.28 & 84.52±0.2 & 84.18±0.22 & 82.9±0.2 & 86.26±0.18 & 85.24±0.19 \\\\\n",
      "Indonesia & 96.35±0.06 & 96.47±0.04 & 96.46±0.07 & 96.36±0.07 & 95.27±0.15 & 95.16±0.14 \\\\\n",
      "Adult & 45.35±0.19 & 48.78±0.28 & 47.57±0.18 & 45.58±0.24 & 50.22±0.25 & 48.93±0.22 \\\\\n",
      "Churn & 54.22±0.67 & 50.93±0.51 & 50.96±0.45 & 51.33±0.34 & 48.3±0.43 & 49.01±0.67 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "dataset_order = ['UK', 'Canada', 'Fiji', 'Rwanda', 'Indonesia', 'Adult', 'Churn']\n",
    "'alpha_pr', 'beta_re'\n",
    "param_eval = 'beta_re'\n",
    "meanq1 = resq_mean.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "stdq1 = resq_std.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "all_resq = meanq1.round(2).astype(str) + '±' + stdq1.round(2).astype(str)\n",
    "# all_res = mean1.round(4).astype(str)\n",
    "colna = ['TabDDPM','TabSyn','TabSynFlow-OT', 'TabSynFlow-VP','TabbyFlow-OT','TabbyFlow-VP'] # ,'TabSynFlow-VP'\n",
    "print(all_resq[dataset_order].transpose()[colna].to_latex())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fce2c708",
   "metadata": {},
   "source": [
    "### Ablation on transformers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "56d39e57",
   "metadata": {},
   "outputs": [],
   "source": [
    "algo2 = ['ot','vp']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "347716b8",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "res2_mean = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo2:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_tabtvfm_{j}_urisk.csv').mean().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = f'tabtvfm_{j}'\n",
    "        res2_mean = pd.concat([res2_mean,aa], axis=1)\n",
    "\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/tabvvfm_{j}_urisk.csv').mean().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = f'tabvvfm_{j}'\n",
    "        res2_mean = pd.concat([res2_mean,aa], axis=1)\n",
    "\n",
    "res2_mean = res2_mean.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "99d36c2f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.9487</td>\n",
       "      <td>0.8619</td>\n",
       "      <td>0.532</td>\n",
       "      <td>0.4716</td>\n",
       "      <td>0.7809</td>\n",
       "      <td>0.4716</td>\n",
       "      <td>0.0068</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.977</td>\n",
       "      <td>0.017</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1077</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>0.9831</td>\n",
       "      <td>0.9702</td>\n",
       "      <td>0.8523</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.9714</td>\n",
       "      <td>0.9014</td>\n",
       "      <td>0.6271</td>\n",
       "      <td>0.4889</td>\n",
       "      <td>0.8333</td>\n",
       "      <td>0.4889</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.9556</td>\n",
       "      <td>0.8774</td>\n",
       "      <td>0.5421</td>\n",
       "      <td>0.482</td>\n",
       "      <td>0.7917</td>\n",
       "      <td>0.482</td>\n",
       "      <td>0.0086</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9539</td>\n",
       "      <td>0.0195</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0438</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8786</td>\n",
       "      <td>0.98</td>\n",
       "      <td>0.9678</td>\n",
       "      <td>0.8262</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.9759</td>\n",
       "      <td>0.9017</td>\n",
       "      <td>0.5422</td>\n",
       "      <td>0.4765</td>\n",
       "      <td>0.8066</td>\n",
       "      <td>0.4765</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.9406</td>\n",
       "      <td>0.8496</td>\n",
       "      <td>0.566</td>\n",
       "      <td>0.335</td>\n",
       "      <td>0.7854</td>\n",
       "      <td>0.335</td>\n",
       "      <td>0.0202</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.833</td>\n",
       "      <td>0.0138</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2263</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.5452</td>\n",
       "      <td>0.9626</td>\n",
       "      <td>0.9259</td>\n",
       "      <td>0.8659</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.9277</td>\n",
       "      <td>0.839</td>\n",
       "      <td>0.6008</td>\n",
       "      <td>0.3373</td>\n",
       "      <td>0.7892</td>\n",
       "      <td>0.3373</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.9259</td>\n",
       "      <td>0.8324</td>\n",
       "      <td>0.4608</td>\n",
       "      <td>0.3209</td>\n",
       "      <td>0.7397</td>\n",
       "      <td>0.3209</td>\n",
       "      <td>0.0198</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8379</td>\n",
       "      <td>0.0126</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2035</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.4976</td>\n",
       "      <td>0.9641</td>\n",
       "      <td>0.925</td>\n",
       "      <td>0.877</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.9606</td>\n",
       "      <td>0.8743</td>\n",
       "      <td>0.4067</td>\n",
       "      <td>0.3008</td>\n",
       "      <td>0.7472</td>\n",
       "      <td>0.3008</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.897</td>\n",
       "      <td>0.7894</td>\n",
       "      <td>0.5309</td>\n",
       "      <td>0.5727</td>\n",
       "      <td>0.7391</td>\n",
       "      <td>0.5727</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9712</td>\n",
       "      <td>0.0146</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.049</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8611</td>\n",
       "      <td>0.9852</td>\n",
       "      <td>0.9769</td>\n",
       "      <td>0.9746</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.8782</td>\n",
       "      <td>0.7966</td>\n",
       "      <td>0.5041</td>\n",
       "      <td>0.5705</td>\n",
       "      <td>0.7263</td>\n",
       "      <td>0.5705</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.8773</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.5708</td>\n",
       "      <td>0.5606</td>\n",
       "      <td>0.7394</td>\n",
       "      <td>0.5606</td>\n",
       "      <td>0.0087</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9802</td>\n",
       "      <td>0.0168</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.062</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.825</td>\n",
       "      <td>0.983</td>\n",
       "      <td>0.9739</td>\n",
       "      <td>0.9737</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.918</td>\n",
       "      <td>0.823</td>\n",
       "      <td>0.4943</td>\n",
       "      <td>0.5588</td>\n",
       "      <td>0.7451</td>\n",
       "      <td>0.5588</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.8403</td>\n",
       "      <td>0.8031</td>\n",
       "      <td>0.5891</td>\n",
       "      <td>0.5359</td>\n",
       "      <td>0.7442</td>\n",
       "      <td>0.5359</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9693</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3424</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.1925</td>\n",
       "      <td>0.9943</td>\n",
       "      <td>0.9888</td>\n",
       "      <td>0.987</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.8137</td>\n",
       "      <td>0.791</td>\n",
       "      <td>0.5806</td>\n",
       "      <td>0.5379</td>\n",
       "      <td>0.7284</td>\n",
       "      <td>0.5379</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.8072</td>\n",
       "      <td>0.7807</td>\n",
       "      <td>0.5748</td>\n",
       "      <td>0.5306</td>\n",
       "      <td>0.7209</td>\n",
       "      <td>0.5306</td>\n",
       "      <td>0.0077</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9765</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.2357</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.3725</td>\n",
       "      <td>0.9934</td>\n",
       "      <td>0.9875</td>\n",
       "      <td>0.9866</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.8364</td>\n",
       "      <td>0.8043</td>\n",
       "      <td>0.5668</td>\n",
       "      <td>0.518</td>\n",
       "      <td>0.7358</td>\n",
       "      <td>0.518</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.8286</td>\n",
       "      <td>0.7481</td>\n",
       "      <td>0.3925</td>\n",
       "      <td>0.405</td>\n",
       "      <td>0.6564</td>\n",
       "      <td>0.405</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0211</td>\n",
       "      <td>0.9822</td>\n",
       "      <td>0.1025</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2667</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.425</td>\n",
       "      <td>0.9966</td>\n",
       "      <td>0.9922</td>\n",
       "      <td>0.9886</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.836</td>\n",
       "      <td>0.7509</td>\n",
       "      <td>0.4145</td>\n",
       "      <td>0.4114</td>\n",
       "      <td>0.6671</td>\n",
       "      <td>0.4114</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.8199</td>\n",
       "      <td>0.7388</td>\n",
       "      <td>0.3959</td>\n",
       "      <td>0.3998</td>\n",
       "      <td>0.6515</td>\n",
       "      <td>0.3998</td>\n",
       "      <td>0.0067</td>\n",
       "      <td>0.0211</td>\n",
       "      <td>0.9817</td>\n",
       "      <td>0.1033</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.6583</td>\n",
       "      <td>0.996</td>\n",
       "      <td>0.9905</td>\n",
       "      <td>0.9828</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.821</td>\n",
       "      <td>0.7241</td>\n",
       "      <td>0.4013</td>\n",
       "      <td>0.3918</td>\n",
       "      <td>0.6488</td>\n",
       "      <td>0.3918</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.7896</td>\n",
       "      <td>0.6677</td>\n",
       "      <td>0.2337</td>\n",
       "      <td>0.5432</td>\n",
       "      <td>0.5637</td>\n",
       "      <td>0.5432</td>\n",
       "      <td>0.0333</td>\n",
       "      <td>0.0003</td>\n",
       "      <td>0.9318</td>\n",
       "      <td>0.0338</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9547</td>\n",
       "      <td>0.9239</td>\n",
       "      <td>0.6936</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.9361</td>\n",
       "      <td>0.8383</td>\n",
       "      <td>0.5417</td>\n",
       "      <td>0.5443</td>\n",
       "      <td>0.772</td>\n",
       "      <td>0.5443</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.8918</td>\n",
       "      <td>0.7872</td>\n",
       "      <td>0.5522</td>\n",
       "      <td>0.5609</td>\n",
       "      <td>0.7437</td>\n",
       "      <td>0.5609</td>\n",
       "      <td>0.0066</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9824</td>\n",
       "      <td>0.0111</td>\n",
       "      <td>0.0273</td>\n",
       "      <td>0.145</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.9868</td>\n",
       "      <td>0.9716</td>\n",
       "      <td>0.9607</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.9485</td>\n",
       "      <td>0.8384</td>\n",
       "      <td>0.4875</td>\n",
       "      <td>0.5037</td>\n",
       "      <td>0.7581</td>\n",
       "      <td>0.5037</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.9809</td>\n",
       "      <td>0.9554</td>\n",
       "      <td>0.6852</td>\n",
       "      <td>0.1183</td>\n",
       "      <td>0.8738</td>\n",
       "      <td>0.1249</td>\n",
       "      <td>0.0135</td>\n",
       "      <td>-0.0001</td>\n",
       "      <td>0.9663</td>\n",
       "      <td>0.0059</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.6165</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0071</td>\n",
       "      <td>0.984</td>\n",
       "      <td>0.9567</td>\n",
       "      <td>0.9778</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.9795</td>\n",
       "      <td>0.9518</td>\n",
       "      <td>0.4586</td>\n",
       "      <td>0.0646</td>\n",
       "      <td>0.7966</td>\n",
       "      <td>0.0773</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.9717</td>\n",
       "      <td>0.9428</td>\n",
       "      <td>0.5872</td>\n",
       "      <td>0.1391</td>\n",
       "      <td>0.8339</td>\n",
       "      <td>0.1427</td>\n",
       "      <td>0.012</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>0.9707</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.3457</td>\n",
       "      <td>0.9375</td>\n",
       "      <td>0.1357</td>\n",
       "      <td>0.983</td>\n",
       "      <td>0.9602</td>\n",
       "      <td>0.9662</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>0.9807</td>\n",
       "      <td>0.9523</td>\n",
       "      <td>0.487</td>\n",
       "      <td>0.0646</td>\n",
       "      <td>0.8066</td>\n",
       "      <td>0.0753</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   ROC_uni ROC_biv     CIO    TCAP Utility    Risk      WD     MMD  KS_sim  \\\n",
       "0   0.9487  0.8619   0.532  0.4716  0.7809  0.4716  0.0068  0.0001   0.977   \n",
       "1   0.9714  0.9014  0.6271  0.4889  0.8333  0.4889     NaN     NaN     NaN   \n",
       "2   0.9556  0.8774  0.5421   0.482  0.7917   0.482  0.0086  0.0001  0.9539   \n",
       "3   0.9759  0.9017  0.5422  0.4765  0.8066  0.4765     NaN     NaN     NaN   \n",
       "4   0.9406  0.8496   0.566   0.335  0.7854   0.335  0.0202    -0.0   0.833   \n",
       "5   0.9277   0.839  0.6008  0.3373  0.7892  0.3373     NaN     NaN     NaN   \n",
       "6   0.9259  0.8324  0.4608  0.3209  0.7397  0.3209  0.0198     0.0  0.8379   \n",
       "7   0.9606  0.8743  0.4067  0.3008  0.7472  0.3008     NaN     NaN     NaN   \n",
       "8    0.897  0.7894  0.5309  0.5727  0.7391  0.5727   0.008     0.0  0.9712   \n",
       "9   0.8782  0.7966  0.5041  0.5705  0.7263  0.5705     NaN     NaN     NaN   \n",
       "10  0.8773    0.77  0.5708  0.5606  0.7394  0.5606  0.0087     0.0  0.9802   \n",
       "11   0.918   0.823  0.4943  0.5588  0.7451  0.5588     NaN     NaN     NaN   \n",
       "12  0.8403  0.8031  0.5891  0.5359  0.7442  0.5359  0.0094     0.0  0.9693   \n",
       "13  0.8137   0.791  0.5806  0.5379  0.7284  0.5379     NaN     NaN     NaN   \n",
       "14  0.8072  0.7807  0.5748  0.5306  0.7209  0.5306  0.0077  0.0001  0.9765   \n",
       "15  0.8364  0.8043  0.5668   0.518  0.7358   0.518     NaN     NaN     NaN   \n",
       "16  0.8286  0.7481  0.3925   0.405  0.6564   0.405  0.0059  0.0211  0.9822   \n",
       "17   0.836  0.7509  0.4145  0.4114  0.6671  0.4114     NaN     NaN     NaN   \n",
       "18  0.8199  0.7388  0.3959  0.3998  0.6515  0.3998  0.0067  0.0211  0.9817   \n",
       "19   0.821  0.7241  0.4013  0.3918  0.6488  0.3918     NaN     NaN     NaN   \n",
       "20  0.7896  0.6677  0.2337  0.5432  0.5637  0.5432  0.0333  0.0003  0.9318   \n",
       "21  0.9361  0.8383  0.5417  0.5443   0.772  0.5443     NaN     NaN     NaN   \n",
       "22  0.8918  0.7872  0.5522  0.5609  0.7437  0.5609  0.0066     0.0  0.9824   \n",
       "23  0.9485  0.8384  0.4875  0.5037  0.7581  0.5037     NaN     NaN     NaN   \n",
       "24  0.9809  0.9554  0.6852  0.1183  0.8738  0.1249  0.0135 -0.0001  0.9663   \n",
       "25  0.9795  0.9518  0.4586  0.0646  0.7966  0.0773     NaN     NaN     NaN   \n",
       "26  0.9717  0.9428  0.5872  0.1391  0.8339  0.1427   0.012    -0.0  0.9707   \n",
       "27  0.9807  0.9523   0.487  0.0646  0.8066  0.0753     NaN     NaN     NaN   \n",
       "\n",
       "   tvd_sim KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject  \\\n",
       "0    0.017     0.0         0.1077            1.0                   0.8   \n",
       "1      NaN     NaN            NaN            NaN                   NaN   \n",
       "2   0.0195     0.0         0.0438            1.0                0.8786   \n",
       "3      NaN     NaN            NaN            NaN                   NaN   \n",
       "4   0.0138     0.0         0.2263            1.0                0.5452   \n",
       "5      NaN     NaN            NaN            NaN                   NaN   \n",
       "6   0.0126     0.0         0.2035            1.0                0.4976   \n",
       "7      NaN     NaN            NaN            NaN                   NaN   \n",
       "8   0.0146     0.0          0.049            1.0                0.8611   \n",
       "9      NaN     NaN            NaN            NaN                   NaN   \n",
       "10  0.0168     0.0          0.062            1.0                 0.825   \n",
       "11     NaN     NaN            NaN            NaN                   NaN   \n",
       "12  0.0048     0.0         0.3424            1.0                0.1925   \n",
       "13     NaN     NaN            NaN            NaN                   NaN   \n",
       "14  0.0059  0.0001         0.2357            1.0                0.3725   \n",
       "15     NaN     NaN            NaN            NaN                   NaN   \n",
       "16  0.1025     0.0         0.2667            1.0                 0.425   \n",
       "17     NaN     NaN            NaN            NaN                   NaN   \n",
       "18  0.1033     0.0         0.1159            1.0                0.6583   \n",
       "19     NaN     NaN            NaN            NaN                   NaN   \n",
       "20  0.0338     0.0            0.0            1.0                   1.0   \n",
       "21     NaN     NaN            NaN            NaN                   NaN   \n",
       "22  0.0111  0.0273          0.145           0.85                  0.61   \n",
       "23     NaN     NaN            NaN            NaN                   NaN   \n",
       "24  0.0059  0.0006         0.6165            1.0                0.0071   \n",
       "25     NaN     NaN            NaN            NaN                   NaN   \n",
       "26    0.01   0.009         0.3457         0.9375                0.1357   \n",
       "27     NaN     NaN            NaN            NaN                   NaN   \n",
       "\n",
       "     shape   trend detection       data      method  \n",
       "0   0.9831  0.9702    0.8523         uk  tabtvfm_ot  \n",
       "1      NaN     NaN       NaN         uk  tabvvfm_ot  \n",
       "2     0.98  0.9678    0.8262         uk  tabtvfm_vp  \n",
       "3      NaN     NaN       NaN         uk  tabvvfm_vp  \n",
       "4   0.9626  0.9259    0.8659     canada  tabtvfm_ot  \n",
       "5      NaN     NaN       NaN     canada  tabvvfm_ot  \n",
       "6   0.9641   0.925     0.877     canada  tabtvfm_vp  \n",
       "7      NaN     NaN       NaN     canada  tabvvfm_vp  \n",
       "8   0.9852  0.9769    0.9746       fiji  tabtvfm_ot  \n",
       "9      NaN     NaN       NaN       fiji  tabvvfm_ot  \n",
       "10   0.983  0.9739    0.9737       fiji  tabtvfm_vp  \n",
       "11     NaN     NaN       NaN       fiji  tabvvfm_vp  \n",
       "12  0.9943  0.9888     0.987     rwanda  tabtvfm_ot  \n",
       "13     NaN     NaN       NaN     rwanda  tabvvfm_ot  \n",
       "14  0.9934  0.9875    0.9866     rwanda  tabtvfm_vp  \n",
       "15     NaN     NaN       NaN     rwanda  tabvvfm_vp  \n",
       "16  0.9966  0.9922    0.9886  indonesia  tabtvfm_ot  \n",
       "17     NaN     NaN       NaN  indonesia  tabvvfm_ot  \n",
       "18   0.996  0.9905    0.9828  indonesia  tabtvfm_vp  \n",
       "19     NaN     NaN       NaN  indonesia  tabvvfm_vp  \n",
       "20  0.9547  0.9239    0.6936     adulta  tabtvfm_ot  \n",
       "21     NaN     NaN       NaN     adulta  tabvvfm_ot  \n",
       "22  0.9868  0.9716    0.9607     adulta  tabtvfm_vp  \n",
       "23     NaN     NaN       NaN     adulta  tabvvfm_vp  \n",
       "24   0.984  0.9567    0.9778      churn  tabtvfm_ot  \n",
       "25     NaN     NaN       NaN      churn  tabvvfm_ot  \n",
       "26   0.983  0.9602    0.9662      churn  tabtvfm_vp  \n",
       "27     NaN     NaN       NaN      churn  tabvvfm_vp  "
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res2_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "9b85f557",
   "metadata": {},
   "outputs": [],
   "source": [
    "res2_std = pd.DataFrame()\n",
    "for i in data_name:\n",
    "    for j in algo2:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/anew_tabtvfm_{j}_urisk.csv').std().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = f'tabtvfm_{j}'\n",
    "        res2_std = pd.concat([res2_std,aa], axis=1)\n",
    "\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/tabvvfm_{j}_urisk.csv').std().round(4)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = f'tabvvfm_{j}'\n",
    "        res2_std = pd.concat([res2_std,aa], axis=1)\n",
    "\n",
    "res2_std = res2_std.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "1b698636",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.0018</td>\n",
       "      <td>0.0032</td>\n",
       "      <td>0.0516</td>\n",
       "      <td>0.0054</td>\n",
       "      <td>0.0172</td>\n",
       "      <td>0.0054</td>\n",
       "      <td>0.0011</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0041</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0396</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0293</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0023</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.053</td>\n",
       "      <td>0.0043</td>\n",
       "      <td>0.0191</td>\n",
       "      <td>0.0043</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0024</td>\n",
       "      <td>0.0027</td>\n",
       "      <td>0.0413</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.0139</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0227</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0336</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0028</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0027</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0576</td>\n",
       "      <td>0.0072</td>\n",
       "      <td>0.0197</td>\n",
       "      <td>0.0072</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>uk</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.0033</td>\n",
       "      <td>0.0038</td>\n",
       "      <td>0.0396</td>\n",
       "      <td>0.0164</td>\n",
       "      <td>0.0129</td>\n",
       "      <td>0.0164</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0013</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0385</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0362</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0033</td>\n",
       "      <td>0.0108</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.0529</td>\n",
       "      <td>0.0156</td>\n",
       "      <td>0.0178</td>\n",
       "      <td>0.0156</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.0026</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0551</td>\n",
       "      <td>0.0185</td>\n",
       "      <td>0.0187</td>\n",
       "      <td>0.0185</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0013</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0428</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0749</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0145</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.0035</td>\n",
       "      <td>0.0045</td>\n",
       "      <td>0.0549</td>\n",
       "      <td>0.0148</td>\n",
       "      <td>0.0188</td>\n",
       "      <td>0.0148</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>canada</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.0038</td>\n",
       "      <td>0.0029</td>\n",
       "      <td>0.0507</td>\n",
       "      <td>0.0091</td>\n",
       "      <td>0.0172</td>\n",
       "      <td>0.0091</td>\n",
       "      <td>0.0011</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0045</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0278</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.071</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0036</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.0047</td>\n",
       "      <td>0.0044</td>\n",
       "      <td>0.0559</td>\n",
       "      <td>0.0063</td>\n",
       "      <td>0.0205</td>\n",
       "      <td>0.0063</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.0042</td>\n",
       "      <td>0.003</td>\n",
       "      <td>0.0569</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0193</td>\n",
       "      <td>0.0048</td>\n",
       "      <td>0.0014</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0032</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0205</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0486</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0008</td>\n",
       "      <td>0.0029</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.0024</td>\n",
       "      <td>0.0629</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>0.0216</td>\n",
       "      <td>0.0074</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>fiji</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.0113</td>\n",
       "      <td>0.0079</td>\n",
       "      <td>0.0709</td>\n",
       "      <td>0.0098</td>\n",
       "      <td>0.027</td>\n",
       "      <td>0.0098</td>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0046</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0507</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0654</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0065</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.0148</td>\n",
       "      <td>0.0091</td>\n",
       "      <td>0.059</td>\n",
       "      <td>0.0139</td>\n",
       "      <td>0.0231</td>\n",
       "      <td>0.0139</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.0087</td>\n",
       "      <td>0.006</td>\n",
       "      <td>0.0636</td>\n",
       "      <td>0.013</td>\n",
       "      <td>0.0225</td>\n",
       "      <td>0.013</td>\n",
       "      <td>0.0007</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0038</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0482</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0678</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0052</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.0079</td>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.0532</td>\n",
       "      <td>0.0105</td>\n",
       "      <td>0.0185</td>\n",
       "      <td>0.0105</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>rwanda</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.0056</td>\n",
       "      <td>0.0035</td>\n",
       "      <td>0.0294</td>\n",
       "      <td>0.0199</td>\n",
       "      <td>0.0096</td>\n",
       "      <td>0.0199</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0641</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0851</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0068</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.0044</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0148</td>\n",
       "      <td>0.0149</td>\n",
       "      <td>0.0046</td>\n",
       "      <td>0.0149</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.0022</td>\n",
       "      <td>0.0043</td>\n",
       "      <td>0.0299</td>\n",
       "      <td>0.0208</td>\n",
       "      <td>0.0097</td>\n",
       "      <td>0.0208</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0034</td>\n",
       "      <td>0.0002</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0365</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0971</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0097</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.0033</td>\n",
       "      <td>0.0041</td>\n",
       "      <td>0.0334</td>\n",
       "      <td>0.0244</td>\n",
       "      <td>0.0103</td>\n",
       "      <td>0.0244</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>indonesia</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.005</td>\n",
       "      <td>0.0034</td>\n",
       "      <td>0.032</td>\n",
       "      <td>0.0139</td>\n",
       "      <td>0.0113</td>\n",
       "      <td>0.0139</td>\n",
       "      <td>0.0016</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0016</td>\n",
       "      <td>0.0007</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0058</td>\n",
       "      <td>0.0083</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.0047</td>\n",
       "      <td>0.0724</td>\n",
       "      <td>0.0177</td>\n",
       "      <td>0.0231</td>\n",
       "      <td>0.0177</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.004</td>\n",
       "      <td>0.0038</td>\n",
       "      <td>0.0481</td>\n",
       "      <td>0.0153</td>\n",
       "      <td>0.0156</td>\n",
       "      <td>0.0153</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0321</td>\n",
       "      <td>0.0384</td>\n",
       "      <td>0.1277</td>\n",
       "      <td>0.0788</td>\n",
       "      <td>0.0003</td>\n",
       "      <td>0.0042</td>\n",
       "      <td>0.0043</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.0026</td>\n",
       "      <td>0.0028</td>\n",
       "      <td>0.0479</td>\n",
       "      <td>0.0172</td>\n",
       "      <td>0.0165</td>\n",
       "      <td>0.0172</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>adulta</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.0042</td>\n",
       "      <td>0.0051</td>\n",
       "      <td>0.0458</td>\n",
       "      <td>0.1011</td>\n",
       "      <td>0.0161</td>\n",
       "      <td>0.0904</td>\n",
       "      <td>0.0007</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0013</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.0925</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0319</td>\n",
       "      <td>0.0008</td>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0099</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.0041</td>\n",
       "      <td>0.0061</td>\n",
       "      <td>0.0302</td>\n",
       "      <td>0.0804</td>\n",
       "      <td>0.0098</td>\n",
       "      <td>0.0579</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.0041</td>\n",
       "      <td>0.0045</td>\n",
       "      <td>0.0298</td>\n",
       "      <td>0.0824</td>\n",
       "      <td>0.0095</td>\n",
       "      <td>0.0736</td>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0016</td>\n",
       "      <td>0.0017</td>\n",
       "      <td>0.0089</td>\n",
       "      <td>0.0961</td>\n",
       "      <td>0.1111</td>\n",
       "      <td>0.1267</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.0013</td>\n",
       "      <td>0.0088</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabtvfm_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>0.0038</td>\n",
       "      <td>0.0056</td>\n",
       "      <td>0.028</td>\n",
       "      <td>0.0845</td>\n",
       "      <td>0.0102</td>\n",
       "      <td>0.0708</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>churn</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   ROC_uni ROC_biv     CIO    TCAP Utility    Risk      WD     MMD  KS_sim  \\\n",
       "0   0.0018  0.0032  0.0516  0.0054  0.0172  0.0054  0.0011     0.0  0.0041   \n",
       "1   0.0031  0.0051   0.053  0.0043  0.0191  0.0043     NaN     NaN     NaN   \n",
       "2   0.0024  0.0027  0.0413   0.004  0.0139   0.004  0.0012     0.0  0.0037   \n",
       "3   0.0027  0.0031  0.0576  0.0072  0.0197  0.0072     NaN     NaN     NaN   \n",
       "4   0.0033  0.0038  0.0396  0.0164  0.0129  0.0164  0.0005     0.0  0.0013   \n",
       "5   0.0031  0.0039  0.0529  0.0156  0.0178  0.0156     NaN     NaN     NaN   \n",
       "6   0.0026  0.0031  0.0551  0.0185  0.0187  0.0185  0.0004     0.0  0.0013   \n",
       "7   0.0035  0.0045  0.0549  0.0148  0.0188  0.0148     NaN     NaN     NaN   \n",
       "8   0.0038  0.0029  0.0507  0.0091  0.0172  0.0091  0.0011     0.0  0.0045   \n",
       "9   0.0047  0.0044  0.0559  0.0063  0.0205  0.0063     NaN     NaN     NaN   \n",
       "10  0.0042   0.003  0.0569  0.0048  0.0193  0.0048  0.0014     0.0  0.0032   \n",
       "11  0.0037  0.0024  0.0629  0.0074  0.0216  0.0074     NaN     NaN     NaN   \n",
       "12  0.0113  0.0079  0.0709  0.0098   0.027  0.0098  0.0009     0.0  0.0046   \n",
       "13  0.0148  0.0091   0.059  0.0139  0.0231  0.0139     NaN     NaN     NaN   \n",
       "14  0.0087   0.006  0.0636   0.013  0.0225   0.013  0.0007     0.0  0.0038   \n",
       "15  0.0079  0.0051  0.0532  0.0105  0.0185  0.0105     NaN     NaN     NaN   \n",
       "16  0.0056  0.0035  0.0294  0.0199  0.0096  0.0199   0.001  0.0002  0.0031   \n",
       "17  0.0044  0.0031  0.0148  0.0149  0.0046  0.0149     NaN     NaN     NaN   \n",
       "18  0.0022  0.0043  0.0299  0.0208  0.0097  0.0208   0.001  0.0002  0.0034   \n",
       "19  0.0033  0.0041  0.0334  0.0244  0.0103  0.0244     NaN     NaN     NaN   \n",
       "20   0.005  0.0034   0.032  0.0139  0.0113  0.0139  0.0016     0.0  0.0016   \n",
       "21  0.0051  0.0047  0.0724  0.0177  0.0231  0.0177     NaN     NaN     NaN   \n",
       "22   0.004  0.0038  0.0481  0.0153  0.0156  0.0153  0.0004     0.0  0.0006   \n",
       "23  0.0026  0.0028  0.0479  0.0172  0.0165  0.0172     NaN     NaN     NaN   \n",
       "24  0.0042  0.0051  0.0458  0.1011  0.0161  0.0904  0.0007     0.0  0.0013   \n",
       "25  0.0041  0.0061  0.0302  0.0804  0.0098  0.0579     NaN     NaN     NaN   \n",
       "26  0.0041  0.0045  0.0298  0.0824  0.0095  0.0736  0.0009     0.0  0.0016   \n",
       "27  0.0038  0.0056   0.028  0.0845  0.0102  0.0708     NaN     NaN     NaN   \n",
       "\n",
       "   tvd_sim KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject  \\\n",
       "0   0.0004     0.0         0.0396            0.0                0.0293   \n",
       "1      NaN     NaN            NaN            NaN                   NaN   \n",
       "2   0.0004     0.0         0.0227            0.0                0.0336   \n",
       "3      NaN     NaN            NaN            NaN                   NaN   \n",
       "4   0.0005     0.0         0.0385            0.0                0.0362   \n",
       "5      NaN     NaN            NaN            NaN                   NaN   \n",
       "6   0.0006     0.0         0.0428            0.0                0.0749   \n",
       "7      NaN     NaN            NaN            NaN                   NaN   \n",
       "8   0.0005     0.0         0.0278            0.0                 0.071   \n",
       "9      NaN     NaN            NaN            NaN                   NaN   \n",
       "10  0.0006     0.0         0.0205            0.0                0.0486   \n",
       "11     NaN     NaN            NaN            NaN                   NaN   \n",
       "12  0.0004     0.0         0.0507            0.0                0.0654   \n",
       "13     NaN     NaN            NaN            NaN                   NaN   \n",
       "14  0.0004  0.0002         0.0482            0.0                0.0678   \n",
       "15     NaN     NaN            NaN            NaN                   NaN   \n",
       "16  0.0002     0.0         0.0641            0.0                0.0851   \n",
       "17     NaN     NaN            NaN            NaN                   NaN   \n",
       "18  0.0002     0.0         0.0365            0.0                0.0971   \n",
       "19     NaN     NaN            NaN            NaN                   NaN   \n",
       "20  0.0007     0.0            0.0            0.0                   0.0   \n",
       "21     NaN     NaN            NaN            NaN                   NaN   \n",
       "22  0.0004  0.0321         0.0384         0.1277                0.0788   \n",
       "23     NaN     NaN            NaN            NaN                   NaN   \n",
       "24   0.001  0.0004         0.0925            0.0                0.0319   \n",
       "25     NaN     NaN            NaN            NaN                   NaN   \n",
       "26  0.0017  0.0089         0.0961         0.1111                0.1267   \n",
       "27     NaN     NaN            NaN            NaN                   NaN   \n",
       "\n",
       "     shape   trend detection       data      method  \n",
       "0   0.0004  0.0005    0.0023         uk  tabtvfm_ot  \n",
       "1      NaN     NaN       NaN         uk  tabvvfm_ot  \n",
       "2   0.0004  0.0006    0.0028         uk  tabtvfm_vp  \n",
       "3      NaN     NaN       NaN         uk  tabvvfm_vp  \n",
       "4   0.0005  0.0033    0.0108     canada  tabtvfm_ot  \n",
       "5      NaN     NaN       NaN     canada  tabvvfm_ot  \n",
       "6   0.0004  0.0031    0.0145     canada  tabtvfm_vp  \n",
       "7      NaN     NaN       NaN     canada  tabvvfm_vp  \n",
       "8   0.0005  0.0006    0.0036       fiji  tabtvfm_ot  \n",
       "9      NaN     NaN       NaN       fiji  tabvvfm_ot  \n",
       "10  0.0006  0.0008    0.0029       fiji  tabtvfm_vp  \n",
       "11     NaN     NaN       NaN       fiji  tabvvfm_vp  \n",
       "12  0.0005   0.001    0.0065     rwanda  tabtvfm_ot  \n",
       "13     NaN     NaN       NaN     rwanda  tabvvfm_ot  \n",
       "14  0.0005   0.001    0.0052     rwanda  tabtvfm_vp  \n",
       "15     NaN     NaN       NaN     rwanda  tabvvfm_vp  \n",
       "16  0.0004  0.0009    0.0068  indonesia  tabtvfm_ot  \n",
       "17     NaN     NaN       NaN  indonesia  tabvvfm_ot  \n",
       "18  0.0004  0.0006    0.0097  indonesia  tabtvfm_vp  \n",
       "19     NaN     NaN       NaN  indonesia  tabvvfm_vp  \n",
       "20  0.0006  0.0058    0.0083     adulta  tabtvfm_ot  \n",
       "21     NaN     NaN       NaN     adulta  tabvvfm_ot  \n",
       "22  0.0003  0.0042    0.0043     adulta  tabtvfm_vp  \n",
       "23     NaN     NaN       NaN     adulta  tabvvfm_vp  \n",
       "24  0.0008  0.0009    0.0099      churn  tabtvfm_ot  \n",
       "25     NaN     NaN       NaN      churn  tabvvfm_ot  \n",
       "26  0.0012  0.0013    0.0088      churn  tabtvfm_vp  \n",
       "27     NaN     NaN       NaN      churn  tabvvfm_vp  "
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res2_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "8b1d903d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "algo_mapping = {\n",
    "    'tabvvfm_ot' : 'MLP-OT',\n",
    "    'tabvvfm_vp' : 'MLP-VP',\n",
    "    'tabtvfm_ot' : 'Transformers-OT',\n",
    "    'tabtvfm_vp' : 'Transformers-VP'\n",
    "}\n",
    "\n",
    "dataset_mapping = {\n",
    "    'uk': 'UK',\n",
    "    'indonesia': 'Indonesia',\n",
    "    'canada': 'Canada',\n",
    "    'fiji': 'Fiji',\n",
    "    'rwanda': 'Rwanda',\n",
    "    'adulta': 'Adult',\n",
    "    'churn': 'Churn'\n",
    "}\n",
    "\n",
    "res2_mean['method'] = res2_mean['method'].map(algo_mapping)\n",
    "res2_std['method'] = res2_std['method'].map(algo_mapping)\n",
    "\n",
    "res2_mean['data'] = res2_mean['data'].map(dataset_mapping)\n",
    "res2_std['data'] = res2_std['data'].map(dataset_mapping)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "252eecb5",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllll}\n",
      "\\toprule\n",
      "method & MLP-OT & MLP-VP & Transformers-OT & Transformers-VP \\\\\n",
      "data &  &  &  &  \\\\\n",
      "\\midrule\n",
      "UK & 0.8333±0.0191 & 0.8066±0.0197 & 0.7809±0.0172 & 0.7917±0.0139 \\\\\n",
      "Indonesia & 0.6671±0.0046 & 0.6488±0.0103 & 0.6564±0.0096 & 0.6515±0.0097 \\\\\n",
      "Canada & 0.7892±0.0178 & 0.7472±0.0188 & 0.7854±0.0129 & 0.7397±0.0187 \\\\\n",
      "Fiji & 0.7263±0.0205 & 0.7451±0.0216 & 0.7391±0.0172 & 0.7394±0.0193 \\\\\n",
      "Rwanda & 0.7284±0.0231 & 0.7358±0.0185 & 0.7442±0.027 & 0.7209±0.0225 \\\\\n",
      "Adult & 0.772±0.0231 & 0.7581±0.0165 & 0.5637±0.0113 & 0.7437±0.0156 \\\\\n",
      "Churn & 0.7966±0.0098 & 0.8066±0.0102 & 0.8738±0.0161 & 0.8339±0.0095 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "dataset_order = ['UK', 'Indonesia', 'Canada', 'Fiji', 'Rwanda', 'Adult', 'Churn']\n",
    "\n",
    "param_eval = 'Utility'\n",
    "mean2 = res2_mean.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "std2 = res2_std.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "all_res2 = mean2.round(4).astype(str) + '±' + std2.round(4).astype(str)\n",
    "print(all_res2[dataset_order].transpose().to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "e1d9263d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "mean2 = res2_mean.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values='Utility',\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "std2 = res2_std.pivot_table(\n",
    "    index='method',\n",
    "    columns='data',\n",
    "    values='Utility',\n",
    "    aggfunc='first'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "1f1ae401",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>data</th>\n",
       "      <th>adulta</th>\n",
       "      <th>canada</th>\n",
       "      <th>churn</th>\n",
       "      <th>fiji</th>\n",
       "      <th>indonesia</th>\n",
       "      <th>rwanda</th>\n",
       "      <th>uk</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>tabtvfm_ot</th>\n",
       "      <td>0.5637±0.0113</td>\n",
       "      <td>0.5578±0.0095</td>\n",
       "      <td>0.8738±0.0161</td>\n",
       "      <td>0.7483±0.0193</td>\n",
       "      <td>0.6564±0.0096</td>\n",
       "      <td>0.7507±0.0209</td>\n",
       "      <td>0.7809±0.0172</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tabtvfm_vp</th>\n",
       "      <td>0.7437±0.0156</td>\n",
       "      <td>0.7634±0.0204</td>\n",
       "      <td>0.8339±0.0095</td>\n",
       "      <td>0.7479±0.0191</td>\n",
       "      <td>0.6515±0.0097</td>\n",
       "      <td>0.7218±0.0267</td>\n",
       "      <td>0.7917±0.0139</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tabvvfm_ot</th>\n",
       "      <td>0.772±0.0231</td>\n",
       "      <td>0.7892±0.0178</td>\n",
       "      <td>0.7966±0.0098</td>\n",
       "      <td>0.7263±0.0205</td>\n",
       "      <td>0.6671±0.0046</td>\n",
       "      <td>0.7284±0.0231</td>\n",
       "      <td>0.8333±0.0191</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tabvvfm_vp</th>\n",
       "      <td>0.7581±0.0165</td>\n",
       "      <td>0.7472±0.0188</td>\n",
       "      <td>0.8066±0.0102</td>\n",
       "      <td>0.7451±0.0216</td>\n",
       "      <td>0.6488±0.0103</td>\n",
       "      <td>0.7358±0.0185</td>\n",
       "      <td>0.8066±0.0197</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "data               adulta         canada          churn           fiji  \\\n",
       "method                                                                   \n",
       "tabtvfm_ot  0.5637±0.0113  0.5578±0.0095  0.8738±0.0161  0.7483±0.0193   \n",
       "tabtvfm_vp  0.7437±0.0156  0.7634±0.0204  0.8339±0.0095  0.7479±0.0191   \n",
       "tabvvfm_ot   0.772±0.0231  0.7892±0.0178  0.7966±0.0098  0.7263±0.0205   \n",
       "tabvvfm_vp  0.7581±0.0165  0.7472±0.0188  0.8066±0.0102  0.7451±0.0216   \n",
       "\n",
       "data            indonesia         rwanda             uk  \n",
       "method                                                   \n",
       "tabtvfm_ot  0.6564±0.0096  0.7507±0.0209  0.7809±0.0172  \n",
       "tabtvfm_vp  0.6515±0.0097  0.7218±0.0267  0.7917±0.0139  \n",
       "tabvvfm_ot  0.6671±0.0046  0.7284±0.0231  0.8333±0.0191  \n",
       "tabvvfm_vp  0.6488±0.0103  0.7358±0.0185  0.8066±0.0197  "
      ]
     },
     "execution_count": 102,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_res = mean2.astype(str) + '±' + std2.round(4).astype(str)\n",
    "\n",
    "all_res\n",
    "# all_res[['uk','canada','fiji','rwanda']]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "45ba3c46",
   "metadata": {},
   "source": [
    "### Ablation on diabetes data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "b17f04f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dir = f'{os.getcwd()}/eval/combine/'\n",
    "algo = ['tabsyn', 'tabsynflow_ot','tabsynflow_vp', 'tabvvfm_ot', 'tabvvfm_vp']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "633b0f83",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "resq_mean = pd.DataFrame()\n",
    "for i in ['diabetes']:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/{j}_urisk.csv')\n",
    "        aa = aa.mean().round(4)\n",
    "#         aa = (aa.mean()* 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_mean = pd.concat([resq_mean,aa], axis=1)\n",
    "    \n",
    "resq_mean = resq_mean.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "09cfed87",
   "metadata": {},
   "outputs": [],
   "source": [
    "resq_std = pd.DataFrame()\n",
    "for i in ['diabetes']:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/{j}_urisk.csv')\n",
    "        aa = aa.std().round(4)\n",
    "#         aa = (aa.std() * 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_std = pd.concat([resq_std,aa], axis=1)\n",
    "    \n",
    "resq_std = resq_std.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "2d995051",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.6725</td>\n",
       "      <td>0.6732</td>\n",
       "      <td>0.3072</td>\n",
       "      <td>0.1217</td>\n",
       "      <td>0.5509</td>\n",
       "      <td>0.1217</td>\n",
       "      <td>0.0052</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9841</td>\n",
       "      <td>0.0243</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.1548</td>\n",
       "      <td>0.9812</td>\n",
       "      <td>0.7875</td>\n",
       "      <td>0.9771</td>\n",
       "      <td>0.9591</td>\n",
       "      <td>0.5226</td>\n",
       "      <td>diabetes</td>\n",
       "      <td>tabsyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.6626</td>\n",
       "      <td>0.6593</td>\n",
       "      <td>0.2855</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>0.5358</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>0.0044</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9836</td>\n",
       "      <td>0.0367</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.1487</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.805</td>\n",
       "      <td>0.9667</td>\n",
       "      <td>0.949</td>\n",
       "      <td>0.3687</td>\n",
       "      <td>diabetes</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.5979</td>\n",
       "      <td>0.5905</td>\n",
       "      <td>0.252</td>\n",
       "      <td>0.0791</td>\n",
       "      <td>0.4801</td>\n",
       "      <td>0.0791</td>\n",
       "      <td>0.0061</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.9815</td>\n",
       "      <td>0.0673</td>\n",
       "      <td>0.0017</td>\n",
       "      <td>0.1434</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8237</td>\n",
       "      <td>0.9408</td>\n",
       "      <td>0.9115</td>\n",
       "      <td>0.1585</td>\n",
       "      <td>diabetes</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.6306</td>\n",
       "      <td>0.654</td>\n",
       "      <td>0.3155</td>\n",
       "      <td>0.1581</td>\n",
       "      <td>0.5333</td>\n",
       "      <td>0.1581</td>\n",
       "      <td>0.0101</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9669</td>\n",
       "      <td>0.0165</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1943</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7012</td>\n",
       "      <td>0.9807</td>\n",
       "      <td>0.9387</td>\n",
       "      <td>0.678</td>\n",
       "      <td>diabetes</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.6654</td>\n",
       "      <td>0.6871</td>\n",
       "      <td>0.3342</td>\n",
       "      <td>0.1392</td>\n",
       "      <td>0.5622</td>\n",
       "      <td>0.1392</td>\n",
       "      <td>0.0117</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9651</td>\n",
       "      <td>0.0104</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1656</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7537</td>\n",
       "      <td>0.9855</td>\n",
       "      <td>0.9446</td>\n",
       "      <td>0.788</td>\n",
       "      <td>diabetes</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  ROC_uni ROC_biv     CIO    TCAP Utility    Risk      WD     MMD  KS_sim  \\\n",
       "0  0.6725  0.6732  0.3072  0.1217  0.5509  0.1217  0.0052  0.0001  0.9841   \n",
       "1  0.6626  0.6593  0.2855  0.0951  0.5358  0.0951  0.0044  0.0001  0.9836   \n",
       "2  0.5979  0.5905   0.252  0.0791  0.4801  0.0791  0.0061  0.0005  0.9815   \n",
       "3  0.6306   0.654  0.3155  0.1581  0.5333  0.1581  0.0101     0.0  0.9669   \n",
       "4  0.6654  0.6871  0.3342  0.1392  0.5622  0.1392  0.0117     0.0  0.9651   \n",
       "\n",
       "  tvd_sim KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject   shape  \\\n",
       "0  0.0243  0.0031         0.1548         0.9812                0.7875  0.9771   \n",
       "1  0.0367  0.0004         0.1487            1.0                 0.805  0.9667   \n",
       "2  0.0673  0.0017         0.1434            1.0                0.8237  0.9408   \n",
       "3  0.0165     0.0         0.1943            1.0                0.7012  0.9807   \n",
       "4  0.0104     0.0         0.1656            1.0                0.7537  0.9855   \n",
       "\n",
       "    trend detection      data         method  \n",
       "0  0.9591    0.5226  diabetes         tabsyn  \n",
       "1   0.949    0.3687  diabetes  tabsynflow_ot  \n",
       "2  0.9115    0.1585  diabetes  tabsynflow_vp  \n",
       "3  0.9387     0.678  diabetes     tabvvfm_ot  \n",
       "4  0.9446     0.788  diabetes     tabvvfm_vp  "
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "resq_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "6a15b75c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "algo_mapping = {\n",
    "    'tabddpm': 'TabDDPM',\n",
    "    'tabsyn': 'TabSyn',\n",
    "    'tabsynflow_ot': 'TabSynFlow-OT',\n",
    "    'tabsynflow_vp': 'TabSynFlow-VP',\n",
    "    'tabvvfm_ot' : 'TabbyFlow-OT',\n",
    "    'tabvvfm_vp' : 'TabbyFlow-VP',\n",
    "}\n",
    "\n",
    "dataset_mapping = {\n",
    "    'uk': 'UK',\n",
    "    'indonesia': 'Indonesia',\n",
    "    'canada': 'Canada',\n",
    "    'fiji': 'Fiji',\n",
    "    'rwanda': 'Rwanda',\n",
    "    'adulta': 'Adult',\n",
    "    'churn': 'Churn'\n",
    "}\n",
    "\n",
    "resq_mean['method'] = resq_mean['method'].map(algo_mapping)\n",
    "resq_std['method'] = resq_std['method'].map(algo_mapping)\n",
    "\n",
    "resq_mean['data'] = resq_mean['data'].map(dataset_mapping)\n",
    "resq_std['data'] = resq_std['data'].map(dataset_mapping)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "f44ee00c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.6725</td>\n",
       "      <td>0.6732</td>\n",
       "      <td>0.3072</td>\n",
       "      <td>0.1217</td>\n",
       "      <td>0.5509</td>\n",
       "      <td>0.1217</td>\n",
       "      <td>0.0052</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9841</td>\n",
       "      <td>0.0243</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.1548</td>\n",
       "      <td>0.9812</td>\n",
       "      <td>0.7875</td>\n",
       "      <td>0.9771</td>\n",
       "      <td>0.9591</td>\n",
       "      <td>0.5226</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TabSyn</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.6626</td>\n",
       "      <td>0.6593</td>\n",
       "      <td>0.2855</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>0.5358</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>0.0044</td>\n",
       "      <td>0.0001</td>\n",
       "      <td>0.9836</td>\n",
       "      <td>0.0367</td>\n",
       "      <td>0.0004</td>\n",
       "      <td>0.1487</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.805</td>\n",
       "      <td>0.9667</td>\n",
       "      <td>0.949</td>\n",
       "      <td>0.3687</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TabSynFlow-OT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.5979</td>\n",
       "      <td>0.5905</td>\n",
       "      <td>0.252</td>\n",
       "      <td>0.0791</td>\n",
       "      <td>0.4801</td>\n",
       "      <td>0.0791</td>\n",
       "      <td>0.0061</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>0.9815</td>\n",
       "      <td>0.0673</td>\n",
       "      <td>0.0017</td>\n",
       "      <td>0.1434</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.8237</td>\n",
       "      <td>0.9408</td>\n",
       "      <td>0.9115</td>\n",
       "      <td>0.1585</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TabSynFlow-VP</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.6306</td>\n",
       "      <td>0.654</td>\n",
       "      <td>0.3155</td>\n",
       "      <td>0.1581</td>\n",
       "      <td>0.5333</td>\n",
       "      <td>0.1581</td>\n",
       "      <td>0.0101</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9669</td>\n",
       "      <td>0.0165</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1943</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7012</td>\n",
       "      <td>0.9807</td>\n",
       "      <td>0.9387</td>\n",
       "      <td>0.678</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TabbyFlow-OT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.6654</td>\n",
       "      <td>0.6871</td>\n",
       "      <td>0.3342</td>\n",
       "      <td>0.1392</td>\n",
       "      <td>0.5622</td>\n",
       "      <td>0.1392</td>\n",
       "      <td>0.0117</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9651</td>\n",
       "      <td>0.0104</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1656</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7537</td>\n",
       "      <td>0.9855</td>\n",
       "      <td>0.9446</td>\n",
       "      <td>0.788</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TabbyFlow-VP</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  ROC_uni ROC_biv     CIO    TCAP Utility    Risk      WD     MMD  KS_sim  \\\n",
       "0  0.6725  0.6732  0.3072  0.1217  0.5509  0.1217  0.0052  0.0001  0.9841   \n",
       "1  0.6626  0.6593  0.2855  0.0951  0.5358  0.0951  0.0044  0.0001  0.9836   \n",
       "2  0.5979  0.5905   0.252  0.0791  0.4801  0.0791  0.0061  0.0005  0.9815   \n",
       "3  0.6306   0.654  0.3155  0.1581  0.5333  0.1581  0.0101     0.0  0.9669   \n",
       "4  0.6654  0.6871  0.3342  0.1392  0.5622  0.1392  0.0117     0.0  0.9651   \n",
       "\n",
       "  tvd_sim KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject   shape  \\\n",
       "0  0.0243  0.0031         0.1548         0.9812                0.7875  0.9771   \n",
       "1  0.0367  0.0004         0.1487            1.0                 0.805  0.9667   \n",
       "2  0.0673  0.0017         0.1434            1.0                0.8237  0.9408   \n",
       "3  0.0165     0.0         0.1943            1.0                0.7012  0.9807   \n",
       "4  0.0104     0.0         0.1656            1.0                0.7537  0.9855   \n",
       "\n",
       "    trend detection data         method  \n",
       "0  0.9591    0.5226  NaN         TabSyn  \n",
       "1   0.949    0.3687  NaN  TabSynFlow-OT  \n",
       "2  0.9115    0.1585  NaN  TabSynFlow-VP  \n",
       "3  0.9387     0.678  NaN   TabbyFlow-OT  \n",
       "4  0.9446     0.788  NaN   TabbyFlow-VP  "
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "resq_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "0c63680a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllll}\n",
      "\\toprule\n",
      "method & TabSynFlow-OT & TabSynFlow-VP & TabbyFlow-OT & TabbyFlow-VP \\\\\n",
      "\\midrule\n",
      "Utility & 53.58±0.58 & 48.01±0.49 & 53.33±2.06 & 56.22±2.13 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "param_eval = 'Utility'\n",
    "meanq1 = resq_mean.pivot_table(\n",
    "    index='method',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "stdq1 = resq_std.pivot_table(\n",
    "    index='method',\n",
    "    values=param_eval,\n",
    "    aggfunc='first'\n",
    ")\n",
    "\n",
    "all_resq = meanq1.round(2).astype(str) + '±' + stdq1.round(2).astype(str)\n",
    "# all_res = mean1.round(4).astype(str)\n",
    "colna = ['TabSynFlow-OT', 'TabSynFlow-VP','TabbyFlow-OT','TabbyFlow-VP'] # ,'TabSynFlow-VP'\n",
    "print(all_resq.transpose()[colna].to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "eae082a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_a = pd.DataFrame()\n",
    "for param_eval in resq_mean.columns[:-2]:\n",
    "    meanq1 = resq_mean.pivot_table(\n",
    "        index='method',\n",
    "        values=param_eval,\n",
    "        aggfunc='first'\n",
    "    )\n",
    "\n",
    "    stdq1 = resq_std.pivot_table(\n",
    "        index='method',\n",
    "        values=param_eval,\n",
    "        aggfunc='first'\n",
    "    )\n",
    "\n",
    "    all_resq = meanq1.round(2).astype(str) + '±' + stdq1.round(2).astype(str)\n",
    "    # all_res = mean1.round(4).astype(str)\n",
    "    colna = ['TabSynFlow-OT', 'TabSynFlow-VP','TabbyFlow-OT','TabbyFlow-VP'] # ,'TabSynFlow-VP'\n",
    "    res_a = pd.concat([res_a, all_resq.transpose()[colna]], axis=0)\n",
    "#     print(all_resq.transpose()[colna].to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "5ef6cf85",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllll}\n",
      "\\toprule\n",
      "method & TabSynFlow-OT & TabSynFlow-VP & TabbyFlow-OT & TabbyFlow-VP \\\\\n",
      "\\midrule\n",
      "ROC_uni & 0.6626±0.0041 & 0.5979±0.0062 & 0.6306±0.0037 & 0.6654±0.0041 \\\\\n",
      "ROC_biv & 0.6593±0.0028 & 0.5905±0.0034 & 0.654±0.0028 & 0.6871±0.0029 \\\\\n",
      "CIO & 0.2855±0.0157 & 0.252±0.0124 & 0.3155±0.0636 & 0.3342±0.0615 \\\\\n",
      "TCAP & 0.0951±0.0097 & 0.0791±0.009 & 0.1581±0.0058 & 0.1392±0.0051 \\\\\n",
      "Utility & 0.5358±0.0058 & 0.4801±0.0049 & 0.5333±0.0206 & 0.5622±0.0213 \\\\\n",
      "Risk & 0.0951±0.0097 & 0.0791±0.009 & 0.1581±0.0058 & 0.1392±0.0051 \\\\\n",
      "WD & 0.0044±0.0001 & 0.0061±0.0001 & 0.0101±0.0005 & 0.0117±0.0006 \\\\\n",
      "MMD & 0.0001±0.0 & 0.0005±0.0 & 0.0±0.0 & 0.0±0.0 \\\\\n",
      "KS_sim & 0.9836±0.0003 & 0.9815±0.0003 & 0.9669±0.0017 & 0.9651±0.0018 \\\\\n",
      "tvd_sim & 0.0367±0.0003 & 0.0673±0.0004 & 0.0165±0.0002 & 0.0104±0.0003 \\\\\n",
      "KS_pval & 0.0004±0.0004 & 0.0017±0.0007 & 0.0±0.0 & 0.0±0.0 \\\\\n",
      "ChiSquare_pval & 0.1487±0.0045 & 0.1434±0.0004 & 0.1943±0.0133 & 0.1656±0.0123 \\\\\n",
      "KS_frac_reject & 1.0±0.0 & 1.0±0.0 & 1.0±0.0 & 1.0±0.0 \\\\\n",
      "ChiSquare_frac_reject & 0.805±0.0103 & 0.8237±0.0056 & 0.7012±0.0222 & 0.7537±0.026 \\\\\n",
      "shape & 0.9667±0.0003 & 0.9408±0.0003 & 0.9807±0.0003 & 0.9855±0.0004 \\\\\n",
      "trend & 0.949±0.001 & 0.9115±0.0009 & 0.9387±0.0018 & 0.9446±0.0018 \\\\\n",
      "detection & 0.3687±0.0014 & 0.1585±0.0009 & 0.678±0.0037 & 0.788±0.0037 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(res_a.to_latex())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2453609e",
   "metadata": {},
   "source": [
    "### Ablation on cancer data (high dimensional)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "de817347",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dir = f'{os.getcwd()}/eval/combine/'\n",
    "algo = ['tabsynflow_ot','tabsynflow_vp', 'tabvvfm_ot', 'tabvvfm_vp']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "beacecfc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "resq_mean = pd.DataFrame()\n",
    "for i in ['tcga']:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/{j}_urisk.csv')\n",
    "        aa['Utility'] = (aa['ROC_uni'] + aa['CIO']) / 2\n",
    "#         aa = aa.mean().round(4)\n",
    "        aa = (aa.mean()* 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_mean = pd.concat([resq_mean,aa], axis=1)\n",
    "    \n",
    "resq_mean = resq_mean.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "73d94d76",
   "metadata": {},
   "outputs": [],
   "source": [
    "resq_std = pd.DataFrame()\n",
    "for i in ['tcga']:\n",
    "    for j in algo:\n",
    "        aa = pd.read_csv(f'{eval_dir}/{i}/{j}_urisk.csv')\n",
    "        aa['Utility'] = (aa['ROC_uni'] + aa['CIO']) / 2\n",
    "#         aa = aa.std().round(4)\n",
    "        aa = (aa.std() * 100).round(2)\n",
    "        aa['data'] = i\n",
    "        aa['method'] = j\n",
    "        resq_std = pd.concat([resq_std,aa], axis=1)\n",
    "    \n",
    "resq_std = resq_std.transpose().reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "94abef00",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ROC_uni</th>\n",
       "      <th>ROC_biv</th>\n",
       "      <th>CIO</th>\n",
       "      <th>TCAP</th>\n",
       "      <th>Utility</th>\n",
       "      <th>Risk</th>\n",
       "      <th>WD</th>\n",
       "      <th>MMD</th>\n",
       "      <th>KS_sim</th>\n",
       "      <th>tvd_sim</th>\n",
       "      <th>KS_pval</th>\n",
       "      <th>ChiSquare_pval</th>\n",
       "      <th>KS_frac_reject</th>\n",
       "      <th>ChiSquare_frac_reject</th>\n",
       "      <th>shape</th>\n",
       "      <th>trend</th>\n",
       "      <th>detection</th>\n",
       "      <th>data</th>\n",
       "      <th>method</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>85.39</td>\n",
       "      <td>0.0</td>\n",
       "      <td>79.27</td>\n",
       "      <td>-13.16</td>\n",
       "      <td>82.33</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.51</td>\n",
       "      <td>0.49</td>\n",
       "      <td>90.11</td>\n",
       "      <td>8.43</td>\n",
       "      <td>15.13</td>\n",
       "      <td>0.95</td>\n",
       "      <td>50.3</td>\n",
       "      <td>95.0</td>\n",
       "      <td>90.1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.12</td>\n",
       "      <td>tcga</td>\n",
       "      <td>tabsynflow_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>86.22</td>\n",
       "      <td>0.0</td>\n",
       "      <td>79.56</td>\n",
       "      <td>-11.26</td>\n",
       "      <td>82.89</td>\n",
       "      <td>0.33</td>\n",
       "      <td>2.32</td>\n",
       "      <td>0.37</td>\n",
       "      <td>90.79</td>\n",
       "      <td>7.97</td>\n",
       "      <td>21.65</td>\n",
       "      <td>3.72</td>\n",
       "      <td>38.63</td>\n",
       "      <td>70.0</td>\n",
       "      <td>90.78</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.46</td>\n",
       "      <td>tcga</td>\n",
       "      <td>tabsynflow_vp</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>86.61</td>\n",
       "      <td>0.0</td>\n",
       "      <td>47.21</td>\n",
       "      <td>-3.31</td>\n",
       "      <td>66.91</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.51</td>\n",
       "      <td>0.15</td>\n",
       "      <td>79.8</td>\n",
       "      <td>5.93</td>\n",
       "      <td>3.06</td>\n",
       "      <td>8.89</td>\n",
       "      <td>96.0</td>\n",
       "      <td>65.0</td>\n",
       "      <td>79.79</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.79</td>\n",
       "      <td>tcga</td>\n",
       "      <td>tabvvfm_ot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>84.08</td>\n",
       "      <td>0.0</td>\n",
       "      <td>50.21</td>\n",
       "      <td>-4.94</td>\n",
       "      <td>67.14</td>\n",
       "      <td>0.02</td>\n",
       "      <td>5.51</td>\n",
       "      <td>0.31</td>\n",
       "      <td>79.54</td>\n",
       "      <td>7.92</td>\n",
       "      <td>3.08</td>\n",
       "      <td>1.4</td>\n",
       "      <td>95.91</td>\n",
       "      <td>95.0</td>\n",
       "      <td>79.53</td>\n",
       "      <td>0.0</td>\n",
       "      <td>6.66</td>\n",
       "      <td>tcga</td>\n",
       "      <td>tabvvfm_vp</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  ROC_uni ROC_biv    CIO   TCAP Utility  Risk    WD   MMD KS_sim tvd_sim  \\\n",
       "0   85.39     0.0  79.27 -13.16   82.33   0.0  2.51  0.49  90.11    8.43   \n",
       "1   86.22     0.0  79.56 -11.26   82.89  0.33  2.32  0.37  90.79    7.97   \n",
       "2   86.61     0.0  47.21  -3.31   66.91   0.0  5.51  0.15   79.8    5.93   \n",
       "3   84.08     0.0  50.21  -4.94   67.14  0.02  5.51  0.31  79.54    7.92   \n",
       "\n",
       "  KS_pval ChiSquare_pval KS_frac_reject ChiSquare_frac_reject  shape trend  \\\n",
       "0   15.13           0.95           50.3                  95.0   90.1   0.0   \n",
       "1   21.65           3.72          38.63                  70.0  90.78   0.0   \n",
       "2    3.06           8.89           96.0                  65.0  79.79   0.0   \n",
       "3    3.08            1.4          95.91                  95.0  79.53   0.0   \n",
       "\n",
       "  detection  data         method  \n",
       "0      2.12  tcga  tabsynflow_ot  \n",
       "1      3.46  tcga  tabsynflow_vp  \n",
       "2     12.79  tcga     tabvvfm_ot  \n",
       "3      6.66  tcga     tabvvfm_vp  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "resq_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "432beb2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pivot table for better visualization\n",
    "algo_mapping = {\n",
    "    'tabddpm': 'TabDDPM',\n",
    "    'tabsyn': 'TabSyn',\n",
    "    'tabsynflow_ot': 'TabSynFlow-OT',\n",
    "    'tabsynflow_vp': 'TabSynFlow-VP',\n",
    "    'tabvvfm_ot' : 'TabbyFlow-OT',\n",
    "    'tabvvfm_vp' : 'TabbyFlow-VP',\n",
    "}\n",
    "\n",
    "dataset_mapping = {\n",
    "    'uk': 'UK',\n",
    "    'indonesia': 'Indonesia',\n",
    "    'canada': 'Canada',\n",
    "    'fiji': 'Fiji',\n",
    "    'rwanda': 'Rwanda',\n",
    "    'adulta': 'Adult',\n",
    "    'churn': 'Churn'\n",
    "}\n",
    "\n",
    "resq_mean['method'] = resq_mean['method'].map(algo_mapping)\n",
    "resq_std['method'] = resq_std['method'].map(algo_mapping)\n",
    "\n",
    "resq_mean['data'] = resq_mean['data'].map(dataset_mapping)\n",
    "resq_std['data'] = resq_std['data'].map(dataset_mapping)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "b5105b8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_a = pd.DataFrame()\n",
    "for param_eval in resq_mean.columns[:-2]:\n",
    "    meanq1 = resq_mean.pivot_table(\n",
    "        index='method',\n",
    "        values=param_eval,\n",
    "        aggfunc='first'\n",
    "    )\n",
    "\n",
    "    stdq1 = resq_std.pivot_table(\n",
    "        index='method',\n",
    "        values=param_eval,\n",
    "        aggfunc='first'\n",
    "    )\n",
    "\n",
    "    all_resq = meanq1.round(2).astype(str) + '±' + stdq1.round(2).astype(str)\n",
    "    # all_res = mean1.round(4).astype(str)\n",
    "    colna = ['TabSynFlow-OT', 'TabSynFlow-VP','TabbyFlow-OT','TabbyFlow-VP'] # ,'TabSynFlow-VP'\n",
    "    res_a = pd.concat([res_a, all_resq.transpose()[colna]], axis=0)\n",
    "#     print(all_resq.transpose()[colna].to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "b032b2ab",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lllll}\n",
      "\\toprule\n",
      "method & TabSynFlow-OT & TabSynFlow-VP & TabbyFlow-OT & TabbyFlow-VP \\\\\n",
      "\\midrule\n",
      "ROC_uni & 85.39±2.65 & 86.22±2.66 & 86.61±3.06 & 84.08±2.09 \\\\\n",
      "ROC_biv & 0.0±0.0 & 0.0±0.0 & 0.0±0.0 & 0.0±0.0 \\\\\n",
      "CIO & 79.27±0.11 & 79.56±0.1 & 47.21±0.05 & 50.21±0.07 \\\\\n",
      "TCAP & -13.16±7.12 & -11.26±7.25 & -3.31±2.29 & -4.94±5.64 \\\\\n",
      "Utility & 82.33±1.33 & 82.89±1.33 & 66.91±1.53 & 67.14±1.03 \\\\\n",
      "Risk & 0.0±0.0 & 0.33±1.48 & 0.0±0.0 & 0.02±0.08 \\\\\n",
      "WD & 2.51±0.03 & 2.32±0.03 & 5.51±0.06 & 5.51±0.06 \\\\\n",
      "MMD & 0.49±0.21 & 0.37±0.18 & 0.15±0.11 & 0.31±0.14 \\\\\n",
      "KS_sim & 90.11±0.08 & 90.79±0.1 & 79.8±0.21 & 79.54±0.18 \\\\\n",
      "tvd_sim & 8.43±1.46 & 7.97±1.45 & 5.93±1.51 & 7.92±1.26 \\\\\n",
      "KS_pval & 15.13±1.0 & 21.65±1.71 & 3.06±0.0 & 3.08±0.01 \\\\\n",
      "ChiSquare_pval & 0.95±1.98 & 3.72±6.67 & 8.89±16.79 & 1.4±2.37 \\\\\n",
      "KS_frac_reject & 50.3±2.12 & 38.63±2.13 & 96.0±0.01 & 95.91±0.05 \\\\\n",
      "ChiSquare_frac_reject & 95.0±22.36 & 70.0±47.02 & 65.0±48.94 & 95.0±22.36 \\\\\n",
      "shape & 90.1±0.08 & 90.78±0.1 & 79.79±0.21 & 79.53±0.18 \\\\\n",
      "trend & 0.0±0.0 & 0.0±0.0 & 0.0±0.0 & 0.0±0.0 \\\\\n",
      "detection & 2.12±4.45 & 3.46±5.12 & 12.79±14.19 & 6.66±10.47 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(res_a.to_latex())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f8f19b6",
   "metadata": {},
   "source": [
    "### Check number of categories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "331a6a30",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "uk & 1 & 218 & 74\n",
      "canada & 4 & 170 & 37\n",
      "fiji & 1 & 239 & 37\n",
      "rwanda & 1 & 197 & 37\n",
      "indonesia & 1 & 62 & 10\n",
      "adulta & 5 & 122 & 42\n",
      "churn & 4 & 26 & 11\n",
      "diabetes & 8 & 2513 & 790\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/slurm.10699896/ipykernel_2468602/72028679.py:3: DtypeWarning: Columns (8) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  data = pd.read_csv(f'data/{i}/train.csv')\n"
     ]
    }
   ],
   "source": [
    "dir_data = 'data/'\n",
    "for i in ['uk', 'canada', 'fiji', 'rwanda', 'indonesia', 'adulta', 'churn','diabetes']:\n",
    "    data = pd.read_csv(f'data/{i}/train.csv')\n",
    "    f = open(f'data/{i}/info.json',)\n",
    "    data_dict = json.load(f)\n",
    "    dn = data.iloc[:,data_dict['num_col_idx']].columns\n",
    "    K = data.iloc[:,data_dict['cat_col_idx']].nunique(dropna=False)\n",
    "    K_y = data.iloc[:,data_dict['target_col_idx']].nunique(dropna=False)\n",
    "    print(f'{i} & {len(dn)} & {K.sum() + K_y.sum()} & {K.max()}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "ed44a529",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "data = pd.read_csv('data/canada/train.csv')\n",
    "f = open('data/canada/info.json',)\n",
    "aa = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "04c88afe",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>MARST</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32144</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32145</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32146</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32147</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32148</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>32149 rows × 1 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       MARST\n",
       "0          1\n",
       "1          1\n",
       "2          6\n",
       "3          2\n",
       "4          1\n",
       "...      ...\n",
       "32144      2\n",
       "32145      2\n",
       "32146      1\n",
       "32147      2\n",
       "32148      1\n",
       "\n",
       "[32149 rows x 1 columns]"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.iloc[:,aa['num_col_idx']]\n",
    "data.iloc[:,aa['cat_col_idx']]\n",
    "data.iloc[:,aa['target_col_idx']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "113e5280",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'name': 'canada',\n",
       " 'task_type': 'binclass',\n",
       " 'header': 'infer',\n",
       " 'column_names': ['AGE',\n",
       "  'HRSWK',\n",
       "  'INCTOT',\n",
       "  'WKSWORK',\n",
       "  'ABIDENT',\n",
       "  'SEX',\n",
       "  'TENURE',\n",
       "  'URBAN',\n",
       "  'WKFULL',\n",
       "  'BPLMOM',\n",
       "  'BPLPOP',\n",
       "  'CITIZEN',\n",
       "  'CLASSWK',\n",
       "  'EMPSTAT',\n",
       "  'LANG',\n",
       "  'MARST',\n",
       "  'TRANWORK',\n",
       "  'RELATE',\n",
       "  'DEGREE',\n",
       "  'OCCISCO',\n",
       "  'YRIMM',\n",
       "  'MINORITY',\n",
       "  'RELIG',\n",
       "  'IND',\n",
       "  'BPL'],\n",
       " 'num_col_idx': [0, 1, 2, 3],\n",
       " 'cat_col_idx': [4,\n",
       "  5,\n",
       "  6,\n",
       "  7,\n",
       "  8,\n",
       "  9,\n",
       "  10,\n",
       "  11,\n",
       "  12,\n",
       "  13,\n",
       "  14,\n",
       "  16,\n",
       "  17,\n",
       "  18,\n",
       "  19,\n",
       "  20,\n",
       "  21,\n",
       "  22,\n",
       "  23,\n",
       "  24],\n",
       " 'target_col_idx': [15],\n",
       " 'file_type': 'csv',\n",
       " 'data_path': '/mnt/hum01-home01/p88346bn/test/tab-ddpm/census-data2/Canada.csv',\n",
       " 'test_path': None,\n",
       " 'column_info': {'0': {},\n",
       "  'type': 'categorical',\n",
       "  'max': 60.93483352661133,\n",
       "  'min': -5.026564598083496,\n",
       "  '1': {},\n",
       "  '2': {},\n",
       "  '3': {},\n",
       "  '4': {},\n",
       "  'categorizes': ['6', '1', '4', '3', '2', '5'],\n",
       "  '5': {},\n",
       "  '6': {},\n",
       "  '7': {},\n",
       "  '8': {},\n",
       "  '9': {},\n",
       "  '10': {},\n",
       "  '11': {},\n",
       "  '12': {},\n",
       "  '13': {},\n",
       "  '14': {},\n",
       "  '16': {},\n",
       "  '17': {},\n",
       "  '18': {},\n",
       "  '19': {},\n",
       "  '20': {},\n",
       "  '21': {},\n",
       "  '22': {},\n",
       "  '23': {},\n",
       "  '24': {},\n",
       "  '15': {}},\n",
       " 'train_num': 32149,\n",
       " 'test_num': 32149,\n",
       " 'idx_mapping': {'0': 0,\n",
       "  '1': 1,\n",
       "  '2': 2,\n",
       "  '3': 3,\n",
       "  '4': 4,\n",
       "  '5': 5,\n",
       "  '6': 6,\n",
       "  '7': 7,\n",
       "  '8': 8,\n",
       "  '9': 9,\n",
       "  '10': 10,\n",
       "  '11': 11,\n",
       "  '12': 12,\n",
       "  '13': 13,\n",
       "  '14': 14,\n",
       "  '15': 24,\n",
       "  '16': 15,\n",
       "  '17': 16,\n",
       "  '18': 17,\n",
       "  '19': 18,\n",
       "  '20': 19,\n",
       "  '21': 20,\n",
       "  '22': 21,\n",
       "  '23': 22,\n",
       "  '24': 23},\n",
       " 'inverse_idx_mapping': {'0': 0,\n",
       "  '1': 1,\n",
       "  '2': 2,\n",
       "  '3': 3,\n",
       "  '4': 4,\n",
       "  '5': 5,\n",
       "  '6': 6,\n",
       "  '7': 7,\n",
       "  '8': 8,\n",
       "  '9': 9,\n",
       "  '10': 10,\n",
       "  '11': 11,\n",
       "  '12': 12,\n",
       "  '13': 13,\n",
       "  '14': 14,\n",
       "  '24': 15,\n",
       "  '15': 16,\n",
       "  '16': 17,\n",
       "  '17': 18,\n",
       "  '18': 19,\n",
       "  '19': 20,\n",
       "  '20': 21,\n",
       "  '21': 22,\n",
       "  '22': 23,\n",
       "  '23': 24},\n",
       " 'idx_name_mapping': {'0': 'AGE',\n",
       "  '1': 'HRSWK',\n",
       "  '2': 'INCTOT',\n",
       "  '3': 'WKSWORK',\n",
       "  '4': 'ABIDENT',\n",
       "  '5': 'SEX',\n",
       "  '6': 'TENURE',\n",
       "  '7': 'URBAN',\n",
       "  '8': 'WKFULL',\n",
       "  '9': 'BPLMOM',\n",
       "  '10': 'BPLPOP',\n",
       "  '11': 'CITIZEN',\n",
       "  '12': 'CLASSWK',\n",
       "  '13': 'EMPSTAT',\n",
       "  '14': 'LANG',\n",
       "  '15': 'MARST',\n",
       "  '16': 'TRANWORK',\n",
       "  '17': 'RELATE',\n",
       "  '18': 'DEGREE',\n",
       "  '19': 'OCCISCO',\n",
       "  '20': 'YRIMM',\n",
       "  '21': 'MINORITY',\n",
       "  '22': 'RELIG',\n",
       "  '23': 'IND',\n",
       "  '24': 'BPL'},\n",
       " 'metadata': {'columns': {'0': {'sdtype': 'numerical',\n",
       "    'computer_representation': 'Float'},\n",
       "   '1': {'sdtype': 'numerical', 'computer_representation': 'Float'},\n",
       "   '2': {'sdtype': 'numerical', 'computer_representation': 'Float'},\n",
       "   '3': {'sdtype': 'numerical', 'computer_representation': 'Float'},\n",
       "   '4': {'sdtype': 'categorical'},\n",
       "   '5': {'sdtype': 'categorical'},\n",
       "   '6': {'sdtype': 'categorical'},\n",
       "   '7': {'sdtype': 'categorical'},\n",
       "   '8': {'sdtype': 'categorical'},\n",
       "   '9': {'sdtype': 'categorical'},\n",
       "   '10': {'sdtype': 'categorical'},\n",
       "   '11': {'sdtype': 'categorical'},\n",
       "   '12': {'sdtype': 'categorical'},\n",
       "   '13': {'sdtype': 'categorical'},\n",
       "   '14': {'sdtype': 'categorical'},\n",
       "   '16': {'sdtype': 'categorical'},\n",
       "   '17': {'sdtype': 'categorical'},\n",
       "   '18': {'sdtype': 'categorical'},\n",
       "   '19': {'sdtype': 'categorical'},\n",
       "   '20': {'sdtype': 'categorical'},\n",
       "   '21': {'sdtype': 'categorical'},\n",
       "   '22': {'sdtype': 'categorical'},\n",
       "   '23': {'sdtype': 'categorical'},\n",
       "   '24': {'sdtype': 'categorical'},\n",
       "   '15': {'sdtype': 'categorical'}}}}"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "aa"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (tabsyn)",
   "language": "python",
   "name": "tabsyn"
  },
  "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
