{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualizations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "\n",
    "path_base = \"results/real_data\"\n",
    "\n",
    "with open(path_base + \"/results.pickle\", \"rb\") as f:\n",
    "    smaller_results = pickle.load(f)\n",
    "\n",
    "\n",
    "data_names = [\"credit\", \"adult\", \"gmsc\"]\n",
    "\n",
    "results = {}\n",
    "for data_name in data_names:\n",
    "    results[data_name] = {}\n",
    "    results[data_name] = {\n",
    "        \"LiCE_optimize\": smaller_results[data_name][\"LiCE_optimize\"],\n",
    "        \"LiCE_median\": smaller_results[data_name][\"LiCE_median\"],\n",
    "        \"LiCE_quartile\": smaller_results[data_name][\"LiCE_quartile\"],\n",
    "        \"LiCE_sample\": smaller_results[data_name][\"LiCE_sample\"],\n",
    "        \"MIO + SPN\": smaller_results[data_name][\"MIO_no_spn\"],\n",
    "\n",
    "        \"VAE + SPN\": smaller_results[data_name][\"VAE\"],\n",
    "        \"DiCE + SPN\": smaller_results[data_name][\"DiCE\"],\n",
    "        \"CH-CVAE \": smaller_results[data_name][\"CVAE\"],\n",
    "        \"FACE_knn\": smaller_results[data_name][\"FACE_knn\"],\n",
    "        \"FACE_eps\": smaller_results[data_name][\"FACE_eps\"],\n",
    "        \"PROPLACE\": smaller_results[data_name][\"PROPLACE\"],\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LL value difference\n",
      "\tgmsc\t\tadult\t\tcredit\n",
      "true & \\scinum{-25.6180484331279} $\\pm$ \\scinum{4.642900031468152} & \\scinum{-18.14528819185729} $\\pm$ \\scinum{3.8878962458968647} & \\scinum{-28.785663175658833} $\\pm$ \\scinum{3.2769836465496667} \n",
      "mio & \\scinum{-25.709163152902526} $\\pm$ \\scinum{4.706936630938196} & \\scinum{-18.67192853775819} $\\pm$ \\scinum{4.10411216765172} & \\scinum{-29.013268255882007} $\\pm$ \\scinum{3.3415703166261443} \n",
      "diff & \\scinum{0.09111471977462675} $\\pm$ \\scinum{0.5700239585170246} & \\scinum{0.5266403459009045} $\\pm$ \\scinum{0.4698927020652466} & \\scinum{0.22760508022317458} $\\pm$ \\scinum{0.24096795119989892} \n"
     ]
    }
   ],
   "source": [
    "res_type = \"valid\"\n",
    "# res_type = \"actionable\"\n",
    "method = \"LiCE_optimize\"\n",
    "\n",
    "data_names = [\"gmsc\", \"adult\", \"credit\"]\n",
    "\n",
    "print(\"LL value difference\")\n",
    "print(\"\\t\" + \"\\t\\t\".join(data_names))\n",
    "print(\"true \", end=\"\")\n",
    "for data_name in data_names:\n",
    "    curr_res = results[data_name][method]\n",
    "    mean_ll = np.mean([res[res_type][\"ll\"] for res in curr_res.values() if res_type in res])\n",
    "    print(f\"& \\\\scinum{{{mean_ll}}} $\\\\pm$ \\\\scinum{{{np.std([res[res_type]['ll'] for res in curr_res.values() if res_type in res])}}} \", end=\"\")\n",
    "print()\n",
    "print(\"mio \", end=\"\")\n",
    "for data_name in data_names:\n",
    "    curr_res = results[data_name][method]\n",
    "    mean_ll_comp = np.mean([res[res_type][\"comp_ll\"] for res in curr_res.values() if res_type in res])\n",
    "    print(f\"& \\\\scinum{{{mean_ll_comp}}} $\\\\pm$ \\\\scinum{{{np.std([res[res_type]['comp_ll'] for res in curr_res.values() if res_type in res])}}} \", end=\"\")\n",
    "print()\n",
    "print(\"diff \", end=\"\")\n",
    "for data_name in data_names:\n",
    "    curr_res = results[data_name][method]\n",
    "    ll_diff = np.array([res[res_type][\"ll\"] for res in curr_res.values() if res_type in res]) - np.array([res[res_type][\"comp_ll\"] for res in curr_res.values() if res_type in res])\n",
    "    print(f\"& \\\\scinum{{{np.mean(ll_diff)}}} $\\\\pm$ \\\\scinum{{{np.std(ll_diff)}}} \", end=\"\")\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "& DiCE (\\uline{+spn}) & \\scinumone{29.10625689186585} $\\pm$ \\scinumone{5.182592246765204} & \\scinumone{27.34425644482405} $\\pm$ \\scinumone{6.665083118856582} & \\scinumone{6.496} $\\pm$ \\scinumone{1.0816579866112948} & \\scinumone{21.024686408227474} $\\pm$ \\scinumone{2.992416842221361} & \\scinumone{26.695823501370704} $\\pm$ \\scinumone{13.122152911830844} & \\scinumone{4.484969939879759} $\\pm$ \\scinumone{1.782028563379273} & \\scinumone{50.95000214113616} $\\pm$ \\scinumone{17.90368498481968} & \\scinumone{27.747628768160773} $\\pm$ \\scinumone{7.203097131076084} & \\scinumone{8.699596774193548} $\\pm$ \\scinumone{2.128076482372827} \\\\\n",
      "& VAE (\\uline{+spn}) & \\scinumone{17.95752152874899} $\\pm$ \\scinumone{2.205400482961012} & \\scinumone{17.15942423141453} $\\pm$ \\scinumone{3.7009726214613} & \\scinumone{8.0} $\\pm$ \\scinumone{1.1547005383792515} & \\scinumone{18.362415899918965} $\\pm$ \\scinumone{3.6099620553232543} & \\scinumone{37.05019368637985} $\\pm$ \\scinumone{13.158852411535614} & \\scinumone{5.390977443609023} $\\pm$ \\scinumone{1.4926784715876806} & \\scinumone{48.54317674715526} $\\pm$ \\scinumone{17.0628902991916} & \\scinumone{28.212745562426505} $\\pm$ \\scinumone{7.511628604013739} & \\scinumone{10.787234042553191} $\\pm$ \\scinumone{1.8899079141448896} \\\\\n",
      "& C-CHVAE & \\scinumone{25.616566158757887} $\\pm$ \\scinumone{2.410857392446074} & \\scinumone{17.99335831372717} $\\pm$ \\scinumone{4.746923856806097} & \\scinumone{8.33254716981132} $\\pm$ \\scinumone{0.7302604359944351} & \\scinumone{18.007649473999095} $\\pm$ \\scinumone{3.4397625799099187} & \\scinumone{8.217931817789482} $\\pm$ \\scinumone{5.197693892322199} & \\scinumone{2.8208955223880596} $\\pm$ \\scinumone{0.896516860757087} & \\scinumone{32.257157094150415} $\\pm$ \\scinumone{3.5797010278231043} & \\scinumone{12.948161617856272} $\\pm$ \\scinumone{4.786269684886356} & \\scinumone{6.637931034482759} $\\pm$ \\scinumone{1.5051437766363736} \\\\\n",
      "& FACE ($\\epsilon$) & \\scinumone{29.392524453725336} $\\pm$ \\scinumone{7.581153748022734} & \\scinumone{14.866606930247457} $\\pm$ \\scinumone{3.9675212447051322} & \\scinumone{8.431174089068826} $\\pm$ \\scinumone{1.1481016888375437} & \\scinumone{14.912364556401291} $\\pm$ \\scinumone{2.8987584965375586} & \\scinumone{15.217606413865454} $\\pm$ \\scinumone{9.073043597351564} & \\scinumone{3.7753164556962027} $\\pm$ \\scinumone{1.2840889352091927} & \\scinumone{43.16661950289423} $\\pm$ \\scinumone{17.61017812598399} & \\scinumone{18.428480079929262} $\\pm$ \\scinumone{6.013189343290098} & \\scinumone{7.042857142857143} $\\pm$ \\scinumone{1.4085018817951251} \\\\\n",
      "& FACE (knn) & \\scinumone{28.98930183234408} $\\pm$ \\scinumone{7.688843596748492} & \\scinumone{15.01510792048053} $\\pm$ \\scinumone{4.236335047036035} & \\scinumone{8.414979757085021} $\\pm$ \\scinumone{1.1434810388589314} & \\scinumone{14.523970255558003} $\\pm$ \\scinumone{2.7729545513327243} & \\scinumone{14.299111738532563} $\\pm$ \\scinumone{7.788558435302829} & \\scinumone{3.6967418546365916} $\\pm$ \\scinumone{1.1892435248640822} & \\scinumone{44.19549389622956} $\\pm$ \\scinumone{17.48755426880034} & \\scinumone{18.643903376259544} $\\pm$ \\scinumone{6.2774523896337255} & \\scinumone{7.0638297872340425} $\\pm$ \\scinumone{1.544667174587287} \\\\\n",
      "& PROPLACE & \\scinumone{27.862626870033896} $\\pm$ \\scinumone{4.289795027596067} & \\scinumone{12.873487843678653} $\\pm$ \\scinumone{3.157686833827407} & \\scinumone{6.386639676113361} $\\pm$ \\scinumone{1.1776871434377294} & \\scinumone{15.380170148150535} $\\pm$ \\scinumone{2.418937736509839} & \\scinumone{23.236144357072323} $\\pm$ \\scinumone{8.604355814800948} & \\scinumone{4.7819548872180455} $\\pm$ \\scinumone{1.3016570075804852} & \\scinumone{38.37978594132448} $\\pm$ \\scinumone{15.17718760578021} & \\scinumone{24.389774081866044} $\\pm$ \\scinumone{6.680465142294482} & \\scinumone{8.957446808510639} $\\pm$ \\scinumone{1.314794919291514} \\\\\n",
      "& MIO (\\uline{+spn}) & \\scinumone{27.866216730694337} $\\pm$ \\scinumone{6.561448994020041} & \\scinumone{5.856167992542774} $\\pm$ \\scinumone{1.5236477613603152} & \\scinumone{2.09} $\\pm$ \\scinumone{0.816026960338934} & \\scinumone{17.7958828931424} $\\pm$ \\scinumone{3.7720799232709408} & \\scinumone{5.815903319170079} $\\pm$ \\scinumone{3.8398249641328888} & \\scinumone{2.244} $\\pm$ \\scinumone{0.9404594621779293} & \\scinumone{43.584538056112685} $\\pm$ \\scinumone{17.53393732196536} & \\scinumone{4.394075599496093} $\\pm$ \\scinumone{2.820349696903412} & \\scinumone{2.3400402414486923} $\\pm$ \\scinumone{1.074239424166205} \\\\\n",
      "& LiCE (optim.) & \\scinumone{25.6180484331279} $\\pm$ \\scinumone{4.642900031468152} & \\scinumone{5.871975675449956} $\\pm$ \\scinumone{1.5692862455704235} & \\scinumone{2.564} $\\pm$ \\scinumone{1.0685990829118281} & \\scinumone{18.14528819185729} $\\pm$ \\scinumone{3.8878962458968647} & \\scinumone{5.621326073950837} $\\pm$ \\scinumone{3.836000929223799} & \\scinumone{2.07} $\\pm$ \\scinumone{1.0045396955820114} & \\scinumone{28.785663175658833} $\\pm$ \\scinumone{3.2769836465496667} & \\scinumone{4.391437014356211} $\\pm$ \\scinumone{2.837272642851949} & \\scinumone{2.2696177062374248} $\\pm$ \\scinumone{1.1574891539784886} \\\\\n",
      "& LiCE (quart.) & \\scinumone{27.02581829625766} $\\pm$ \\scinumone{3.6541985919993056} & \\scinumone{5.7958046754567825} $\\pm$ \\scinumone{1.537387735544409} & \\scinumone{1.74} $\\pm$ \\scinumone{0.7696752561957543} & \\scinumone{18.398455237685592} $\\pm$ \\scinumone{3.6079451843915678} & \\scinumone{5.682450805492205} $\\pm$ \\scinumone{3.915689734601706} & \\scinumone{2.08} $\\pm$ \\scinumone{1.0225458424931373} & \\scinumone{39.09685614607912} $\\pm$ \\scinumone{15.037858240535053} & \\scinumone{4.298850022441022} $\\pm$ \\scinumone{2.81292729046722} & \\scinumone{1.9537223340040242} $\\pm$ \\scinumone{1.0727422256349126} \\\\\n",
      "& LiCE (sample) & \\scinumone{20.46178693614155} $\\pm$ \\scinumone{4.164355940410764} & \\scinumone{9.898428720433277} $\\pm$ \\scinumone{3.551480404901545} & \\scinumone{4.189801699716714} $\\pm$ \\scinumone{1.3800308800163896} & \\scinumone{14.347531762391048} $\\pm$ \\scinumone{2.7084895375799944} & \\scinumone{8.486433409382506} $\\pm$ \\scinumone{5.76335924514419} & \\scinumone{2.7177914110429446} $\\pm$ \\scinumone{1.2654405981360375} & \\scinumone{30.98416192656248} $\\pm$ \\scinumone{6.083974307319718} & \\scinumone{4.335079503699477} $\\pm$ \\scinumone{2.8519840355678916} & \\scinumone{2.0301810865191148} $\\pm$ \\scinumone{1.15459652093768} \\\\\n",
      "& LiCE (median) & \\scinumone{18.339971231941952} $\\pm$ \\scinumone{2.1705020128868937} & \\scinumone{10.991793505652852} $\\pm$ \\scinumone{3.381991266009829} & \\scinumone{4.376666666666667} $\\pm$ \\scinumone{1.1610866557764852} & \\scinumone{12.863731934272424} $\\pm$ \\scinumone{1.020329080754504} & \\scinumone{9.73520944742331} $\\pm$ \\scinumone{6.555911307790609} & \\scinumone{2.9955849889624724} $\\pm$ \\scinumone{1.3794383874794596} & \\scinumone{29.911151664342015} $\\pm$ \\scinumone{3.140483844993052} & \\scinumone{4.372400589776368} $\\pm$ \\scinumone{2.8773888613627907} & \\scinumone{2.084507042253521} $\\pm$ \\scinumone{1.157992699025639} \\\\\n",
      "\n",
      "\n",
      "valid actionable\n",
      "&DiCE (\\uline{+spn}) & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{99.8}\\% & \\scinumone{65.4}\\% & \\scinumone{99.2}\\% & \\scinumone{3.4000000000000004}\\% \\\\\n",
      "&VAE (\\uline{+spn}) & \\scinumone{1.2}\\% & \\scinumone{0.2}\\% & \\scinumone{79.80000000000001}\\% & \\scinumone{22.6}\\% & \\scinumone{28.199999999999996}\\% & \\scinumone{0.0}\\% \\\\\n",
      "&C-CHVAE & \\scinumone{84.8}\\% & \\scinumone{21.2}\\% & \\scinumone{13.4}\\% & \\scinumone{9.0}\\% & \\scinumone{11.600000000000001}\\% & \\scinumone{9.6}\\% \\\\\n",
      "&FACE ($\\epsilon$) & \\scinumone{98.8}\\% & \\scinumone{15.8}\\% & \\scinumone{63.2}\\% & \\scinumone{31.2}\\% & \\scinumone{28.000000000000004}\\% & \\scinumone{10.4}\\% \\\\\n",
      "&FACE (knn) & \\scinumone{98.8}\\% & \\scinumone{14.799999999999999}\\% & \\scinumone{79.80000000000001}\\% & \\scinumone{45.4}\\% & \\scinumone{28.199999999999996}\\% & \\scinumone{11.200000000000001}\\% \\\\\n",
      "&PROPLACE & \\scinumone{98.8}\\% & \\scinumone{34.2}\\% & \\scinumone{79.80000000000001}\\% & \\scinumone{54.800000000000004}\\% & \\scinumone{28.199999999999996}\\% & \\scinumone{9.6}\\% \\\\\n",
      "&MIO (\\uline{+spn}) & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{99.4}\\% & \\scinumone{99.4}\\% \\\\\n",
      "&LiCE (optim.) & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{99.4}\\% & \\scinumone{99.4}\\% \\\\\n",
      "&LiCE (quart.) & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{100.0}\\% & \\scinumone{99.4}\\% & \\scinumone{99.4}\\% \\\\\n",
      "&LiCE (sample) & \\scinumone{70.6}\\% & \\scinumone{70.6}\\% & \\scinumone{97.8}\\% & \\scinumone{97.8}\\% & \\scinumone{99.4}\\% & \\scinumone{99.4}\\% \\\\\n",
      "&LiCE (median) & \\scinumone{60.0}\\% & \\scinumone{60.0}\\% & \\scinumone{90.60000000000001}\\% & \\scinumone{90.60000000000001}\\% & \\scinumone{99.4}\\% & \\scinumone{99.4}\\% \\\\\n",
      "\n",
      "\n",
      "TIME\n",
      "DiCE & \\scinum{27.554261050001514}s & \\scinum{18.397285150000243}s & \\scinum{145.2109368499996}s \\\\\n",
      "VAE & \\scinum{0.7027929499963648}s & \\scinum{0.9159553500003312}s & \\scinum{0.665724100000034}s \\\\\n",
      "C-CHVAE & \\scinum{0.4693015999999943}s & \\scinum{0.6607097500000805}s & \\scinum{0.5561984000000066}s \\\\\n",
      "FACE ($\\epsilon$) & \\scinum{9.253137449999969}s & \\scinum{7.251108299999942}s & \\scinum{5.084518550000041}s \\\\\n",
      "FACE (knn) & \\scinum{6.6794177499999705}s & \\scinum{7.123655649999932}s & \\scinum{5.172697150000033}s \\\\\n",
      "PROPLACE & \\scinum{0.24579905000064173}s & \\scinum{0.352189250000265}s & \\scinum{0.29431544999999915}s \\\\\n",
      "MIO & \\scinum{0.8029172304959502}s & \\scinum{1.5212002155021764}s & \\scinum{1.5597039720014436}s \\\\\n",
      "LiCE (optimize) & \\scinum{132.7203930024989}s & \\scinum{34.38838112049416}s & \\scinum{3.1153807135087845}s \\\\\n",
      "LiCE (quartile) & \\scinum{19.27427208700101}s & \\scinum{10.642477315996075}s & \\scinum{2.7065230645057454}s \\\\\n",
      "LiCE (sample) & \\scinum{124.3165388024936}s & \\scinum{14.336067685493617}s & \\scinum{2.860192965497845}s \\\\\n",
      "LiCE (median) & \\scinum{122.49571805945016}s & \\scinum{17.70222161700076}s & \\scinum{2.9302646345095127}s \\\\\n"
     ]
    }
   ],
   "source": [
    "method_order = [\n",
    "    \"DiCE + SPN\",\n",
    "    \"VAE + SPN\",\n",
    "    \"CH-CVAE \",\n",
    "    \"FACE_eps\",\n",
    "    \"FACE_knn\",\n",
    "    \"PROPLACE\",\n",
    "    'MIO + SPN',\n",
    "    'LiCE_optimize',\n",
    "    'LiCE_quartile',\n",
    "    'LiCE_sample',\n",
    "    'LiCE_median',\n",
    "]\n",
    "method_map = {\n",
    "    \"DiCE + SPN\" : \"DiCE\",\n",
    "    \"VAE + SPN\": \"VAE\",\n",
    "    \"CH-CVAE \": \"C-CHVAE\",\n",
    "    \"FACE_eps\": \"FACE ($\\\\epsilon$)\",\n",
    "    \"FACE_knn\": \"FACE (knn)\",\n",
    "    \"PROPLACE\": \"PROPLACE\",\n",
    "    'LiCE_optimize': \"LiCE (optimize)\",\n",
    "    'LiCE_quartile': \"LiCE (quartile)\",\n",
    "    'LiCE_sample': \"LiCE (sample)\",\n",
    "    'LiCE_median': \"LiCE (median)\",\n",
    "    'MIO + SPN': \"MIO\",\n",
    "}\n",
    "method_map_short = {k:v for k,v in method_map.items()}\n",
    "method_map_short['LiCE_optimize'] = \"LiCE (optim.)\"\n",
    "method_map_short['LiCE_quartile'] = \"LiCE (quart.)\"\n",
    "method_map_short['LiCE_median'] = \"LiCE (median)\"\n",
    "method_map_short['MIO + SPN'] = \"MIO (\\\\uline{+spn})\"\n",
    "method_map_short[\"DiCE + SPN\"] = \"DiCE (\\\\uline{+spn})\"\n",
    "method_map_short['VAE + SPN'] = \"VAE (\\\\uline{+spn})\"\n",
    "\n",
    "res_type = \"valid\"\n",
    "\n",
    "for method in method_order:\n",
    "    print(\"& \" + method_map_short[method], end=\"\")\n",
    "    for data_name in [\"gmsc\", \"adult\", \"credit\"]:\n",
    "        curr_res = results[data_name][method]\n",
    "        spar = [res[res_type][\"sparsity\"] for res in curr_res.values() if res_type in res]\n",
    "        nll = [-res[res_type][\"ll\"] for res in curr_res.values() if res_type in res]\n",
    "        dist = [res[res_type][\"distance\"] for res in curr_res.values() if res_type in res]\n",
    "        for d in [nll, dist, spar]:\n",
    "            print(f\" & \\\\scinumone{{{np.mean(d)}}} $\\\\pm$ \\\\scinumone{{{np.std(d)}}}\", end=\"\")\n",
    "    print(\" \\\\\\\\\")\n",
    "\n",
    "print(\"\\n\\nvalid actionable\")\n",
    "for method in method_order:\n",
    "    print(\"&\" + method_map_short[method], end=\"\")\n",
    "    for data_name in [\"gmsc\", \"adult\", \"credit\"]:\n",
    "        curr_res = results[data_name][method]\n",
    "        val = [\"valid\" in res for res in curr_res.values()]\n",
    "        act = [\"actionable\" in res for res in curr_res.values()]\n",
    "        for d in [val, act]:\n",
    "            print(f\" & \\\\scinumone{{{np.mean(d)*100}}}\\\\%\", end=\"\")\n",
    "    print(\" \\\\\\\\\")\n",
    "\n",
    "\n",
    "print(\"\\n\\nTIME\")\n",
    "for method in method_order:\n",
    "    print(method_map[method], end=\"\")\n",
    "    for data_name in [\"gmsc\", \"adult\", \"credit\"]:\n",
    "        curr_res = results[data_name][method]\n",
    "        time = [res[\"time\"] for res in curr_res.values()]\n",
    "        for d in [time]:\n",
    "            print(f\" & \\\\scinum{{{np.median(d)}}}s\", end=\"\")\n",
    "    print(\" \\\\\\\\\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'gmsc': 254, 'adult': 55, 'credit': 56}\n",
      "DiCE (\\uline{+spn}) & \\scinumone{28.103874532656263} $\\pm$ \\scinumone{5.502861442487442} & \\scinumone{28.451628992662673} $\\pm$ \\scinumone{6.525698069047968} & \\scinumone{6.582677165354331} $\\pm$ \\scinumone{1.097175650289786} & \\scinumone{19.824268128084924} $\\pm$ \\scinumone{2.5968090149044296} & \\scinumone{22.861493088500712} $\\pm$ \\scinumone{6.148794719362975} & \\scinumone{4.090909090909091} $\\pm$ \\scinumone{1.443137078762504} & \\scinumone{35.10076510249688} $\\pm$ \\scinumone{2.962354972612703} & \\scinumone{22.093721763150263} $\\pm$ \\scinumone{4.619429460202573} & \\scinumone{7.625} $\\pm$ \\scinumone{1.8761900985012914} \\\\\n",
      "VAE (\\uline{+spn}) & - & - & - & \\scinumone{17.85207693716387} $\\pm$ \\scinumone{2.785874577263402} & \\scinumone{31.91471250642849} $\\pm$ \\scinumone{9.734174357728024} & \\scinumone{5.0} $\\pm$ \\scinumone{1.2358287613066494} & \\scinumone{46.18310370969824} $\\pm$ \\scinumone{16.99755806547317} & \\scinumone{27.794408407952353} $\\pm$ \\scinumone{6.184796545036988} & \\scinumone{10.732142857142858} $\\pm$ \\scinumone{1.787766677695261} \\\\\n",
      "C-CHVAE & \\scinumone{25.824226652150266} $\\pm$ \\scinumone{2.524844926530808} & \\scinumone{18.23883026585549} $\\pm$ \\scinumone{4.779710257839793} & \\scinumone{8.326771653543307} $\\pm$ \\scinumone{0.7473784965793667} & \\scinumone{17.3335217282021} $\\pm$ \\scinumone{3.039848899668282} & \\scinumone{7.529566068087307} $\\pm$ \\scinumone{4.901026603361893} & \\scinumone{2.6363636363636362} $\\pm$ \\scinumone{0.7946099412149874} & \\scinumone{32.12617055008118} $\\pm$ \\scinumone{3.4830996779256393} & \\scinumone{12.86771892007172} $\\pm$ \\scinumone{4.829811377303758} & \\scinumone{6.625} $\\pm$ \\scinumone{1.482788155565627} \\\\\n",
      "FACE ($\\epsilon$) & \\scinumone{28.762684666166475} $\\pm$ \\scinumone{6.603250437475102} & \\scinumone{15.165656737177658} $\\pm$ \\scinumone{4.128060579010106} & \\scinumone{8.456692913385826} $\\pm$ \\scinumone{1.1654873301419597} & \\scinumone{14.121332261358372} $\\pm$ \\scinumone{2.5923356853407435} & \\scinumone{9.286817332739286} $\\pm$ \\scinumone{6.519195754838216} & \\scinumone{2.672727272727273} $\\pm$ \\scinumone{1.0278759290983688} & \\scinumone{42.00023406820758} $\\pm$ \\scinumone{17.46551962508634} & \\scinumone{17.74299836274508} $\\pm$ \\scinumone{5.02131569762876} & \\scinumone{7.017857142857143} $\\pm$ \\scinumone{1.469828360103065} \\\\\n",
      "FACE (knn) & \\scinumone{28.518917503252837} $\\pm$ \\scinumone{6.868664423549906} & \\scinumone{15.400884561380062} $\\pm$ \\scinumone{4.387393178538073} & \\scinumone{8.385826771653543} $\\pm$ \\scinumone{1.1875153979572814} & \\scinumone{13.88656134552211} $\\pm$ \\scinumone{2.767061087906256} & \\scinumone{8.876320534517383} $\\pm$ \\scinumone{5.952808165110323} & \\scinumone{2.7636363636363637} $\\pm$ \\scinumone{1.0083945180990581} & \\scinumone{42.794723488508566} $\\pm$ \\scinumone{17.803823614080322} & \\scinumone{18.60902678478356} $\\pm$ \\scinumone{5.3937972979774145} & \\scinumone{7.142857142857143} $\\pm$ \\scinumone{1.469068842943081} \\\\\n",
      "PROPLACE & \\scinumone{27.827140654322154} $\\pm$ \\scinumone{4.531715006199955} & \\scinumone{13.292335265584011} $\\pm$ \\scinumone{3.234283576299283} & \\scinumone{6.468503937007874} $\\pm$ \\scinumone{1.2442751289169098} & \\scinumone{15.133937270176977} $\\pm$ \\scinumone{2.2565620939026334} & \\scinumone{19.200531239218176} $\\pm$ \\scinumone{7.008461828457941} & \\scinumone{3.8727272727272726} $\\pm$ \\scinumone{1.0278759290983688} & \\scinumone{37.09766272930455} $\\pm$ \\scinumone{14.79786941628895} & \\scinumone{22.784133896210108} $\\pm$ \\scinumone{4.655047880326478} & \\scinumone{8.75} $\\pm$ \\scinumone{1.242836617236094} \\\\\n",
      "MIO (\\uline{+spn}) & \\scinumone{27.070623343674395} $\\pm$ \\scinumone{6.272343137182528} & \\scinumone{6.239665600187307} $\\pm$ \\scinumone{1.4587653161808867} & \\scinumone{2.078740157480315} $\\pm$ \\scinumone{0.838129706503003} & \\scinumone{15.83039802771636} $\\pm$ \\scinumone{3.6088751565858344} & \\scinumone{3.1296583622348857} $\\pm$ \\scinumone{2.2054558810464764} & \\scinumone{1.6363636363636365} $\\pm$ \\scinumone{0.6705123241667555} & \\scinumone{34.118002946496645} $\\pm$ \\scinumone{12.029091917446449} & \\scinumone{2.2920537967044026} $\\pm$ \\scinumone{1.317131226013349} & \\scinumone{1.875} $\\pm$ \\scinumone{0.7574039307303034} \\\\\n",
      "LiCE (optim.) & \\scinumone{24.42161951749979} $\\pm$ \\scinumone{5.359837511068675} & \\scinumone{6.275389200523003} $\\pm$ \\scinumone{1.5165235796255487} & \\scinumone{2.641732283464567} $\\pm$ \\scinumone{1.0838790751683045} & \\scinumone{16.405229066312216} $\\pm$ \\scinumone{3.857049546171445} & \\scinumone{2.872337343190369} $\\pm$ \\scinumone{2.2068604860041483} & \\scinumone{1.4363636363636363} $\\pm$ \\scinumone{0.7074573257579534} & \\scinumone{28.79574999638109} $\\pm$ \\scinumone{3.385456896757974} & \\scinumone{2.2913550120528283} $\\pm$ \\scinumone{1.2817847259944493} & \\scinumone{1.6785714285714286} $\\pm$ \\scinumone{0.7816453081514033} \\\\\n",
      "LiCE (median) & \\scinumone{18.281495255522557} $\\pm$ \\scinumone{2.1613049122249155} & \\scinumone{11.104395283070122} $\\pm$ \\scinumone{3.277462880636033} & \\scinumone{4.34251968503937} $\\pm$ \\scinumone{1.179217656375854} & \\scinumone{12.53089367102274} $\\pm$ \\scinumone{1.1861790765347522} & \\scinumone{6.115913931324642} $\\pm$ \\scinumone{4.631996465527181} & \\scinumone{2.109090909090909} $\\pm$ \\scinumone{1.0561116895605531} & \\scinumone{29.849448853453488} $\\pm$ \\scinumone{2.8400750844081486} & \\scinumone{2.3038349640876605} $\\pm$ \\scinumone{1.2976130195669229} & \\scinumone{1.4107142857142858} $\\pm$ \\scinumone{0.6485364213333885} \\\\\n"
     ]
    }
   ],
   "source": [
    "# ONLY SAME \n",
    "res_type = \"valid\"\n",
    "\n",
    "method_order = [m for m in method_order if \"sample\" not in m and \"quart\" not in m]  \n",
    "\n",
    "same_is = {}\n",
    "for data_name in data_names:\n",
    "    same_is[data_name] = []\n",
    "    methods = method_order\n",
    "    if data_name == \"gmsc\":\n",
    "        methods = [m for m in methods if m != \"VAE + SPN\"]\n",
    "    for i in results[data_name][methods[0]].keys():\n",
    "        if all(res_type in results[data_name][method][i] for method in methods):\n",
    "            same_is[data_name].append(i)\n",
    "print({k: len(v) for k, v in same_is.items()})\n",
    "\n",
    "for method in method_order:\n",
    "    print(method_map_short[method], end=\"\")\n",
    "    for data_name in [\"gmsc\", \"adult\", \"credit\"]:\n",
    "        if data_name == \"gmsc\" and method == \"VAE + SPN\":\n",
    "            print(\" & - & - & -\", end=\"\")\n",
    "            continue\n",
    "        curr_res = results[data_name][method]\n",
    "        spar = [curr_res[i][res_type][\"sparsity\"] for i in same_is[data_name]]\n",
    "        nll = [-curr_res[i][res_type][\"ll\"] for i in same_is[data_name]]\n",
    "        dist = [curr_res[i][res_type][\"distance\"] for i in same_is[data_name]]\n",
    "        for d in [nll, dist, spar]:\n",
    "            print(f\" & \\\\scinumone{{{np.mean(d)}}} $\\\\pm$ \\\\scinumone{{{np.std(d)}}}\", end=\"\")\n",
    "    print(\" \\\\\\\\\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
