{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "chubby-assembly",
   "metadata": {},
   "source": [
    "This notebook contains the code for an example of running our algorithm on Dixit perturb-seq real dataset. We also run UT-IGSP algorithm and generate the ROC figures for both methods via running the algorithms with different hyperparameters. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "eastern-arlington",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import time\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.colors as mcolors\n",
    "import os"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "nominated-ratio",
   "metadata": {},
   "source": [
    "Import the ground truth model and auxiliary functions for Dixit dataset."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "continued-supplement",
   "metadata": {},
   "outputs": [],
   "source": [
    "from realdata.dixit.dixit_meta import EFFECTIVE_NODES, DIXIT_FIGURES_FOLDER\n",
    "from realdata.dixit.dixit_meta import dixit_get_samples, nnodes, true_B_dixit_paper\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "nasty-bargain",
   "metadata": {},
   "source": [
    "Import our algorithm and the necessary components from causaldag package to run UT-IGSP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "passing-mouth",
   "metadata": {},
   "outputs": [],
   "source": [
    "from functions import run_ours_real\n",
    "from causaldag import unknown_target_igsp\n",
    "from causaldag import MemoizedCI_Tester, MemoizedInvarianceTester, gauss_invariance_test, gauss_invariance_suffstat\n",
    "from causaldag import partial_correlation_test, partial_correlation_suffstat\n",
    "from causaldag import hsic_test, hsic_invariance_test, kci_test, kci_invariance_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fuzzy-henry",
   "metadata": {},
   "outputs": [],
   "source": [
    "ALGS2COLORS = dict(zip(['ours','utigsp_gauss', 'utigsp_star_gauss', 'utigsp_hsic','utigsp_star_hsic'],\\\n",
    "                       mcolors.BASE_COLORS))\n",
    "ALGS2MARKERS = {'ours':'o','utigsp_gauss': 'P', 'utigsp_star_gauss': '*', 'utigsp_hsic': 'X', 'utigsp_star_hsic': 'x'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "average-statement",
   "metadata": {},
   "outputs": [],
   "source": [
    "# conventionally accepted ground truth DAG and skeleton\n",
    "B = true_B_dixit_paper.copy()\n",
    "np.fill_diagonal(B, 0)\n",
    "correct_skeleton = B + B.T\n",
    "correct_skeleton[np.where(correct_skeleton)] = 1\n",
    "n_possible_skeleton = int(nnodes*(nnodes-1)/2)\n",
    "n_true_skeleton = int(np.sum(correct_skeleton)/2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "acceptable-philadelphia",
   "metadata": {},
   "source": [
    "Create the functions to run UT-IGSP algorithm (ours is already imported) and the function to interpret the results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "military-bench",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_utigsp_real(setting_list,obs_samples,iv_samples_list,ci_test='gauss',alpha=1e-3,alpha_i=1e-5,no_targets=True):\n",
    "    if ci_test == 'gauss':\n",
    "        obs_suffstat = partial_correlation_suffstat(obs_samples)\n",
    "        invariance_suffstat = gauss_invariance_suffstat(obs_samples, iv_samples_list)\n",
    "        ci_tester = MemoizedCI_Tester(partial_correlation_test, obs_suffstat, alpha=alpha)\n",
    "        invariance_tester = MemoizedInvarianceTester(gauss_invariance_test, invariance_suffstat, alpha=alpha_i)\n",
    "    elif ci_test == 'hsic':\n",
    "        hsic_invariance_suffstat = {iv: samples for iv, samples in enumerate(iv_samples_list)}\n",
    "        hsic_invariance_suffstat['obs_samples'] = obs_samples\n",
    "        ci_tester = MemoizedCI_Tester(hsic_test, obs_samples, alpha=alpha)\n",
    "        invariance_tester = MemoizedInvarianceTester(hsic_invariance_test,hsic_invariance_suffstat,alpha=alpha_i)\n",
    "    elif ci_test == 'kci':\n",
    "        kci_invariance_suffstat = {iv: samples for iv, samples in enumerate(iv_samples_list)}\n",
    "        kci_invariance_suffstat['obs_samples'] = obs_samples\n",
    "        ci_tester = MemoizedCI_Tester(kci_test, obs_samples, alpha=alpha)\n",
    "        invariance_tester = MemoizedInvarianceTester(kci_invariance_test,kci_invariance_suffstat,alpha=alpha_i)        \n",
    "\n",
    "    t_start = time.time()\n",
    "    est_dag, learned_interventions = unknown_target_igsp(\n",
    "        setting_list,\n",
    "        set(range(nnodes)),\n",
    "        ci_tester,\n",
    "        invariance_tester,\n",
    "        no_targets = no_targets,\n",
    "        nruns=10)\n",
    "    \n",
    "    t_past = time.time() - t_start\n",
    "    est_dag = est_dag.to_amat()[0]\n",
    "    est_skeleton = est_dag+est_dag.T\n",
    "    est_skeleton[np.where(est_skeleton)] = 1\n",
    "    \n",
    "    return est_dag, est_skeleton, learned_interventions, t_past\n",
    "\n",
    "def read_results(file, B, skeleton, nodes='all', method='utigsp',delete_bi_directions=False):\n",
    "    tp = []\n",
    "    fp = []\n",
    "    tp_skeleton = []\n",
    "    fp_skeleton = []\n",
    "    for vals in file.keys():\n",
    "        if method == 'utigsp':\n",
    "            estimated_dag = file[vals]['estimated_dag']\n",
    "        else:\n",
    "            estimated_dag = file[vals]['estimated_cpdag']\n",
    "            if delete_bi_directions == True:\n",
    "                estimated_dag[np.where(estimated_dag*estimated_dag.T)] = 0\n",
    "            \n",
    "        estimated_skeleton = file[vals]['estimated_skeleton']\n",
    "        if nodes == 'all':\n",
    "            tp.append(int(np.sum(estimated_dag*B)))\n",
    "            fp.append(int(np.sum(estimated_dag)-tp[-1]))\n",
    "            tp_skeleton.append(int(np.sum(estimated_skeleton*skeleton)/2))\n",
    "            fp_skeleton.append(int(np.sum(estimated_skeleton)/2 - tp_skeleton[-1]))    \n",
    "        else:\n",
    "            tp.append(int(np.sum(estimated_dag[:,EFFECTIVE_NODES]*B[:,EFFECTIVE_NODES])))\n",
    "            fp.append(int(np.sum(estimated_dag[:,EFFECTIVE_NODES])-tp[-1]))\n",
    "            tp_skeleton.append(int(np.sum(estimated_skeleton[:,EFFECTIVE_NODES]*skeleton[:,EFFECTIVE_NODES]))-\\\n",
    "                               int(np.sum(estimated_skeleton[EFFECTIVE_NODES][:,EFFECTIVE_NODES]*skeleton[EFFECTIVE_NODES][:,EFFECTIVE_NODES])))\n",
    "            fp_skeleton.append(int(np.sum(estimated_skeleton[:,EFFECTIVE_NODES]) -\\\n",
    "                                   np.sum(estimated_skeleton[EFFECTIVE_NODES][:,EFFECTIVE_NODES]) - tp_skeleton[-1]))                \n",
    "    \n",
    "    return tp, fp, tp_skeleton, fp_skeleton"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "brazilian-cornell",
   "metadata": {},
   "source": [
    "Load the data, build the sufficient stats and the format to feed to the algorithms."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "complex-penalty",
   "metadata": {},
   "outputs": [],
   "source": [
    "I_nodes = EFFECTIVE_NODES\n",
    "n_knock = len(I_nodes)\n",
    "obs_samples, setting_list = dixit_get_samples()\n",
    "# get only the interventional data for 8 targets\n",
    "setting_list = [setting for setting in setting_list if list(setting['known_interventions'])[0] in I_nodes]\n",
    "iv_samples_list = [setting['samples'] for setting in setting_list]\n",
    "# build the sufficient stats\n",
    "S_obs = (obs_samples.T@obs_samples)/obs_samples.shape[0]\n",
    "S_int = {}\n",
    "for idx_setting in range(len(setting_list)):\n",
    "    samples_current = setting_list[idx_setting]['samples']\n",
    "    S_current = (samples_current.T @ samples_current)/samples_current.shape[0]\n",
    "    S_int['setting_%d'%idx_setting] = S_current"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "german-karen",
   "metadata": {},
   "source": [
    "We note that our algorithm uses ADMM-based $\\Delta_\\Theta$ estimation at several stages, which calls for different $\\lambda$ sparsity regularization parameters. Their choice can be dependent on the properties of the data.\n",
    "\n",
    "We use $\\lambda_1$ in paper, *lambda_l1* below, for estimating $\\Delta_\\Theta$ over a number of nodes, e.g., initial estimation over $p$ nodes and running the algorithm for each group. $\\lambda_2$ in paper, *pair_l1* below, is used while building root ancestor sets, $J_k^k$'s in paper. More importantly for causal discovery, $\\lambda_3$ in paper, *parent_l1* below, is used for parent discovery step. First two parameters do not affect the results much, the last one acts as a thresholder. We vary these parameters below to generate multiple instances and ROC curve."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "played-princeton",
   "metadata": {},
   "outputs": [],
   "source": [
    "'Our algorithm'\n",
    "# for Delta_Theta estimations\n",
    "lambda_l1 = 0.1\n",
    "# for J0 threshold\n",
    "single_threshold = 0.05\n",
    "# for building J0 descendants\n",
    "pair_l1 = 0.05\n",
    "# remove the small values after J0 descendants built\n",
    "pair_threshold = 0.005\n",
    "# always taken one. ADMM parameter\n",
    "rho = 1.0\n",
    "\n",
    "# this is more important one. Penalty parameter for parent selection\n",
    "parent_l1_list = [0.005,0.01,0.02,0.03,0.04,0.05,0.06,0.08,0.09,0.10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "empty-savage",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [8, 3]\n",
      "Al_sizes: [4, 1, 1]\n",
      "Al_sizes: [2, 2, 1]\n",
      "Al_sizes: [1, 1, 1]\n",
      "Al_sizes: [2, 1, 3]\n",
      "Al_sizes: [4, 1]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6, 3]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [5, 1]\n",
      "Al_sizes: [2]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [7]\n",
      "Al_sizes: [4]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [6, 2]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [5]\n",
      "Al_sizes: [3]\n",
      "Al_sizes: [6]\n",
      "Al_sizes: [6]\n"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "for parent_l1 in parent_l1_list:\n",
    "    parameters = (lambda_l1, single_threshold, pair_l1, pair_threshold, parent_l1, rho) \n",
    "    results[parameters] = {}\n",
    "    est_cpdag, est_skeleton, I_hat_all, I_hat_parents_all, Ij_hat_parents_all, N_lists_all, A_groups_all, time_all = \\\n",
    "        run_ours_real(S_obs,S_int,lambda_l1,single_threshold,pair_l1,pair_threshold,parent_l1,rho)  \n",
    "        \n",
    "    results[parameters]['estimated_cpdag'] = est_cpdag\n",
    "    results[parameters]['estimated_skeleton'] = est_skeleton\n",
    "    results[parameters]['I_hat'] = I_hat_all\n",
    "    results[parameters]['I_hat_parents'] = I_hat_parents_all\n",
    "    results[parameters]['Ij_hat_parents'] = Ij_hat_parents_all\n",
    "    results[parameters]['N_lists'] = N_lists_all\n",
    "    results[parameters]['A_groups'] = A_groups_all\n",
    "    results[parameters]['time'] = time_all"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eastern-relay",
   "metadata": {},
   "source": [
    "UT-IGSP algorithm is run with and without known targets for different $\\alpha$ cut-off values for CI tests."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "right-fireplace",
   "metadata": {},
   "outputs": [],
   "source": [
    "'UTIGSP Gauss without targets'\n",
    "alpha_i = 1e-5\n",
    "alpha_list = [1e-3, 2e-3, 5e-3, 1e-2, 2e-2]\n",
    "utigsp_star_gauss = {}\n",
    "\n",
    "for alpha in alpha_list:\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha] = {}\n",
    "    est_dag, est_skeleton, learned_interventions, t_past = \\\n",
    "        run_utigsp_real(setting_list,obs_samples,iv_samples_list,ci_test='gauss',alpha=alpha,alpha_i=alpha_i,no_targets=True)\n",
    "\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha]['alpha_i'] = alpha_i\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha]['estimated_dag'] = est_dag\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha]['estimated_skeleton'] = est_skeleton\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha]['estimated_interventions'] = learned_interventions\n",
    "    utigsp_star_gauss['alpha_%.3f'%alpha]['time'] = t_past   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "attended-finish",
   "metadata": {},
   "outputs": [],
   "source": [
    "'UTIGSP Gauss with targets'\n",
    "alpha_i = 1e-5\n",
    "alpha_list = [1e-3, 2e-3, 5e-3, 1e-2, 2e-2]\n",
    "utigsp_gauss = {}\n",
    "\n",
    "for alpha in alpha_list:\n",
    "    utigsp_gauss['alpha_%.3f'%alpha] = {}\n",
    "    est_dag, est_skeleton, learned_interventions, t_past = \\\n",
    "        run_utigsp_real(setting_list,obs_samples,iv_samples_list,ci_test='gauss',alpha=alpha,alpha_i=alpha_i,no_targets=False)\n",
    "\n",
    "    utigsp_gauss['alpha_%.3f'%alpha]['alpha_i'] = alpha_i\n",
    "    utigsp_gauss['alpha_%.3f'%alpha]['estimated_dag'] = est_dag\n",
    "    utigsp_gauss['alpha_%.3f'%alpha]['estimated_skeleton'] = est_skeleton\n",
    "    utigsp_gauss['alpha_%.3f'%alpha]['estimated_interventions'] = learned_interventions\n",
    "    utigsp_gauss['alpha_%.3f'%alpha]['time'] = t_past    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "authentic-young",
   "metadata": {},
   "source": [
    "From the estimated models, infer the true positives and false positives."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "developing-ambassador",
   "metadata": {},
   "outputs": [],
   "source": [
    "ours_tp, ours_fp, ours_tp_skeleton, ours_fp_skeleton = read_results(results, B, correct_skeleton,method='ours')\n",
    "\n",
    "utigsp_gauss_tp, utigsp_gauss_fp, utigsp_gauss_tp_skeleton, utigsp_gauss_fp_skeleton = \\\n",
    "    read_results(utigsp_gauss, B, correct_skeleton,method='utigsp')\n",
    "\n",
    "utigsp_star_gauss_tp, utigsp_star_gauss_fp, utigsp_star_gauss_tp_skeleton, utigsp_star_gauss_fp_skeleton = \\\n",
    "    read_results(utigsp_star_gauss, B, correct_skeleton,method='utigsp')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "failing-liberal",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure('directed')\n",
    "plt.scatter(utigsp_gauss_fp,utigsp_gauss_tp,label='UTIGSP',marker=ALGS2MARKERS['utigsp_gauss'],color=ALGS2COLORS['utigsp_gauss'])\n",
    "plt.scatter(utigsp_star_gauss_fp,utigsp_star_gauss_tp,label='UTIGSP*',marker=ALGS2MARKERS['utigsp_star_gauss'],color=ALGS2COLORS['utigsp_star_gauss'])\n",
    "plt.scatter(ours_fp,ours_tp,label='ours',marker=ALGS2MARKERS['ours'],color=ALGS2COLORS['ours'])\n",
    "plt.xlim([0,50])\n",
    "plt.ylim([0,16])\n",
    "plt.title('Directed Edges')\n",
    "plt.xlabel('False positives')\n",
    "plt.ylabel('True positives')\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.savefig(os.path.join(DIXIT_FIGURES_FOLDER, 'example_dixit_directed_gauss.png'))\n",
    "\n",
    "plt.figure('skeleton')\n",
    "plt.scatter(utigsp_gauss_fp_skeleton,utigsp_gauss_tp_skeleton,label='UTIGSP',marker=ALGS2MARKERS['utigsp_gauss'],color=ALGS2COLORS['utigsp_gauss'])\n",
    "plt.scatter(utigsp_star_gauss_fp_skeleton,utigsp_star_gauss_tp_skeleton,label='UTIGSP*',marker=ALGS2MARKERS['utigsp_star_gauss'],color=ALGS2COLORS['utigsp_star_gauss'])\n",
    "plt.scatter(ours_fp_skeleton,ours_tp_skeleton,label='ours',marker=ALGS2MARKERS['ours'],color=ALGS2COLORS['ours'])\n",
    "plt.plot([0, n_possible_skeleton - n_true_skeleton], [0, n_true_skeleton], color='grey')\n",
    "plt.xlim([0,100])\n",
    "plt.ylim([0,18])\n",
    "plt.title('Skeleton')\n",
    "plt.xlabel('False positives')\n",
    "plt.ylabel('True positives')\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.savefig(os.path.join(DIXIT_FIGURES_FOLDER, 'example_dixit_skeleton_gauss.eps'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "professional-glance",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
