{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MultiGroupDirectLiNGAM"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import and settings\n",
    "In this example, we need to import `numpy`, `pandas`, and `graphviz` in addition to `lingam`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:40.886776Z",
     "start_time": "2021-06-25T04:05:36.015299Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1.16.2', '0.24.2', '0.11.1', '1.5.4']\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import graphviz\n",
    "import lingam\n",
    "from lingam.utils import print_causal_directions, print_dagc, make_dot\n",
    "\n",
    "print([np.__version__, pd.__version__, graphviz.__version__, lingam.__version__])\n",
    "\n",
    "np.set_printoptions(precision=3, suppress=True)\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test data\n",
    "We generate two datasets consisting of 6 variables."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:40.949179Z",
     "start_time": "2021-06-25T04:05:40.886776Z"
    }
   },
   "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>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.239321</td>\n",
       "      <td>15.340724</td>\n",
       "      <td>4.104399</td>\n",
       "      <td>0.548814</td>\n",
       "      <td>14.176947</td>\n",
       "      <td>9.249925</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.155632</td>\n",
       "      <td>16.630954</td>\n",
       "      <td>4.767220</td>\n",
       "      <td>0.715189</td>\n",
       "      <td>12.775458</td>\n",
       "      <td>9.189045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.284116</td>\n",
       "      <td>15.910406</td>\n",
       "      <td>4.139736</td>\n",
       "      <td>0.602763</td>\n",
       "      <td>14.201794</td>\n",
       "      <td>9.273880</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.343420</td>\n",
       "      <td>14.921457</td>\n",
       "      <td>3.519820</td>\n",
       "      <td>0.544883</td>\n",
       "      <td>15.580067</td>\n",
       "      <td>9.723392</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.314940</td>\n",
       "      <td>11.055176</td>\n",
       "      <td>3.146972</td>\n",
       "      <td>0.423655</td>\n",
       "      <td>7.604743</td>\n",
       "      <td>5.312976</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0         x1        x2        x3         x4        x5\n",
       "0  2.239321  15.340724  4.104399  0.548814  14.176947  9.249925\n",
       "1  2.155632  16.630954  4.767220  0.715189  12.775458  9.189045\n",
       "2  2.284116  15.910406  4.139736  0.602763  14.201794  9.273880\n",
       "3  2.343420  14.921457  3.519820  0.544883  15.580067  9.723392\n",
       "4  1.314940  11.055176  3.146972  0.423655   7.604743  5.312976"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x3 = np.random.uniform(size=1000)\n",
    "x0 = 3.0*x3 + np.random.uniform(size=1000)\n",
    "x2 = 6.0*x3 + np.random.uniform(size=1000)\n",
    "x1 = 3.0*x0 + 2.0*x2 + np.random.uniform(size=1000)\n",
    "x5 = 4.0*x0 + np.random.uniform(size=1000)\n",
    "x4 = 8.0*x0 - 1.0*x2 + np.random.uniform(size=1000)\n",
    "X1 = pd.DataFrame(np.array([x0, x1, x2, x3, x4, x5]).T ,columns=['x0', 'x1', 'x2', 'x3', 'x4', 'x5'])\n",
    "X1.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:41.934414Z",
     "start_time": "2021-06-25T04:05:40.953169Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\r\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\r\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\r\n",
       "<!-- Generated by graphviz version 2.38.0 (20140413.2041)\r\n",
       " -->\r\n",
       "<!-- Title: %3 Pages: 1 -->\r\n",
       "<svg width=\"245pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 245.00 218.00\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 214)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-214 241,-214 241,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"150\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"150\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"125\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"125\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x0&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M147.442,-86.6548C145.783,-76.931 143.308,-64.6521 140,-54 139.069,-51.0031 137.968,-47.9142 136.791,-44.8705\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"139.956,-43.3657 132.892,-35.4693 133.49,-46.0472 139.956,-43.3657\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"155.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.00</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M134.544,-90.005C120.464,-77.3813 100.597,-59.916 92,-54 81.194,-46.5643 68.6395,-39.4801 57.4616,-33.6547\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"58.9644,-30.4924 48.4645,-29.0773 55.7902,-36.7313 58.9644,-30.4924\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"121.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">8.00</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"210\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"210\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x5 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M161.005,-88.4097C169.97,-75.709 182.78,-57.5615 193.053,-43.0079\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"196.157,-44.6796 199.065,-34.4915 190.439,-40.6428 196.157,-44.6796\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"195.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">4.00</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"66\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"66\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M62.441,-87.1561C61.1798,-76.9067 61.2665,-63.9233 67,-54 72.721,-44.0984 82.4634,-36.6692 92.347,-31.2627\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"93.9103,-34.3944 101.352,-26.8534 90.8319,-28.1076 93.9103,-34.3944\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"79.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">2.00</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M43.7256,-94.7988C32.9729,-89.0846 21.1041,-80.5923 15,-69 11.0376,-61.4751 11.6861,-52.6266 14.0624,-44.4816\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"17.3723,-45.6237 17.6242,-35.0319 10.8221,-43.1548 17.3723,-45.6237\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"29.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;1.00</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"112\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"112\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x0 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M119.327,-174.611C124.741,-162.499 132.221,-145.768 138.439,-131.86\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"141.81,-132.896 142.696,-122.339 135.419,-130.039 141.81,-132.896\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"145.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.00</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M103.131,-174.611C96.47,-162.303 87.2279,-145.226 79.6308,-131.187\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"82.5237,-129.179 74.686,-122.05 76.3674,-132.511 82.5237,-129.179\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"103.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">6.00</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x245896d8748>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m = np.array([[0.0, 0.0, 0.0, 3.0, 0.0, 0.0],\n",
    "              [3.0, 0.0, 2.0, 0.0, 0.0, 0.0],\n",
    "              [0.0, 0.0, 0.0, 6.0, 0.0, 0.0],\n",
    "              [0.0, 0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "              [8.0, 0.0,-1.0, 0.0, 0.0, 0.0],\n",
    "              [4.0, 0.0, 0.0, 0.0, 0.0, 0.0]])\n",
    "\n",
    "make_dot(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:41.981290Z",
     "start_time": "2021-06-25T04:05:41.938404Z"
    }
   },
   "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>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.913337</td>\n",
       "      <td>14.568170</td>\n",
       "      <td>2.893918</td>\n",
       "      <td>0.374794</td>\n",
       "      <td>12.115455</td>\n",
       "      <td>9.358286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.013935</td>\n",
       "      <td>15.857260</td>\n",
       "      <td>3.163377</td>\n",
       "      <td>0.428686</td>\n",
       "      <td>12.657021</td>\n",
       "      <td>9.242911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3.172835</td>\n",
       "      <td>24.734385</td>\n",
       "      <td>5.142203</td>\n",
       "      <td>0.683057</td>\n",
       "      <td>19.605722</td>\n",
       "      <td>14.666783</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.990395</td>\n",
       "      <td>20.878961</td>\n",
       "      <td>4.113485</td>\n",
       "      <td>0.600948</td>\n",
       "      <td>19.452091</td>\n",
       "      <td>13.494380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.248702</td>\n",
       "      <td>2.268163</td>\n",
       "      <td>0.532419</td>\n",
       "      <td>0.070483</td>\n",
       "      <td>1.854870</td>\n",
       "      <td>1.130948</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0         x1        x2        x3         x4         x5\n",
       "0  1.913337  14.568170  2.893918  0.374794  12.115455   9.358286\n",
       "1  2.013935  15.857260  3.163377  0.428686  12.657021   9.242911\n",
       "2  3.172835  24.734385  5.142203  0.683057  19.605722  14.666783\n",
       "3  2.990395  20.878961  4.113485  0.600948  19.452091  13.494380\n",
       "4  0.248702   2.268163  0.532419  0.070483   1.854870   1.130948"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x3 = np.random.uniform(size=1000)\n",
    "x0 = 3.5*x3 + np.random.uniform(size=1000)\n",
    "x2 = 6.5*x3 + np.random.uniform(size=1000)\n",
    "x1 = 3.5*x0 + 2.5*x2 + np.random.uniform(size=1000)\n",
    "x5 = 4.5*x0 + np.random.uniform(size=1000)\n",
    "x4 = 8.5*x0 - 1.5*x2 + np.random.uniform(size=1000)\n",
    "X2 = pd.DataFrame(np.array([x0, x1, x2, x3, x4, x5]).T ,columns=['x0', 'x1', 'x2', 'x3', 'x4', 'x5'])\n",
    "X2.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:42.330276Z",
     "start_time": "2021-06-25T04:05:41.984281Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\r\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\r\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\r\n",
       "<!-- Generated by graphviz version 2.38.0 (20140413.2041)\r\n",
       " -->\r\n",
       "<!-- Title: %3 Pages: 1 -->\r\n",
       "<svg width=\"245pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 245.00 218.00\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 214)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-214 241,-214 241,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"150\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"150\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"125\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"125\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x0&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M147.442,-86.6548C145.783,-76.931 143.308,-64.6521 140,-54 139.069,-51.0031 137.968,-47.9142 136.791,-44.8705\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"139.956,-43.3657 132.892,-35.4693 133.49,-46.0472 139.956,-43.3657\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"155.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.50</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M134.544,-90.005C120.464,-77.3813 100.597,-59.916 92,-54 81.194,-46.5643 68.6395,-39.4801 57.4616,-33.6547\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"58.9644,-30.4924 48.4645,-29.0773 55.7902,-36.7313 58.9644,-30.4924\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"121.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">8.50</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"210\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"210\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x5 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M161.005,-88.4097C169.97,-75.709 182.78,-57.5615 193.053,-43.0079\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"196.157,-44.6796 199.065,-34.4915 190.439,-40.6428 196.157,-44.6796\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"195.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">4.50</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"66\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"66\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M62.441,-87.1561C61.1798,-76.9067 61.2665,-63.9233 67,-54 72.721,-44.0984 82.4634,-36.6692 92.347,-31.2627\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"93.9103,-34.3944 101.352,-26.8534 90.8319,-28.1076 93.9103,-34.3944\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"79.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">2.50</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M43.7256,-94.7988C32.9729,-89.0846 21.1041,-80.5923 15,-69 11.0376,-61.4751 11.6861,-52.6266 14.0624,-44.4816\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"17.3723,-45.6237 17.6242,-35.0319 10.8221,-43.1548 17.3723,-45.6237\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"29.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;1.50</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"112\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"112\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x0 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M119.327,-174.611C124.741,-162.499 132.221,-145.768 138.439,-131.86\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"141.81,-132.896 142.696,-122.339 135.419,-130.039 141.81,-132.896\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"145.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.50</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M103.131,-174.611C96.47,-162.303 87.2279,-145.226 79.6308,-131.187\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"82.5237,-129.179 74.686,-122.05 76.3674,-132.511 82.5237,-129.179\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"103.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">6.50</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2458b5bf208>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m = np.array([[0.0, 0.0, 0.0, 3.5, 0.0, 0.0],\n",
    "              [3.5, 0.0, 2.5, 0.0, 0.0, 0.0],\n",
    "              [0.0, 0.0, 0.0, 6.5, 0.0, 0.0],\n",
    "              [0.0, 0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "              [8.5, 0.0,-1.5, 0.0, 0.0, 0.0],\n",
    "              [4.5, 0.0, 0.0, 0.0, 0.0, 0.0]])\n",
    "\n",
    "make_dot(m)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We create a list variable that contains two datasets."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:42.345752Z",
     "start_time": "2021-06-25T04:05:42.332279Z"
    }
   },
   "outputs": [],
   "source": [
    "X_list = [X1, X2]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Causal Discovery\n",
    "To run causal discovery for multiple datasets, we create a `MultiGroupDirectLiNGAM` object and call the `fit` method."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:42.536704Z",
     "start_time": "2021-06-25T04:05:42.352739Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<lingam.multi_group_direct_lingam.MultiGroupDirectLiNGAM at 0x2458e2d3ba8>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = lingam.MultiGroupDirectLiNGAM()\n",
    "model.fit(X_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Using the `causal_order_` properties, we can see the causal ordering as a result of the causal discovery."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:42.556294Z",
     "start_time": "2021-06-25T04:05:42.540672Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[3, 0, 5, 2, 1, 4]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.causal_order_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T01:24:30.429100Z",
     "start_time": "2019-09-09T01:24:30.422118Z"
    }
   },
   "source": [
    "Also, using the `adjacency_matrix_` properties, we can see the adjacency matrix as a result of the causal discovery. As you can see from the following, DAG in each dataset is correctly estimated."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:43.002688Z",
     "start_time": "2021-06-25T04:05:42.556294Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.    0.    0.    3.006 0.    0.   ]\n",
      " [2.873 0.    1.969 0.    0.    0.   ]\n",
      " [0.    0.    0.    5.882 0.    0.   ]\n",
      " [0.    0.    0.    0.    0.    0.   ]\n",
      " [6.095 0.    0.    0.    0.    0.   ]\n",
      " [3.967 0.    0.    0.    0.    0.   ]]\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\r\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\r\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\r\n",
       "<!-- Generated by graphviz version 2.38.0 (20140413.2041)\r\n",
       " -->\r\n",
       "<!-- Title: %3 Pages: 1 -->\r\n",
       "<svg width=\"224pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 224.00 218.00\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 214)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-214 220,-214 220,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"105\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"105\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"183\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"183\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x0&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M118.587,-89.1941C130.778,-75.9087 148.837,-56.2284 162.734,-41.0842\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"165.387,-43.3706 169.569,-33.6362 160.229,-38.6377 165.387,-43.3706\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"160.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">2.87</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M90.1055,-89.5953C83.7944,-83.367 76.4283,-75.9303 70,-69 61.9755,-60.3489 53.4429,-50.5596 46.1118,-41.9507\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"48.6346,-39.5135 39.507,-34.1341 43.2878,-44.0314 48.6346,-39.5135\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"82.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">6.09</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"99\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"99\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x5 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M102.14,-86.9569C101.299,-81.2635 100.476,-74.8733 100,-69 99.4057,-61.674 99.0951,-53.7255 98.9455,-46.3673\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"102.443,-46.1093 98.8274,-36.1504 95.4433,-46.1903 102.443,-46.1093\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"112.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.97</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"189\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"189\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M187.786,-86.799C186.964,-75.1626 185.862,-59.5479 184.923,-46.2368\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"188.408,-45.9041 184.212,-36.1754 181.425,-46.3971 188.408,-45.9041\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"198.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">1.97</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"151\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"151\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x0 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M142.131,-174.611C135.47,-162.303 126.228,-145.226 118.631,-131.187\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"121.524,-129.179 113.686,-122.05 115.367,-132.511 121.524,-129.179\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"142.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.01</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M158.327,-174.611C163.741,-162.499 171.221,-145.768 177.439,-131.86\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"180.81,-132.896 181.696,-122.339 174.419,-130.039 180.81,-132.896\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"184.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">5.88</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x245896d8dd8>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(model.adjacency_matrices_[0])\n",
    "make_dot(model.adjacency_matrices_[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:43.403324Z",
     "start_time": "2021-06-25T04:05:43.005680Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0.     0.     0.     3.483  0.     0.   ]\n",
      " [ 3.516  0.     2.466  0.165  0.     0.   ]\n",
      " [ 0.     0.     0.     6.383  0.     0.   ]\n",
      " [ 0.     0.     0.     0.     0.     0.   ]\n",
      " [ 8.456  0.    -1.471  0.     0.     0.   ]\n",
      " [ 4.446  0.     0.     0.     0.     0.   ]]\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\r\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\r\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\r\n",
       "<!-- Generated by graphviz version 2.38.0 (20140413.2041)\r\n",
       " -->\r\n",
       "<!-- Title: %3 Pages: 1 -->\r\n",
       "<svg width=\"278pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 278.00 218.00\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 214)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-214 274,-214 274,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"99\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"99\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"223\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"223\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x0&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M105.257,-87.13C110.022,-76.345 117.554,-62.7826 128,-54 137.535,-45.9832 165.638,-36.1135 188.822,-28.9008\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"189.843,-32.2486 198.388,-25.9855 187.802,-25.5526 189.843,-32.2486\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"140.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.52</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"125\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"125\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M84.9992,-89.3967C77.1213,-79.3378 69.9664,-65.7244 76,-54 80.1259,-45.9826 87.0337,-39.3946 94.3805,-34.183\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"96.4826,-36.995 103.066,-28.6941 92.7431,-31.0775 96.4826,-36.995\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"88.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">8.46</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x5 -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M76.8533,-94.3394C65.6328,-88.4545 52.6001,-79.9471 44,-69 38.743,-62.3084 35.0634,-53.8968 32.5083,-45.8919\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"35.8528,-44.8528 29.8393,-36.1299 29.1006,-46.699 35.8528,-44.8528\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"56.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">4.45</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"198\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"198\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M202.939,-87.2067C206.432,-75.332 211.186,-59.1684 215.189,-45.5567\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"218.607,-46.3396 218.071,-35.7584 211.892,-44.3644 218.607,-46.3396\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"223.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">2.47</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M184.949,-88.8037C173.738,-75.7495 157.408,-56.7354 144.622,-41.8473\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"147.108,-39.3707 137.938,-34.0647 141.798,-43.9314 147.108,-39.3707\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"179.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;1.47</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"198\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"198\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x0 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M182.094,-177.343C166.073,-163.588 141.163,-142.2 122.792,-126.427\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"124.734,-123.482 114.867,-119.623 120.174,-128.793 124.734,-123.482\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"166.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">3.48</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x1 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M212.45,-176.789C217.76,-170.825 223.358,-163.53 227,-156 246.897,-114.859 250.244,-98.5371 240,-54 239.258,-50.7742 238.177,-47.5009 236.915,-44.3167\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"240.075,-42.8104 232.738,-35.167 233.707,-45.7174 240.075,-42.8104\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"257.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.17</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M198,-173.799C198,-162.163 198,-146.548 198,-133.237\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"201.5,-133.175 198,-123.175 194.5,-133.175 201.5,-133.175\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"210.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">6.38</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x245896d8eb8>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(model.adjacency_matrices_[1])\n",
    "make_dot(model.adjacency_matrices_[1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To compare, we run DirectLiNGAM with single dataset concatenating two datasets."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:43.419281Z",
     "start_time": "2021-06-25T04:05:43.405319Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2000, 6)\n"
     ]
    }
   ],
   "source": [
    "X_all = pd.concat([X1, X2])\n",
    "print(X_all.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:43.557082Z",
     "start_time": "2021-06-25T04:05:43.421274Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1, 5, 2, 3, 0, 4]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_all = lingam.DirectLiNGAM()\n",
    "model_all.fit(X_all)\n",
    "\n",
    "model_all.causal_order_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "You can see that the causal structure cannot be estimated correctly for a single dataset."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:43.918022Z",
     "start_time": "2021-06-25T04:05:43.561072Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\r\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\r\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\r\n",
       "<!-- Generated by graphviz version 2.38.0 (20140413.2041)\r\n",
       " -->\r\n",
       "<!-- Title: %3 Pages: 1 -->\r\n",
       "<svg width=\"304pt\" height=\"479pt\"\r\n",
       " viewBox=\"0.00 0.00 304.00 479.00\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 475)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-475 300,-475 300,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"81\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"81\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"223\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"223\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge9\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M100.447,-92.3593C124.741,-77.8168 166.508,-52.8156 194.437,-36.0977\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"196.55,-38.912 203.332,-30.7728 192.955,-32.9059 196.55,-38.912\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"173.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">8.98</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"167\" cy=\"-453\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"167\" y=\"-449.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x0 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x1&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M140.169,-450.361C92.9615,-445.87 0,-429.137 0,-367 0,-367 0,-367 0,-191 0,-160.408 27.8381,-136.471 50.8746,-121.901\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"52.9404,-124.744 59.7182,-116.6 49.3416,-118.74 52.9404,-124.744\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"14.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.03</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"212\" cy=\"-279\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"212\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x2 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x1&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M174.239,-435.459C176.597,-429.689 179.095,-423.124 181,-417 192.636,-379.586 201.877,-335.17 207.146,-307.279\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"210.651,-307.571 209.031,-297.1 203.768,-306.296 210.651,-307.571\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"211.5\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.32</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"135\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"135\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x3 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x1&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M164.9,-435.006C159.476,-391.102 144.958,-273.6 138.354,-220.147\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"141.807,-219.552 137.107,-210.056 134.86,-220.41 141.807,-219.552\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"166.5\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.02</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x4 -->\r\n",
       "<g id=\"edge10\" class=\"edge\"><title>x1&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M190.446,-443.934C220.003,-432.097 267,-406.988 267,-367 267,-367 267,-367 267,-104 267,-81.1466 254.301,-58.3159 242.547,-42.0793\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"245.056,-39.5976 236.201,-33.7791 239.495,-43.8492 245.056,-39.5976\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"281.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.25</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"97\" cy=\"-366\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"97\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x5 -->\r\n",
       "<g id=\"edge12\" class=\"edge\"><title>x1&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M150.073,-438.651C142.825,-432.487 134.542,-424.812 128,-417 121.711,-409.49 115.783,-400.59 110.828,-392.395\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"113.737,-390.434 105.681,-383.554 107.688,-393.957 113.737,-390.434\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"140.5\" y=\"-405.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.56</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x3 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x2&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M198.588,-263.194C186.626,-249.99 168.942,-230.468 155.257,-215.362\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"157.825,-212.983 148.517,-207.921 152.637,-217.682 157.825,-212.983\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"191.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.19</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge11\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M212.722,-261.006C214.586,-217.102 219.577,-99.5997 221.847,-46.1469\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"225.348,-46.1958 222.276,-36.0563 218.354,-45.8987 225.348,-46.1958\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"232.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.66</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x0 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M124.843,-175.012C116.923,-162.546 105.785,-145.013 96.7168,-130.739\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"99.4281,-128.48 91.1114,-121.916 93.5196,-132.234 99.4281,-128.48\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"124.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.99</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x0 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x5&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M95.9502,-348.006C93.2379,-304.102 85.9791,-186.6 82.677,-133.147\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"86.1637,-132.821 82.0537,-123.056 79.177,-133.253 86.1637,-132.821\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"102.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.22</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x2 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x5&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M99.7971,-347.711C102.351,-337.029 107.142,-323.739 116,-315 132.023,-299.192 155.746,-290.456 175.6,-285.665\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"176.537,-289.043 185.568,-283.503 175.053,-282.202 176.537,-289.043\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"130.5\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.17</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x3 -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x5&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M98.4778,-347.786C99.4558,-338.103 100.941,-325.822 103,-315 109.337,-281.684 119.719,-244.027 126.932,-219.475\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"130.311,-220.389 129.808,-209.806 123.602,-218.393 130.311,-220.389\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"128.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.03</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2458e2d3f60>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "make_dot(model_all.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Independence between error variables\n",
    "To check if the LiNGAM assumption is broken, we can get p-values of independence between error variables. The value in the i-th row and j-th column of the obtained matrix shows the p-value of the independence of the error variables $e_i$ and $e_j$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:54.827108Z",
     "start_time": "2021-06-25T04:05:43.919942Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.    0.136 0.075 0.838 0.    0.832]\n",
      " [0.136 0.    0.008 0.    0.544 0.403]\n",
      " [0.075 0.008 0.    0.11  0.    0.511]\n",
      " [0.838 0.    0.11  0.    0.039 0.049]\n",
      " [0.    0.544 0.    0.039 0.    0.101]\n",
      " [0.832 0.403 0.511 0.049 0.101 0.   ]]\n"
     ]
    }
   ],
   "source": [
    "p_values = model.get_error_independence_p_values(X_list)\n",
    "print(p_values[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:05:54.843068Z",
     "start_time": "2021-06-25T04:05:54.830103Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.    0.545 0.908 0.285 0.525 0.728]\n",
      " [0.545 0.    0.84  0.814 0.086 0.297]\n",
      " [0.908 0.84  0.    0.032 0.328 0.026]\n",
      " [0.285 0.814 0.032 0.    0.904 0.   ]\n",
      " [0.525 0.086 0.328 0.904 0.    0.237]\n",
      " [0.728 0.297 0.026 0.    0.237 0.   ]]\n"
     ]
    }
   ],
   "source": [
    "print(p_values[1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bootstrapping\n",
    "In `MultiGroupDirectLiNGAM`, bootstrap can be executed in the same way as normal `DirectLiNGAM`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.074307Z",
     "start_time": "2021-06-25T04:05:54.846059Z"
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "results = model.bootstrap(X_list, n_sampling=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-09T05:23:32.829569Z",
     "start_time": "2019-12-09T05:23:32.822589Z"
    }
   },
   "source": [
    "## Causal Directions\n",
    "The `bootstrap` method returns a list of multiple `BootstrapResult`, so we can get the result of bootstrapping from the list. We can get the same number of results as the number of datasets, so we specify an index when we access the results. We can get the ranking of the causal directions extracted by `get_causal_direction_counts()`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.089236Z",
     "start_time": "2021-06-25T04:06:15.074307Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x0 <--- x3  (100.0%)\n",
      "x1 <--- x0  (100.0%)\n",
      "x1 <--- x2  (100.0%)\n",
      "x2 <--- x3  (100.0%)\n",
      "x4 <--- x0  (100.0%)\n",
      "x5 <--- x0  (100.0%)\n",
      "x4 <--- x2  (94.0%)\n",
      "x4 <--- x5  (20.0%)\n"
     ]
    }
   ],
   "source": [
    "cdc = results[0].get_causal_direction_counts(n_directions=8, min_causal_effect=0.01)\n",
    "print_causal_directions(cdc, 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.105795Z",
     "start_time": "2021-06-25T04:06:15.090616Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x0 <--- x3  (100.0%)\n",
      "x1 <--- x0  (100.0%)\n",
      "x1 <--- x2  (100.0%)\n",
      "x2 <--- x3  (100.0%)\n",
      "x4 <--- x0  (100.0%)\n",
      "x4 <--- x2  (100.0%)\n",
      "x5 <--- x0  (100.0%)\n",
      "x1 <--- x3  (72.0%)\n"
     ]
    }
   ],
   "source": [
    "cdc = results[1].get_causal_direction_counts(n_directions=8, min_causal_effect=0.01)\n",
    "print_causal_directions(cdc, 100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Directed Acyclic Graphs\n",
    "Also, using the `get_directed_acyclic_graph_counts()` method, we can get the ranking of the DAGs extracted. In the following sample code, `n_dags` option is limited to the dags of the top 3 rankings, and `min_causal_effect` option is limited to causal directions with a coefficient of 0.01 or more."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.121087Z",
     "start_time": "2021-06-25T04:06:15.105795Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DAG[0]: 61.0%\n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx4 <--- x2 \n",
      "\tx5 <--- x0 \n",
      "DAG[1]: 13.0%\n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx4 <--- x2 \n",
      "\tx4 <--- x5 \n",
      "\tx5 <--- x0 \n",
      "DAG[2]: 6.0%\n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx5 <--- x0 \n"
     ]
    }
   ],
   "source": [
    "dagc = results[0].get_directed_acyclic_graph_counts(n_dags=3, min_causal_effect=0.01)\n",
    "print_dagc(dagc, 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.137044Z",
     "start_time": "2021-06-25T04:06:15.124080Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DAG[0]: 59.0%\n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx1 <--- x3 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx4 <--- x2 \n",
      "\tx5 <--- x0 \n",
      "DAG[1]: 17.0%\n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx4 <--- x2 \n",
      "\tx5 <--- x0 \n",
      "DAG[2]: 10.0%\n",
      "\tx0 <--- x2 \n",
      "\tx0 <--- x3 \n",
      "\tx1 <--- x0 \n",
      "\tx1 <--- x2 \n",
      "\tx1 <--- x3 \n",
      "\tx2 <--- x3 \n",
      "\tx4 <--- x0 \n",
      "\tx4 <--- x2 \n",
      "\tx5 <--- x0 \n"
     ]
    }
   ],
   "source": [
    "dagc = results[1].get_directed_acyclic_graph_counts(n_dags=3, min_causal_effect=0.01)\n",
    "print_dagc(dagc, 100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Probability\n",
    "Using the get_probabilities() method, we can get the probability of bootstrapping."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.149302Z",
     "start_time": "2021-06-25T04:06:15.140038Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.   0.   0.08 1.   0.   0.  ]\n",
      " [1.   0.   1.   0.08 0.   0.05]\n",
      " [0.   0.   0.   1.   0.   0.  ]\n",
      " [0.   0.   0.   0.   0.   0.  ]\n",
      " [1.   0.   0.94 0.   0.   0.2 ]\n",
      " [1.   0.   0.   0.   0.01 0.  ]]\n"
     ]
    }
   ],
   "source": [
    "prob = results[0].get_probabilities(min_causal_effect=0.01)\n",
    "print(prob)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Total Causal Effects\n",
    "Using the `get_total_causal_effects()` method, we can get the list of total causal effect. The total causal effects we can get are dictionary type variable.\n",
    "We can display the list nicely by assigning it to pandas.DataFrame. Also, we have replaced the variable index with a label below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.196299Z",
     "start_time": "2021-06-25T04:06:15.149302Z"
    }
   },
   "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>from</th>\n",
       "      <th>to</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>x3</td>\n",
       "      <td>x0</td>\n",
       "      <td>3.005604</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>x0</td>\n",
       "      <td>x1</td>\n",
       "      <td>2.990264</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>x2</td>\n",
       "      <td>x1</td>\n",
       "      <td>2.091170</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>x3</td>\n",
       "      <td>x1</td>\n",
       "      <td>20.937520</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>x3</td>\n",
       "      <td>x2</td>\n",
       "      <td>5.969457</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>x0</td>\n",
       "      <td>x4</td>\n",
       "      <td>7.992477</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>x3</td>\n",
       "      <td>x4</td>\n",
       "      <td>18.058717</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>x0</td>\n",
       "      <td>x5</td>\n",
       "      <td>3.970275</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>x3</td>\n",
       "      <td>x5</td>\n",
       "      <td>12.028240</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>x5</td>\n",
       "      <td>x1</td>\n",
       "      <td>0.148078</td>\n",
       "      <td>0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>x5</td>\n",
       "      <td>x4</td>\n",
       "      <td>0.104561</td>\n",
       "      <td>0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>x2</td>\n",
       "      <td>x5</td>\n",
       "      <td>0.152502</td>\n",
       "      <td>0.15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>x5</td>\n",
       "      <td>x2</td>\n",
       "      <td>0.078391</td>\n",
       "      <td>0.09</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>x2</td>\n",
       "      <td>x0</td>\n",
       "      <td>0.035852</td>\n",
       "      <td>0.08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>x4</td>\n",
       "      <td>x1</td>\n",
       "      <td>-1.623188</td>\n",
       "      <td>0.03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>x4</td>\n",
       "      <td>x5</td>\n",
       "      <td>0.027130</td>\n",
       "      <td>0.01</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   from  to     effect  probability\n",
       "0    x3  x0   3.005604         1.00\n",
       "1    x0  x1   2.990264         1.00\n",
       "2    x2  x1   2.091170         1.00\n",
       "3    x3  x1  20.937520         1.00\n",
       "4    x3  x2   5.969457         1.00\n",
       "5    x0  x4   7.992477         1.00\n",
       "6    x3  x4  18.058717         1.00\n",
       "7    x0  x5   3.970275         1.00\n",
       "8    x3  x5  12.028240         1.00\n",
       "9    x5  x1   0.148078         0.29\n",
       "10   x5  x4   0.104561         0.21\n",
       "11   x2  x5   0.152502         0.15\n",
       "12   x5  x2   0.078391         0.09\n",
       "13   x2  x0   0.035852         0.08\n",
       "14   x4  x1  -1.623188         0.03\n",
       "15   x4  x5   0.027130         0.01"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "causal_effects = results[0].get_total_causal_effects(min_causal_effect=0.01)\n",
    "df = pd.DataFrame(causal_effects)\n",
    "\n",
    "labels = [f'x{i}' for i in range(X1.shape[1])]\n",
    "df['from'] = df['from'].apply(lambda x : labels[x])\n",
    "df['to'] = df['to'].apply(lambda x : labels[x])\n",
    "df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We can easily perform sorting operations with pandas.DataFrame."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.228214Z",
     "start_time": "2021-06-25T04:06:15.201287Z"
    }
   },
   "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>from</th>\n",
       "      <th>to</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>x3</td>\n",
       "      <td>x1</td>\n",
       "      <td>20.937520</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>x3</td>\n",
       "      <td>x4</td>\n",
       "      <td>18.058717</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>x3</td>\n",
       "      <td>x5</td>\n",
       "      <td>12.028240</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>x0</td>\n",
       "      <td>x4</td>\n",
       "      <td>7.992477</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>x3</td>\n",
       "      <td>x2</td>\n",
       "      <td>5.969457</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  from  to     effect  probability\n",
       "3   x3  x1  20.937520          1.0\n",
       "6   x3  x4  18.058717          1.0\n",
       "8   x3  x5  12.028240          1.0\n",
       "5   x0  x4   7.992477          1.0\n",
       "4   x3  x2   5.969457          1.0"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.sort_values('effect', ascending=False).head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "And with pandas.DataFrame, we can easily filter by keywords. The following code extracts the causal direction towards x1."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:15.260129Z",
     "start_time": "2021-06-25T04:06:15.232204Z"
    }
   },
   "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>from</th>\n",
       "      <th>to</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>x0</td>\n",
       "      <td>x1</td>\n",
       "      <td>2.990264</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>x2</td>\n",
       "      <td>x1</td>\n",
       "      <td>2.091170</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>x3</td>\n",
       "      <td>x1</td>\n",
       "      <td>20.937520</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>x5</td>\n",
       "      <td>x1</td>\n",
       "      <td>0.148078</td>\n",
       "      <td>0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>x4</td>\n",
       "      <td>x1</td>\n",
       "      <td>-1.623188</td>\n",
       "      <td>0.03</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   from  to     effect  probability\n",
       "1    x0  x1   2.990264         1.00\n",
       "2    x2  x1   2.091170         1.00\n",
       "3    x3  x1  20.937520         1.00\n",
       "9    x5  x1   0.148078         0.29\n",
       "14   x4  x1  -1.623188         0.03"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[df['to']=='x1'].head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Because it holds the raw data of the total causal effect (the original data for calculating the median), it is possible to draw a histogram of the values of the causal effect, as shown below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:06:16.881821Z",
     "start_time": "2021-06-25T04:06:15.262123Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 4.,  8., 10., 19., 16., 14., 14.,  8.,  6.,  1.]),\n",
       " array([2.941, 2.955, 2.969, 2.984, 2.998, 3.012, 3.026, 3.04 , 3.055,\n",
       "        3.069, 3.083]),\n",
       " <a list of 10 Patch objects>)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "sns.set()\n",
    "%matplotlib inline\n",
    "\n",
    "from_index = 3\n",
    "to_index = 0\n",
    "plt.hist(results[0].total_effects_[:, to_index, from_index])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bootstrap Probability of Path\n",
    "Using the `get_paths()` method, we can explore all paths from any variable to any variable and calculate the bootstrap probability for each path. The path will be output as an array of variable indices. For example, the array `[3, 0, 1]` shows the path from variable X3 through variable X0 to variable X1."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-25T04:07:31.680360Z",
     "start_time": "2021-06-25T04:07:31.640468Z"
    }
   },
   "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>path</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>[3, 0, 1]</td>\n",
       "      <td>8.561128</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>[3, 2, 1]</td>\n",
       "      <td>11.622379</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>[3, 1]</td>\n",
       "      <td>0.151715</td>\n",
       "      <td>0.08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>[3, 2, 0, 1]</td>\n",
       "      <td>0.618533</td>\n",
       "      <td>0.08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>[3, 0, 5, 1]</td>\n",
       "      <td>0.967472</td>\n",
       "      <td>0.05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           path     effect  probability\n",
       "0     [3, 0, 1]   8.561128         1.00\n",
       "1     [3, 2, 1]  11.622379         1.00\n",
       "2        [3, 1]   0.151715         0.08\n",
       "3  [3, 2, 0, 1]   0.618533         0.08\n",
       "4  [3, 0, 5, 1]   0.967472         0.05"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from_index = 3 # index of x3\n",
    "to_index = 1 # index of x0\n",
    "\n",
    "pd.DataFrame(results[0].get_paths(from_index, to_index))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.3"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
