{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/statsmodels/tools/_testing.py:19: FutureWarning: pandas.util.testing is deprecated. Use the functions in the public API at pandas.testing instead.\n",
      "  import pandas.util.testing as tm\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from dowhy.gcm.independence_test import kernel_based\n",
    "from dowhy.gcm.ml.regression import create_hist_gradient_boost_regressor\n",
    "from dowhy.gcm import AdditiveNoiseModel\n",
    "from experiments.structural_equations import *\n",
    "from experiments.data_generation import ExperimentationModel\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fitting causal mechanism of node x2: 100%|██████████| 2/2 [00:00<00:00, 566.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iter: 1\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.2079574085873882\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.1678242831611516\n",
      "Iter: 2\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.03772620313777508\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.8866167860445708\n",
      "Iter: 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:236: UserWarning: Numerical issues were encountered when centering the data and might not be solved. Dataset may contain too large values. You may need to prescale your features.\n",
      "  \"Numerical issues were encountered \"\n",
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:255: UserWarning: Numerical issues were encountered when scaling the data and might not be solved. The standard deviation of the data is probably very close to 0. \n",
      "  \"Numerical issues were encountered \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.15519688634120232\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.23055968852281938\n",
      "Iter: 4\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.06324440393969322\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.5365206662548172\n",
      "Iter: 5\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.5539858375620969\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.4978433842461426\n",
      "Iter: 6\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.5707749836657994\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.9286483258263042\n",
      "Iter: 7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:255: UserWarning: Numerical issues were encountered when scaling the data and might not be solved. The standard deviation of the data is probably very close to 0. \n",
      "  \"Numerical issues were encountered \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.00013527135243196486\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.013959671973815091\n",
      "Iter: 8\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:236: UserWarning: Numerical issues were encountered when centering the data and might not be solved. Dataset may contain too large values. You may need to prescale your features.\n",
      "  \"Numerical issues were encountered \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.01046764051647997\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.2328228126579882\n",
      "Iter: 9\n",
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.47630856928564735\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.7308245712623482\n",
      "Iter: 10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:236: UserWarning: Numerical issues were encountered when centering the data and might not be solved. Dataset may contain too large values. You may need to prescale your features.\n",
      "  \"Numerical issues were encountered \"\n",
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:255: UserWarning: Numerical issues were encountered when scaling the data and might not be solved. The standard deviation of the data is probably very close to 0. \n",
      "  \"Numerical issues were encountered \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.05192026209925027\n",
      "ANM - p-value X->Y using ANM (should be uniform on [0, 1]): 0.26931299432372824\n"
     ]
    }
   ],
   "source": [
    "##################################################\n",
    "####### CHANGE NUMBER OF SIMULATIONS HERE ########\n",
    "############ MORE SIMULATIONS BETTER #############\n",
    "##################################################\n",
    "n_simulations = 20\n",
    "##################################################\n",
    "\n",
    "n = 5000\n",
    "scm_type = \"bivariate\"\n",
    "equations_type = \"nonlinear\"\n",
    "g = get_graph(scm_type)\n",
    "structural_equations, noise_distributions = select_struct_and_noise(equations_type, scm_type)\n",
    "exper_model = ExperimentationModel(g, scm_type, structural_equations, noise_distributions)\n",
    "\n",
    "\n",
    "params = {'num_epochs': 2000,\n",
    "            'lr': 1e-4,\n",
    "            'batch_size': 64,\n",
    "            'use_positional_encoding': False,\n",
    "            'hidden_dim': 128,\n",
    "            'w': 0,\n",
    "            'verbose' : False\n",
    "            }\n",
    "\n",
    "\n",
    "def get_p_val(model, X, Y):\n",
    "    noise = model.estimate_noise(Y, X)\n",
    "    pval = kernel_based(X, noise)\n",
    "    return pval\n",
    "\n",
    "test_n = 1000\n",
    "\n",
    "dcm_pvals = []\n",
    "anm_pvals = []\n",
    "for i in range(10):\n",
    "    train, _ = exper_model.sample(n)\n",
    "    Xtr,Ytr = train.iloc[:,0], train.iloc[:,1]\n",
    "    print(\"Iter: \" + str(i+1))\n",
    "\n",
    "    dcm_xy = CausalDiffusionModel(**params)\n",
    "    dcm_yx = CausalDiffusionModel(**params)\n",
    "\n",
    "    anm_xy = AdditiveNoiseModel(create_hist_gradient_boost_regressor())\n",
    "    anm_yx = AdditiveNoiseModel(create_hist_gradient_boost_regressor())\n",
    "\n",
    "    dcm_xy.fit(Xtr, Ytr)\n",
    "    anm_xy.fit(Xtr, Ytr)\n",
    "\n",
    "   # dcm_yx.fit(Ytr, Xtr)\n",
    "   # anm_yx.fit(Ytr, Xtr)\n",
    "\n",
    "    test, _ = exper_model.sample(test_n)\n",
    "    Xte,Yte = test.iloc[:,0], test.iloc[:,1]\n",
    "    pval = get_p_val(dcm_xy, Xte, Yte)\n",
    "    dcm_pvals.append(pval)\n",
    "    print(\"DCM - p-value X->Y using DCM (should be uniform on [0, 1]):\", pval)\n",
    "   # print(\"DCM - p-value Y->X using DCM (should be < 0.05):\",\n",
    "    #     get_p_val(dcm_yx, Yte, Xte))\n",
    "    pval = get_p_val(anm_xy, Xte, Yte)\n",
    "    anm_pvals.append(pval)\n",
    "    print(\"ANM - p-value X->Y using ANM (should be uniform on [0, 1]):\", pval)\n",
    "    # print(\"ANM - p-value Y->X using ANM (should be < 0.05):\",\n",
    "    #      get_p_val(anm_yx, Yte, Xte))\n",
    "\n",
    "    # noise = dcm_xy.estimate_noise(Yte,Xte)\n",
    "    # plt.scatter(Xte,noise,s=3)\n",
    "    with open('dcm_pvals.npy', 'wb') as f:\n",
    "        np.save(f, np.array(dcm_pvals))\n",
    "    with open('anm_pvals.npy', 'wb') as f:\n",
    "        np.save(f, np.array(anm_pvals))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "# with open('dcm_pvals.npy', 'rb') as f:\n",
    "#     dcm_pvals = np.load(f)\n",
    "# with open('anm_pvals.npy', 'rb') as f:\n",
    "#     anm_pvals = np.load(f)\n",
    "\n",
    "with open('dcm_pvalsLESS.npy', 'rb') as f:\n",
    "    dcm_pvals = np.load(f)\n",
    "with open('anm_pvalsLESS.npy', 'rb') as f:\n",
    "    anm_pvals = np.load(f)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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>0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>100.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>0.196446</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>0.207855</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>0.000006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>0.029982</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>0.120709</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>0.283185</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>0.947162</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                0\n",
       "count  100.000000\n",
       "mean     0.196446\n",
       "std      0.207855\n",
       "min      0.000006\n",
       "25%      0.029982\n",
       "50%      0.120709\n",
       "75%      0.283185\n",
       "max      0.947162"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(dcm_pvals)\n",
    "df.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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>0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>100.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>0.419894</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>0.255811</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>0.000028</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>0.178426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>0.446340</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>0.624329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>0.894283</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                0\n",
       "count  100.000000\n",
       "mean     0.419894\n",
       "std      0.255811\n",
       "min      0.000028\n",
       "25%      0.178426\n",
       "50%      0.446340\n",
       "75%      0.624329\n",
       "max      0.894283"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(anm_pvals)\n",
    "df.describe()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.00386619, 0.51542697, 0.94716192])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.quantile(dcm_pvals,[0.1,0.9,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(31, 5)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(dcm_pvals<=0.05),np.sum(anm_pvals<=0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f8caea3bf90>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.log(dcm_pvals),alpha=0.5, label=\"DCM\")\n",
    "plt.hist(np.log(anm_pvals),alpha=0.5, label=\"ANM\")\n",
    "plt.title(\"Log p-values\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.xlabel(\"Log p-value\")\n",
    "plt.axvline(np.log(0.05),color=\"tomato\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAACMAAAAOCAYAAACl66WxAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAB4ElEQVQ4EZWV7U0CQRCGD2IBh3aAHYB2gB2IHQglGP/xz1CCWoFCB9IBQgfagcQOzve57EtWXO7WSSYzO1/77uxXp6qqwjSbzeZB/5I8F89l+7S/SSquL/80xJSSjMlfBdsvIftAhoV4KP0bZ8dgZNho/CC5xCFJQWxX0hsBhVgmNphC+kS5j+Kx9Ljms2w78YUYQD35azBdDZxYOinYCKAIBduIiSfKv44CX4N+bxuTigEH6BfbLWswGozFWxsjuZY+UjJdaiJyAV+vkEDl7HXGOXQSgkaST4kEF8RftzoRw8Sci17sk81dyulsndpVUhkXOaKfHrEnzaoJeC7DVHpqkck8OuOJ3IU4kIMG5QAuNDEHEiCXYrbuXZxNgMmhs5wggQEADDC2aSO5v03Ym4gD7NWn4tw13p1/kUBwxuj2QnpWZzkz3p5Ugm1t78xAddiiQ/I2sXWt5KvNbegnot2Z5CtKfFg1jyNbYvCJUu0mg+FZ5kU8pKEMW03i7h36AYMPXibiXPPoYuKCNRgV4frtJP02FNJZ5Y341gnYxJWYTsR0p8FbbFAMtajB9QZsK8V/E4k83T6sXE/+qvp2uJLGH9JXkvt/CJ/GnAtechPb/uejVBy7wFx0Dcl5ZI71D0X/tJJ4dDdBAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 0.31$"
      ],
      "text/plain": [
       "0.31"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(dcm_pvals < 0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "test, _ = exper_model.sample(n)\n",
    "Xte,Yte = test.iloc[:,0], test.iloc[:,1]\n",
    "noise = dcm_xy.estimate_noise(Yte,Xte)\n",
    "anm_noise = anm_xy.estimate_noise(Yte,Xte)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fbe79ea8d90>"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(Xte,anm_noise,s=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fbe7adb0710>"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXIAAAD4CAYAAADxeG0DAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAgNUlEQVR4nO3dbYxcV3kH8P9jT7ITm3hTKxuI42TtyAgTrDgWVtaVUFscWsclOE4lJLP9gNRKER/AWCqSYxIFl4baERJy7VZqowa1VbMYpIBxCVYIWRAg4QUnfsHEC1rFWhFMiKmJHWLtpmM//TB7Nnfv3pdz3++58/9JUbw7M/eemdl55tznPOccUVUQEZG7FlTdACIiyoaBnIjIcQzkRESOYyAnInIcAzkRkeNaVZz0xhtv1BUrVlRxaiIiZ73wwgu/U9UB/+8rCeQrVqzAsWPHqjg1EZGzRGQy6PdMrRAROY6BnIjIcQzkRESOYyAnInIcAzkRkeMYyImIHMdATkTkOKcC+cjYJDbseR4jY4GllEREPcmpQL5/dAKvXpzCgdGJqptCRFQbTgXy7RtX4eb+Nj61cVXVTSEiqo1KpuinNTw0iOGhwaqbQURUK5l75CJyq4h8T0TOiMjPReTTeTSMiIjs5NEj7wD4O1V9UUSuB/CCiDynqi/lcGwiIoqRuUeuqr9R1Rdn/v0GgDMAbsl6XCIispPrYKeIrACwDsBYwG0PisgxETl2/vz5PE9LRNTTcgvkIvIOAE8D2KGql/y3q+oTqrpeVdcPDMxbF52IqPGKmguTSyAXkWvQDeJPqerX8zgmEVHTFDUXJo+qFQHwJIAzqvql7E0iImqmoubCiKpmO4DIBwD8EMDPAFyd+fVnVfXbYY9Zv369cqs3IqJkROQFVV3v/33m8kNV/REAyXocIiJKx6kp+kRENB8DORGR4xjIiYgcx0BOROQ4BnIiogAubWTDQE5EFMCljWwYyImIAri0kY1TG0sQEZXFpY1s2CMnInIcAzkRkeMYyGvCpRFyojzxbz+7xgVyV/8oXBohJ8oT//aza1wgd/WPwqURcqI8Bf3tu9ohq0rmZWzTKHIZ25GxSRwYncCnNq5yZsSZiObasOd5vHpxCjf3t/HjXfdU3ZzaKGwZ27pxqWSIiOYbGZvE5ekO+tstXqFaalxqhYjctn90ApemOljU12KnzBIDORHVCseLkmtcaoWI3Mb0aHLskRMROY6BnIjIcT0fyFmvSpQNP0PV6/lA7uoEIqK64Geoej0fyDlCTpQNP0PVa9zMTiKqj5GxSewfncB2zrTORdjMzp7vkbuIOUlyBdMu5WAgz6CqgMoPB7mCaZdyMJBnUFVA5YeDXDE8NIgf77qHaZWCMZBnUFVA5YeDXMSUYHE4RT8DTiUmsue9guXnJl/skdcMey3UVEwJFoc98pphr4WailewxWGPvGbYayGX5X1FyStUOwzkNcOBTKpS1sCZdyUXS23tMJDXBHseVAdZA2feV5S8QrWTyxR9EfkygPsAvKaqa+Lu3+Qp+kmnJJv7X57u4NJUp/TNZjmFmry4eXm9FT1F/z8A3JvTsZyWtEdj7i9AJT0PXrrmpwlXVUztuSmXQK6qPwBwIY9juS7ppaC5/87Nqyv5APHSNT/8UrTThC+8uslt9UMRWQHgW2GpFRF5EMCDAHDbbbe9f3KSbyLTGs3CtISdDXuex6sXpwpNIzb1s1X56oeq+oSqrlfV9QMDA2WdttbYg2sWpiXeFtXrLuMqsNc+W6xaqRDTGtRUUYG0jC+8XvtsMZBXyPsHXXbekHnK5qjDe+lvQ9WBtNeujnIJ5CLyFQA/BvAeEXlFRP42j+P2krIvBXvt0rPJ6vBe+tvQa4G0anlVrXxMVW9W1WtUdbmqPpnHcXtJ2T2YqntMUerQw3RJlvcyr9d6w8qlWCDA0Mqls8e9c/ezuHP3s3wfS8A9O6l2wqoamlqJEKfI551XBYn/OOZnAFggwGNb1/TUe1aUyqtWKLte6amG9TDrkEIAyn8finje5jlsWLk0lysz/3u2feMqLGm3IACuKip/z5qOgdwheX2gywhE5hw7Dh5PfK6w/Gpd0kFFfqEEvTdFPG/zHMbOXpjzWqf92/C/Z8NDgzi1exO+8MCaWrxnTcdA7pC8PtBl9GzNOQ6fPJfoXFGBxAQLAJVemRT5hRL03hQxcGh6zG9Od+a8jnn/bXDQsxwM5A7J60MRFIjy7qWbc2xZuyxR0LMJJFWnWIoMTkm+JLK8Z8NDg1jU18Klqc6c17EuVz2UDAc7G8Q/KLbj4HF888Q59LUEj37kfZGBp4xp0zZsprn3+lT4vFbM7PXX0UVhg50M5A3iD8a373oGV2fe3iXtFk7t3hT62KI/1E2oOCnrOcSdx7zP/e0WFvW1GIh7CKtWeoD3snhkbBLXLpTZ2yTicUDxuUybdEjdq3LKSunEnafsFTPr/r4QA3mjeIPx/tEJTHUUS9qt2Q99kLI+pDa516pz33HKyh/HnafsAcSk7wsDf/kYyBvKBIOHZnptQHClR97BM+xDbBN8qhho23HwOG7f9Qx2HDwee9+yAmidKj1GxiZxebqD/nYr1wFryhcDuYNsezze0Y+wD1fewTPLh7iKAHb45Dlc1e7/y5K1x5rl8Ukfu390ApemOljU17J+X1j5Uj4GcgelKdEL+3BFrcCYJmAU/SG2bZPt/basXYYF0v1/WbL2WIMeb/t8k5477P20qfevwxVFr2Agd5BNsPTfx+bD5f+Qpwk4RX+I9x4Zx6sXp7D3yHjk/WwHV4+evYDHtq7Bvm3rErclKpgVubFC0ONt36ukder7QyqZmD6pFwZyR3gDg02wTBNQg9bLqOslclwVThmDq1GPj+o1A8j0ZRf03iZ5r0zKLW6FwqjnV+e/jV7EOnJHpJmw04Tabb886913HDyOwyfPYcvaZbE9cvNabli5FEfPXsD2mQB2YHQCQ57fedcs8bezDpOuvG1QYHaFwqA25fFaN/FvsEqsI3dcmh6Qv0eVJBUQ1lvLI4+eRZ6pm6NnL+CqAmNnL8TeN2jtGNOWo2cvWK2PUofxA28btm9chf52C0sCKlKi0ipJMAVTDgZyR+SRKkmSCjDVCv61OPLIo9eF//WxyWsHrR1je5yiF/3yvhc2bdg/OoEPrr4Ji/pa89qd1/vKFEw5mFqpgTKnfoddKvtvGxmbxONHxjHduYJrWwvx0ObVs7/33y/J5Xfcc81ye5bXcWRsEo8cOo2rGpxmSCIoheJtmwmSeaZYRsYmZweAH9q8OvYcpo0LBLPP2aRalrS7gV0A7Jx536kemFqpsbJ6tf5efdQA6vDQIE7u3oQbFvfN6ZX7e5VAsoE781wfOXQ68QBb3O1ZXsf9oxO4qt3dbPLeZMHftjy3ZjM/7z0yjktTHSyeqfeOO0fQFYZZ2vaNmSuxJLXjVC0G8op4P5BVXX7aBL4ku/XY5mhNLzBNNUTU7VleR7Pn5Ja1yzIHr7j8eJY8f1hqC0CiclNz+75t62bvZ5a2Vdh/oXE6fj0wtVKROlQwZKlKSFKV4U951HH51Dq8Hzb8KRQAub6WSd8bV163pmBqpWby7IXntT1XkuME9fj8O6kb3l7kjoPH8cih0xhaudQ68JTR64t7P+rS8/RvCBH0PoS1Na5u3Bw/ydUCBzPrgYG8InmW0eWVY896nLByPu+HPc3aJmXskQlE5/qrqM4JC8hxwTOsrf5KJO/x8+oMUDUYyBsgr95kmnU14h7vr0eOW9sk6Fx5PL+w+xQxtd323HHtDmtbXPAMa6sZzDQrGXqPb/79+JHxWlx5UDLMkfeArHnMLI9P+tik948qGwwq+etvt3BdX2t2huaGlUsxdvZCaElmlrJQ8/iwLdninmvRYwne4wPdXPubGbePo2IxR97DilikqajHJr1/VNlgUMmfqZU2MzTHzl4I7d0mSacE9a7N4wUI7SGn3UAirjdvc5XiPb7590ObVzPn7SD2yMlpSSY5eX83FNMT33tkHG91rqCvtXB2UkxUDz1sElBRPeq43jyrSZqJmy9T4ZqyQJIJgsDcdE1UcAwL2kGvSVA5ZtLZqv60SNA56lbiSdkxkPeQqgJqU3qBZnkCBWaXJjC/Txocg14T/++80+W3rF02ZyVFc9uSdguL+lrWVwPUTMyR95CqFrIKq1pJW1FibourfU4i6Fz+35nlCU7t3jQnaOaxcNnIWHcPTO+Kg97Zrt7VFb2PBxC6IBZruYmBvIGq/GD7r+/ivlRM1UnU+ilBqzCmFdSeIr/4/MHfPJ/FnnVMhocG8djWNfPWPvGWbnoHIf3tZS03MZA3UJYZm2mFBWSbyStRi1X5a59t2hG1jvqGlUtjl6ENOmaWqwr/84naO9W79ok3YHvfU/bAyY858h5QRg7VO0C4pN2ak1uOYpN3TpLz97YDALbe1d39x/8apDmmCZ6mosW7vG8RrzEHLMmPOfIGSdrDTtuDS1KrbM6xpN1dB2Sv5QxBm7RAktSH2fXG+OaJc4E9cZtNGLzH9KY1Lk11MNXROemeItZqqXPKpC5rz1BXLj1yEbkXwD8BWAjg31V1b9T92SPPpqwqhTS1yqYXaTtD0L+aX9jkl6Q9U7Mf57ULBVMdDZz1aY6ZZKOHHQeP49CJ7jox7Zbg0Y+8r5BVAuteyslKmWoU1iMXkYUA/gXAZgB3APiYiNyR9bgUrqwcaZq1wZPOELQZzLTtmXp7ifu2rcPLez6MRz/yvtj1X5K8nkc9C4L90eK+wlYJTLLfah7KusqjYmTukYvIHwPYraqbZn7eBQCquifsMeyRV6vK3l7QZJigmm3bx3vZ5sFtepOmR79lbTfH7j3/57/1Eqb+72qiHrkNb3uBueuMe2vNH9u6pvSZolQPRebIbwHwK8/Pr8z8zt+AB0XkmIgcO3/+fA6npbSKKLfz9+hsVxsMq9lO03b/euhh97XpTUYtt/tW5yoAYKqjge3IutrhI4dOA5i7rG7czkpZsYfttjwCuQT8bl43X1WfUNX1qrp+YGAgh9NSWkV8aMO2IPNvBff6m9MQzN98wty+Yc/z2HHweOikHTNoObRy6bz7+NdDjyv1i/riCFtu15RLCjA7qccfoKPWA4/6Ao0K1t5a8yKCbZ0HVileK/4usV4BcKvn5+UA7HcNoNKZ1e6Silo3xLscLNANSt61QIBuIJvqdL/jD588h7t9uwSZQGd6w6Z+2nubWa3QpAK8Xxz+NiR9nt7nt2/bujkpFcP7vPxb3Jn2Bj33sNfEyxwv7D5p3zdqvjxy5C0AvwRwD4BfA/gpgGFV/XnYY5gjd5PNuiF+/rzv3iPjeGOqA0Xw+uFhKxP6K1dsqk5sFqyKe342stZ7px2zyGOso+7VMTRXYTlyVe0A+CSAZwGcAfC1qCBObgjK5walKpJuO7aor4X771oWmfLwzm407QDmb8VmuiBhbfDvFXr7rmfw+W+9FJreSLNDkr8CxuYxca+R7WPzGOuoal0eyhdndva4sDruvKoYvNUfR89eSHzMsHbYtM/bUza7CAFvb/KQZQXDPNoX1M4ks0TzmPnJ2aNu4czOHmNbORFWx216p0GDikl4ByDTzH6M2n8ybuDPO4BnBi+33rUs1QqG/e0W3pzuzHsdsrQvqJ1JHpumvj7tMaje2CNvKNueYtTa21H7TdpK0uPL6yogr7yv9zhxsz+TnLPsvDRrxJuDPfIeY9tTDKvjNoELCN5vMk5UbjtJm9PMaMwr7+ut6w5aNTHtOcvOS7NGvPnYI6dAWXOnWXqBtj3hsJ5tXrljf4WNqZAJ2qINgPU5mZemtLjVG2WWJCUQNsXd5hxmYNIEz7CgV2TKwLvF2uK+VmCZY9iiYXUr56tjmygdplYosyQpAf8syzBBg6/ejSaiBuOKWp7Xe+yHNq8O3dAh6PzmNXrcchnfJG1Ky2aXJi5J6zb2yMlakpRA1H29JY8AcGmqM7u58IaAyUB5Pwdvj982XZPk+AdGJ/D7N6cx1VEsabdwavem2OMWeXUR975xMNQd7JFTZqZ3DCC2BxfVk/aWPAowZ3NhMwU/LIiaiT07Dh4HkLw3aXr8QPB6L1G9V5uFwczzvra1EMDbCxHZrLNS1ToqHAx1HwM5JZZkd52w2vAl7RbaLYEC8zYXjnLoRHcdFrO5Q9IKELMwFQB8b/w167r1oHNFzcg0z2fn5tWxxwXmBtuyUx2sJXcfAzkFigom/q3PogJp0O3DQ4M4tXsTbljch0tTncBlW8O0r1kw5/9Je5PeVQSnO1fw6sWpOWmeoKAWtvLiu67vi1w2V33ntb2a4bR5SoqBnAJFBZMkO7pH3Z5mje1H77sDN/e38eh9d8xri5fNbEZ/+iPs8f6VF81SA6d+fTF02dy0S9n6j0Nkg4OdFKisWueizpN0LZaw0sYlno2czczXqFUavccOWsMm6YAxywbJi3XkVKmip7D7HxO07G3UZJ6g5W6TbCIdJGs1iHl8f7uF6/paDOjEqhUqT1Bao+gp7EFbyHlTLt7p9qa3bPLjYXl8s4l02IJZcbIuPGYer0DmnHmWAVTWmdcfAznlLqia4/J0Z3ZrtDhROeKwoBIUNL33DcvHS8z5hocGcV1fa97qkGG85zRfBianbhuIzTF+cvYCFMDG1TdlzplnGUDl4Gv9MZBT7vyB0dSNL+5rWaUG4mrQg4KKP2juPTKORw6dnnPfd/S1Zr9MTHngB1ffNG9jCP+Xhc3go3mM6ekHLQlsG4i9W97Z1NbbyDKAysHX+mOOnAqX14CmdwBx4+qbcHRmjfOgBbNMbnuBAI9tXYO9R8ZxaaqD/nYLJ3dvmr1/0LK+UTM/w5jjtFuCt65o4Boztrl/m8FU6k3MkVMu0uRLh4cGZ0vysuRZvT37sHSFN7d9c38bj21dg+GhQVye7gAA3pz5vxF09eBd6yWIf3ap9zjXthaGrjFjm6II2vKOKAoDeY9KO4CVZAq7zeOSzAz1Bt0NK5fOmYzjf4w/XXJl5sLziu8CNGx3HvMFEOTwye7s0sMnz807zsbVN4W2iykKKgoDeY9KO4DlD0ZBE2eCpqybafn+6o8kM0O9QTdqdcWgJQTWLu/HAgHuv2tZqq3PRsYmcefuZ7v/3dI91rL+9ryeeVS7skyFZ+UIRWEg71Fpe4dhZX0HZnK//jSFNwgD3ZUOvVPik84M9U+XD5sx6p9h+ds3pvHyng9j37Z1qb7ETI790lRn9ljnLk7N65kX1evOu3KEXwzN0oq/CzXR8NBgLrnX7b6NH7zH3LByKQ6fPDcvzeCdEh/XDv/t/unycY/5ydkL89qwfeMq7D0yPnt1kPR1MEF6y9pls5tn2D6ftLyvcx6CvmTJXeyRUyZR6QJ/msG/ImASpgdpFqp65/V9Vj3KoFTH8NAgFiWoDfe2/R8feDt3vm/butleftHyXqGQ+fpmYfkhFSbPdVRMeZ+Z1GP+H1ciGNYGb4lfUBljHXCtFfLjWitUS2Zvzztv6cerb0yHBi1v4B0dfw1vda6gr7UQOz0LUpn7JQl+SdZDKSuwmvNczrDOCzUT68iplkwp34lXLkYO5nlrqxf1tTDVUSwKmCmaZqMJ2xRD1gFH2wFGcx6zexLTHxSHgZxiFVnhsGXtMiwQ4K7l/dZBK26Nc9vjBNWbe28L2z0o7SJYtpsgb1i5FEvardndk5hWoThMrVCstMux5rGRcdjj80hzRD0v722mjNGcK8vrYbsJslnxkGkV8mJqhVKL6+WG9dizpiKiHp9HXbVtz95/rrxq8KPOyaoSSoI9csosrIeatWolaJcd0xPf4FtQqsiByLTPg1UnlDdWrVBhwrY1y4P/SyLsSyMqFRLV7rwCrfcLxpQzmp583ukRfkH0LqZWKDHbQc40E2xs+VMMYSkHm42P/fKc9u5fQzxoyYK8cKMH8mMgp1BJAkaROV3vNaM/z2y+bADM/t62LVErKCZlzrll7bLZc+c9G9N/LtvXmuuqNB9TKxSqqB3uk4irEMmywXHQY5uYtsi6CTTVB1MrlFhRPcokwnqfNqsgpjl2E9MWrIBpvkw9chH5KIDdAN4L4G5Vtepms0dOWeXdywyrhiGqk6J65KcB/BWAH2Q8DvWgLLnbvHuZpic+Ov4agro2ReWZy8xfM1feXJkCuaqeUdVf5NUY6i1pt40DkqV9bAKY+WIAELjL0d4j46G7HyU9l1eZqZwmpo2oq7QcuYg8KCLHROTY+fPnyzot1UTY2iX9Adu/AfkFnZGxSTxy6HTsFwbw9oYR/e3WvF2O/AtYhbWvyEW70gjb85SaJTaQi8h3ReR0wH/3JzmRqj6hqutVdf3AwED6FpOTggLc8NAgrgupP7cNOkE72vvPa9YvDzqWt137RydwaaozZ1VF046dm1cHbtIcVc9uo+gB5bA9T6lZcik/FJHvA/gMBzsJCC7hi9vgIe3g4u27npkN1C/v+XBgW6KO770dQOXllnmrQwkp5afQKfoM5OSVZ0WJ90sBwLwvCLMxxZa1y7Bv27pG1oETGYUEchF5AMABAAMAXgdwQlU3xT2OgbzZitjizXZpV05+oSYrpPxQVb+hqstVtU9V32kTxKn5onKxSas6/Eu7Lmm38Ps3p3Hn7mcDj5FlQI/leeQqzuykUpnBt0cOnbYKmN4vBbM411RHAwdIo3b8SdI2lueRaxjIqVTbN67CAgGuKhIFTP82aN4SQSNrIA7qzbOXTi5oVd0A6i2mp+ytFLFhgvTY2Qs4tTs4g7d946rEx/W3LWoz57BePgdYqWrskVPpktYzj4xN4vJ0J7AXnuW4Nmxy7kWlZHg1QLYYyCl3eQYgMzPTP1GnKEFtj6vr4gYSVDUGcspd3jvvRM3MBLJ9cfgf62972HPxPq4uG0hQ72Igp9zlGYC8O+/sH50IDNZZvjj8jw3bWm5o5dLIgF8ETqknW9whiJwQNdFnZGwSjx8ZhyL55s+2k5f85y9q6jsHTikKdwgip0X18qMW34pj2+v1n7+o3jLz4pQGAzk5IS5wpk3nJMmvl3Htyrw4pcFA3kOaXs6WJtDa9oDL6ikzL05pMJD3kCZftsc9t7AvMdseMHvKVGcc7OwhTV6bOu65cVVEaoJC1yNPioGciuav/mjylxj1DlatkHOy5PT9qRbmnqnJGMiptrLk9JnTpl7CQE61lSUY2/TAm17FQ72DgZxqq8wd5uuIXzRki4Gcepa3x1/HoFn3LxqqDwZy6jkmaAOY7fHXMWgyz0+2GMjJaWE96agedlDQrmPQZKUN2WIgJ6eF9aSjethBQZtBk1zGQE5OC+tJx62WyKBNTcKZnUQBuC441RFndhIlUMfBT6IwDOREAeo4+EkUplV1A4jqaHhokCkVcgZ75EREjmMgJyJyHAM5EZHjGMiJiBzHQE5E5DgGciIixzGQExE5LlMgF5Evisi4iJwSkW+IyA05tYsoV3Vcb5woL1l75M8BWKOqdwL4JYBd2ZtElD9OuacmyxTIVfU7qtqZ+fEogOXZm0SUP065pybLbfVDEfkfAF9V1f8Ouf1BAA8CwG233fb+yUle4hIRJRG2+mHsWisi8l0A7wq46WFV/ebMfR4G0AHwVNhxVPUJAE8A3WVsLdtNREQxYgO5qn4o6nYR+TiA+wDco1Usbk5E1OMyrX4oIvcC2AngT1X1cj5NIiKiJLJWrfwzgOsBPCciJ0TkX3NoExERJZCpR66qLAEgIqoYZ3YSETmOgZyIyHEM5NQYnIZPvYqBnBqjjGn4/LKgOmIgp8YoYxo+12yhOspUtUJUJ8NDxe98v33jKhwYneCaLVQrDORECZTxZUGUFFMrRESOYyAnInIcAzkRkeMYyImIHMdATkTkOAZyahRO2KFexEBOjcIJO9SLGMipUbjJMvUiTgiiRuGEHepF7JETETmOgZyIyHEM5EREjmMgJyJyHAM5EZHjGMiJiBzHQE5E5DhR1fJPKnIeQFFzqG8E8LuCjl0ktrtcbHe52O58DKrqgP+XlQTyIonIMVVdX3U7kmK7y8V2l4vtLhZTK0REjmMgJyJyXBMD+RNVNyAltrtcbHe52O4CNS5HTkTUa5rYIyci6ikM5EREjmtkIBeRfxCRUyJyQkS+IyLLqm6TDRH5ooiMz7T9GyJyQ9VtsiEiHxWRn4vIVRGpfamWiNwrIr8QkQkReajq9tgQkS+LyGsicrrqtiQhIreKyPdE5MzM38inq26TDRFpi8hPROTkTLv/vuo2RWlkjlxElqjqpZl/bwdwh6p+ouJmxRKRvwAwqqodEXkcAFR1Z8XNiiUi7wVwFcC/AfiMqh6ruEmhRGQhgF8C+HMArwD4KYCPqepLlTYshoj8CYA/APgvVV1TdXtsicjNAG5W1RdF5HoALwDY6sDrLQAWq+ofROQaAD8C8GlVPVpx0wI1skdugviMxQCc+LZS1e+oamfmx6MAllfZHluqekZVf1F1OyzdDWBCVV9W1bcAHARwf8VtiqWqPwBwoep2JKWqv1HVF2f+/QaAMwBuqbZV8bTrDzM/XjPzX23jSCMDOQCIyBdE5FcA/hrAo1W3J4W/AXCk6kY00C0AfuX5+RU4EFiaQERWAFgHYKziplgRkYUicgLAawCeU9XattvZQC4i3xWR0wH/3Q8Aqvqwqt4K4CkAn6y2tW+La/fMfR4G0EG37bVg025HSMDvatvTagoReQeApwHs8F0x15aqXlHVu9C9Mr5bRGqb0nJ282VV/ZDlXUcAPAPgcwU2x1pcu0Xk4wDuA3CP1mgAI8HrXXevALjV8/NyAOcqaktPmMkxPw3gKVX9etXtSUpVXxeR7wO4F0AtB5ud7ZFHEZF3e37cAmC8qrYkISL3AtgJYIuqXq66PQ31UwDvFpGVInItgG0ADlfcpsaaGTR8EsAZVf1S1e2xJSIDpmpMRK4D8CHUOI40tWrlaQDvQbeSYhLAJ1T119W2Kp6ITADoA/C/M7866ki1zQMADgAYAPA6gBOquqnSRkUQkb8EsA/AQgBfVtUvVNuieCLyFQB/hu6yqr8F8DlVfbLSRlkQkQ8A+CGAn6H7eQSAz6rqt6trVTwRuRPAf6L7N7IAwNdU9fPVtipcIwM5EVEvaWRqhYiolzCQExE5joGciMhxDORERI5jICcichwDORGR4xjIiYgc9/95CDfbB2xw6AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DCM - p-value X->Y using DCM (should be uniform on [0, 1]): 0.0\n",
      "DCM - p-value Y->X using DCM (should be < 0.05): 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/preprocessing/_data.py:255: UserWarning: Numerical issues were encountered when scaling the data and might not be solved. The standard deviation of the data is probably very close to 0. \n",
      "  \"Numerical issues were encountered \"\n"
     ]
    }
   ],
   "source": [
    "from causallearn.utils.KCI.KCI import KCI_UInd\n",
    "print(\"DCM - p-value X->Y using DCM (should be uniform on [0, 1]):\", \n",
    "      get_p_val(dcm_xy, Xte, Yte))\n",
    "print(\"DCM - p-value Y->X using DCM (should be < 0.05):\",\n",
    "          get_p_val(dcm_yx, Yte, Xte))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle \\left( 0.0, \\  2581.75691934226\\right)$"
      ],
      "text/plain": [
       "(0.0, 2581.7569193422587)"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Xte = Xte.values.reshape(-1,1)\n",
    "KCI_UInd().compute_pvalue(Xte, dcm_xy.estimate_noise(Yte, Xte))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "import random\n",
    "def random_dag(num_nodes, p = 0.3):\n",
    "    graph = nx.DiGraph()\n",
    "    nodes = list(range(num_nodes))\n",
    "    graph.add_nodes_from(nodes)\n",
    "\n",
    "    for i in nodes:\n",
    "        for j in nodes[i + 1:]:\n",
    "            if random.random() < p:\n",
    "                graph.add_edge(i, j)\n",
    "\n",
    "    return graph\n",
    "g = random_dag(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "OutEdgeView([(0, 2), (0, 9), (1, 4), (1, 6), (1, 7), (2, 3), (3, 7), (4, 6), (6, 7), (8, 9)])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "g.edges()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.4 ('base')",
   "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.4"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "40d3a090f54c6569ab1632332b64b2c03c39dcf918b08424e98f38b5ae0af88f"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
