{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import statistics\n",
    "\n",
    "import numpy as np\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# after running ./scripts/run_cd.sh\n",
    "# results read from ../../results_paper/res_e2/$EXPERIMENT_IDF$/$BASE_PARAMS_IDF$/tikzfiles/change/\n",
    "path_prefix = \"../../results_paper/\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2",
   "metadata": {},
   "source": [
    "### Line Plots \"Discovering Causal Graphs\" (Fig. 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.exp.config import exp_default_parameters, ExpType\n",
    "from src.exp.gen.generate import NoiseType, IvType, FunType, DagType, IvMode, GSType\n",
    "from matplotlib import pyplot as plt\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "def show_mixing_line(exp, params, attribute, metric=\"sd\", path_prefix=os.path.join(path_prefix, \"res_e2/\")):\n",
    "    pth = os.path.join(path_prefix,  f\"CD_F_{exp['F'].value}_NS_{exp['NS'].value}_DG_{exp['DG'].value}_IVT_{exp['IVT'].value}_IVM_{exp['IVM'].value}_GS_{exp['GS']}/N_{params['N']}_S_{params['S']}_P_{params['P']}_C_{params['C']}_K_{params['K']}_PZ_{params['PZ']}_NZ_{params['NZ']}/tikzfiles/change/\")\n",
    "    methods = ['causal-mixtureshatGhatZ','cam', 'score', 'lingam', 'fci', 'ges', 'pc-partial-correl', 'varsort', 'r2sort']\n",
    "    method_names = ['CMM', 'CAM','SCORE', 'LiNGAM', 'FCI', 'GES', 'PC', 'VarSort', 'R2Sort']\n",
    "    plt.figure(figsize=(6, 5))\n",
    "    for mth in methods:\n",
    "        tb = pd.read_csv(os.path.join(pth, f'change_{attribute}_m_{mth}.tsv'), sep='\\t')\n",
    "        tb[f'{metric}_mn'].plot()\n",
    "    plt.legend(method_names)\n",
    "    plt.title(f\"change {attribute}, metric {metric}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.exp.config import exp_base_parameters\n",
    "experiment = { 'NS': NoiseType.GAUSS, 'F': FunType.LIN, 'DG': DagType.ERDOS,  'IVT': IvType.FLIP, 'IVM': IvMode.MIXING, 'GS': GSType.GRAPH}\n",
    "params = exp_base_parameters(ExpType.CAUSAL_DISCOVERY)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5",
   "metadata": {},
   "outputs": [],
   "source": [
    "for metric in [\"sc\", \"f1\"]:\n",
    "    show_mixing_line(experiment, params, \"N\", metric)\n",
    "    show_mixing_line(experiment, params, \"S\", metric)\n",
    "    show_mixing_line(experiment, params, \"PZ\", metric)\n",
    "    show_mixing_line(experiment, params, \"P\", metric)\n",
    "    show_mixing_line(experiment, params, \"NZ\", metric)"
   ]
  }
 ],
 "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
}
