{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "from matplotlib import pyplot as plt\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_prefix = \"../../results_paper/\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2",
   "metadata": {},
   "source": [
    "### Sachs et al. Interventional Samples (Tb. 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def show_sachs_boxplots(path_prefix=os.path.join(path_prefix, \"res_sachs/\")):\n",
    "    methods = ['causal-mixtures_trueG', 'causal-mixtures', 'mix-utigsp']\n",
    "    method_names = ['CMM-G*', 'CMM', 'MixUT-IGSP']\n",
    "\n",
    "    for mth, nm in zip(methods, method_names):\n",
    "        plt.figure(figsize=(6, 5))\n",
    "        tb = pd.read_csv(os.path.join(path_prefix, f'results_ivtargets_m_{mth}.tsv'), sep='\\t')\n",
    "        tb.plot.bar(ylim=(0, 1))\n",
    "        plt.title(f\"Sachs et al. data, algo: {nm}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4",
   "metadata": {},
   "outputs": [],
   "source": [
    "show_sachs_boxplots()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5",
   "metadata": {},
   "source": [
    "### Sachs et al. Causal Discovery (Tb. 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def show_sachs_boxplot(metric=\"sd\", path_prefix=os.path.join(path_prefix, \"res_sachs/\")):\n",
    "    methods = ['causal-mixtures', 'mix-utigsp', 'cam', 'score', 'lingam', 'ges', 'pc-partial-correl', 'varsort', 'r2sort']\n",
    "    method_names = ['CMM', 'MixUT-IGSP', 'CAM','SCORE', 'LiNGAM', 'GES', 'PC', 'VarSort', 'R2Sort']\n",
    "\n",
    "    plt.figure(figsize=(6, 5))\n",
    "    method_metrics = []\n",
    "    for mth in methods:\n",
    "        tb = pd.read_csv(os.path.join(path_prefix, f'results_m_{mth}.tsv'), sep='\\t')\n",
    "        method_metrics.append(tb[f'{metric}'][0])\n",
    "\n",
    "    plt.bar(methods, method_metrics, label=method_names)#, color=bar_colors)\n",
    "    plt.title(f\"Sachs et al. data, metric: {metric}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7",
   "metadata": {},
   "outputs": [],
   "source": [
    "show_sachs_boxplot(\"f1\")\n",
    "show_sachs_boxplot(\"sc\")\n",
    "show_sachs_boxplot(\"sd\")"
   ]
  }
 ],
 "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
