{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Longitudinal LiNGAM"
   ]
  },
  {
   "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": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1.16.2', '0.24.2', '0.11.1', '1.5.2']\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import graphviz\n",
    "import lingam\n",
    "from lingam.utils import print_causal_directions, print_dagc, make_dot\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\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 create test data consisting of 5 variables. The causal model at each timepoint is as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# setting\n",
    "n_features = 5\n",
    "n_samples = 200\n",
    "n_lags = 1\n",
    "n_timepoints = 3\n",
    "\n",
    "causal_orders = []\n",
    "B_t_true = np.empty((n_timepoints, n_features, n_features))\n",
    "B_tau_true = np.empty((n_timepoints, n_lags, n_features, n_features))\n",
    "X_t = np.empty((n_timepoints, n_samples, n_features))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "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=\"140pt\" height=\"392pt\"\r\n",
       " viewBox=\"0.00 0.00 139.79 392.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 388)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-388 135.795,-388 135.795,4 -4,4\"/>\r\n",
       "<!-- x0(0) -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0(0)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"101.897\" cy=\"-105\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"101.897\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0(0)</text>\r\n",
       "</g>\r\n",
       "<!-- x4(0) -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4(0)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"51.8973\" cy=\"-18\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"51.8973\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4(0)</text>\r\n",
       "</g>\r\n",
       "<!-- x0(0)&#45;&gt;x4(0) -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x0(0)&#45;&gt;x4(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M92.2568,-87.6111C84.9939,-75.2642 74.9072,-58.1167 66.6346,-44.0534\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"69.5953,-42.1833 61.5083,-35.3385 63.5617,-45.7325 69.5953,-42.1833\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92.3973\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.10</text>\r\n",
       "</g>\r\n",
       "<!-- x1(0) -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1(0)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"29.8973\" cy=\"-192\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"29.8973\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1(0)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(0)&#45;&gt;x0(0) -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x1(0)&#45;&gt;x0(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M39.3152,-174.491C45.4403,-164.368 53.9339,-151.399 62.8973,-141 67.1851,-136.026 72.1557,-131.073 77.0832,-126.527\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"79.5361,-129.029 84.6865,-119.771 74.8864,-123.797 79.5361,-129.029\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"75.3973\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.50</text>\r\n",
       "</g>\r\n",
       "<!-- x1(0)&#45;&gt;x4(0) -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x1(0)&#45;&gt;x4(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M29.4085,-173.96C29.0777,-153.272 29.3494,-117.379 33.8973,-87 35.9739,-73.1297 39.8098,-58.0191 43.4087,-45.5724\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"46.8104,-46.4135 46.3321,-35.8294 40.1057,-44.4016 46.8104,-46.4135\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"48.3973\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.70</text>\r\n",
       "</g>\r\n",
       "<!-- x2(0) -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2(0)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"97.8973\" cy=\"-279\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"97.8973\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2(0)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(0)&#45;&gt;x0(0) -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2(0)&#45;&gt;x0(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M98.2955,-260.879C98.9903,-231.001 100.43,-169.113 101.263,-133.274\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"104.767,-133.13 101.501,-123.052 97.7692,-132.967 104.767,-133.13\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"114.397\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x2(0)&#45;&gt;x1(0) -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x2(0)&#45;&gt;x1(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M80.078,-264.077C73.004,-258.045 65.0945,-250.625 58.8973,-243 52.8271,-235.532 47.2349,-226.642 42.6146,-218.443\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"45.6676,-216.731 37.8373,-209.594 39.5078,-220.056 45.6676,-216.731\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"73.3973\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x3(0) -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3(0)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"50.8973\" cy=\"-366\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"50.8973\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3(0)</text>\r\n",
       "</g>\r\n",
       "<!-- x3(0)&#45;&gt;x1(0) -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3(0)&#45;&gt;x1(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M45.6501,-348.146C41.6542,-334.502 36.4238,-314.709 33.8973,-297 30.2029,-271.105 29.4077,-241.239 29.4142,-220.175\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"32.9149,-220.052 29.4795,-210.029 25.9151,-220.007 32.9149,-220.052\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"46.3973\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.40</text>\r\n",
       "</g>\r\n",
       "<!-- x3(0)&#45;&gt;x2(0) -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3(0)&#45;&gt;x2(0)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M59.9594,-348.611C66.7216,-336.382 76.0877,-319.443 83.8217,-305.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"87.0871,-306.783 88.8631,-296.339 80.9612,-303.396 87.0871,-306.783\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"90.3973\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2ba5105a588>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# B(0,0)\n",
    "B_t_true[0] = np.array([[0.0, 0.5,-0.3, 0.0, 0.0],\n",
    "                        [0.0, 0.0,-0.3, 0.4, 0.0],\n",
    "                        [0.0, 0.0, 0.0, 0.3, 0.0],\n",
    "                        [0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "                        [0.1,-0.7, 0.0, 0.0, 0.0]])\n",
    "causal_orders.append([3, 2, 1, 0, 4])\n",
    "make_dot(B_t_true[0], labels=[f'x{i}(0)' for i in range(5)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "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=\"184pt\" height=\"305pt\"\r\n",
       " viewBox=\"0.00 0.00 184.32 305.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 301)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-301 180.321,-301 180.321,4 -4,4\"/>\r\n",
       "<!-- x0(1) -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0(1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"68.4238\" cy=\"-18\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.4238\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0(1)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(1) -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1(1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"68.4238\" cy=\"-192\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.4238\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1(1)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(1)&#45;&gt;x0(1) -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x1(1)&#45;&gt;x0(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M49.8161,-177.792C34.3672,-165.584 13.508,-145.907 4.42375,-123 -1.47458,-108.127 -1.47458,-101.873 4.42375,-87 12.0176,-67.8515 27.8397,-50.9593 41.8513,-38.801\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"44.3445,-41.2808 49.8161,-32.2081 39.881,-35.8885 44.3445,-41.2808\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"16.9238\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.20</text>\r\n",
       "</g>\r\n",
       "<!-- x2(1) -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2(1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"68.4238\" cy=\"-105\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.4238\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2(1)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(1)&#45;&gt;x2(1) -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x1(1)&#45;&gt;x2(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M68.4238,-173.799C68.4238,-162.163 68.4238,-146.548 68.4238,-133.237\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.9239,-133.175 68.4238,-123.175 64.9239,-133.175 71.9239,-133.175\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"80.9238\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x4(1) -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4(1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"146.424\" cy=\"-105\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"146.424\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4(1)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(1)&#45;&gt;x4(1) -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x1(1)&#45;&gt;x4(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M82.3686,-175.804C94.4587,-162.629 112.12,-143.383 125.836,-128.435\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"128.417,-130.799 132.6,-121.065 123.26,-126.066 128.417,-130.799\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"126.924\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.40</text>\r\n",
       "</g>\r\n",
       "<!-- x2(1)&#45;&gt;x0(1) -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2(1)&#45;&gt;x0(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M68.4238,-86.799C68.4238,-75.1626 68.4238,-59.5479 68.4238,-46.2368\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.9239,-46.1754 68.4238,-36.1754 64.9239,-46.1755 71.9239,-46.1754\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"82.9238\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.10</text>\r\n",
       "</g>\r\n",
       "<!-- x3(1) -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3(1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"68.4238\" cy=\"-279\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.4238\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3(1)</text>\r\n",
       "</g>\r\n",
       "<!-- x3(1)&#45;&gt;x1(1) -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3(1)&#45;&gt;x1(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M68.4238,-260.799C68.4238,-249.163 68.4238,-233.548 68.4238,-220.237\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.9239,-220.175 68.4238,-210.175 64.9239,-220.175 71.9239,-220.175\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"80.9238\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.40</text>\r\n",
       "</g>\r\n",
       "<!-- x4(1)&#45;&gt;x0(1) -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x4(1)&#45;&gt;x0(1)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M132.729,-88.5986C123.859,-78.6697 112.027,-65.5098 101.424,-54 97.6044,-49.8539 93.5048,-45.4609 89.5385,-41.2395\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"92.0395,-38.7901 82.632,-33.9166 86.947,-43.593 92.0395,-38.7901\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"128.924\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.50</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2ba56744748>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# B(1,1)\n",
    "B_t_true[1] = np.array([[0.0, 0.2,-0.1, 0.0,-0.5],\n",
    "                        [0.0, 0.0, 0.0, 0.4, 0.0],\n",
    "                        [0.0, 0.3, 0.0, 0.0, 0.0],\n",
    "                        [0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "                        [0.0,-0.4, 0.0, 0.0, 0.0]])\n",
    "causal_orders.append([3, 1, 2, 4, 0])\n",
    "make_dot(B_t_true[1], labels=[f'x{i}(1)' for i in range(5)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "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=\"172pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 171.79 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 167.795,-214 167.795,4 -4,4\"/>\r\n",
       "<!-- x0(2) -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0(2)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"97.8973\" cy=\"-192\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"97.8973\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0(2)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(2) -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2(2)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"55.8973\" cy=\"-105\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"55.8973\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2(2)</text>\r\n",
       "</g>\r\n",
       "<!-- x0(2)&#45;&gt;x2(2) -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x0(2)&#45;&gt;x2(2)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M89.7993,-174.611C83.7566,-162.382 75.3868,-145.443 68.4756,-131.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.5383,-129.753 63.9705,-122.339 65.2626,-132.854 71.5383,-129.753\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92.3973\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.20</text>\r\n",
       "</g>\r\n",
       "<!-- x4(2) -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4(2)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"133.897\" cy=\"-105\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"133.897\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4(2)</text>\r\n",
       "</g>\r\n",
       "<!-- x0(2)&#45;&gt;x4(2) -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x0(2)&#45;&gt;x4(2)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M105.01,-174.207C110.088,-162.216 117.019,-145.851 122.819,-132.157\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"126.123,-133.332 126.8,-122.758 119.677,-130.602 126.123,-133.332\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"130.397\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x1(2) -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1(2)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"120.897\" cy=\"-18\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"120.897\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1(2)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(2)&#45;&gt;x1(2) -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x2(2)&#45;&gt;x1(2)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M67.4115,-88.1227C74.6384,-78.237 84.2039,-65.2966 92.8973,-54 95.7508,-50.2922 98.8084,-46.3954 101.817,-42.6029\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"104.718,-44.5785 108.226,-34.5811 99.2495,-40.209 104.718,-44.5785\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"107.397\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.70</text>\r\n",
       "</g>\r\n",
       "<!-- x3(2) -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3(2)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"29.8973\" cy=\"-18\" rx=\"29.795\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"29.8973\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3(2)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(2)&#45;&gt;x3(2) -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x2(2)&#45;&gt;x3(2)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M41.979,-88.7455C37.5759,-82.979 33.2472,-76.0879 30.8973,-69 28.5204,-61.8302 27.6435,-53.7589 27.5216,-46.2269\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"31.024,-46.1726 27.7745,-36.0884 24.0262,-45.9981 31.024,-46.1726\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"45.3973\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.40</text>\r\n",
       "</g>\r\n",
       "<!-- x4(2)&#45;&gt;x1(2) -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x4(2)&#45;&gt;x1(2)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M131.267,-86.799C129.487,-75.1626 127.099,-59.5479 125.063,-46.2368\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"128.496,-45.5313 123.524,-36.1754 121.576,-46.5897 128.496,-45.5313\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"140.397\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.50</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2ba56744b38>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# B(2,2)\n",
    "B_t_true[2] = np.array([[0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "                        [0.0, 0.0,-0.7, 0.0, 0.5],\n",
    "                        [0.2, 0.0, 0.0, 0.0, 0.0],\n",
    "                        [0.0, 0.0,-0.4, 0.0, 0.0],\n",
    "                        [0.3, 0.0, 0.0, 0.0, 0.0]])\n",
    "causal_orders.append([0, 2, 4, 3, 1])\n",
    "make_dot(B_t_true[2], labels=[f'x{i}(2)' for i in range(5)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# create B(t,t-τ) and X\n",
    "for t in range(n_timepoints):\n",
    "    # external influence\n",
    "    expon = 0.1\n",
    "    ext = np.empty((n_features, n_samples))\n",
    "    for i in range(n_features):\n",
    "        ext[i, :] = np.random.normal(size=(1, n_samples));\n",
    "        ext[i, :] = np.multiply(np.sign(ext[i, :]), abs(ext[i, :]) ** expon);\n",
    "        ext[i, :] = ext[i, :] - np.mean(ext[i, :]);\n",
    "        ext[i, :] = ext[i, :] / np.std(ext[i, :]);\n",
    "\n",
    "    # create B(t,t-τ)\n",
    "    for tau in range(n_lags):\n",
    "        value = np.random.uniform(low=0.01, high=0.5, size=(n_features, n_features))\n",
    "        sign = np.random.choice([-1, 1], size=(n_features, n_features))\n",
    "        B_tau_true[t, tau] = np.multiply(value, sign)\n",
    "\n",
    "    # create X(t)\n",
    "    X = np.zeros((n_features, n_samples))\n",
    "    for co in causal_orders[t]:\n",
    "        X[co] = np.dot(B_t_true[t][co, :], X) + ext[co]\n",
    "        if t > 0:\n",
    "            for tau in range(n_lags):\n",
    "                X[co] = X[co] + np.dot(B_tau_true[t, tau][co, :], X_t[t-(tau+1)].T)\n",
    "    \n",
    "    X_t[t] = X.T"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Causal Discovery\n",
    "To run causal discovery, we create a `LongitudinalLiNGAM` object by specifying the `n_lags` parameter. Then, we call the `fit` method. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = lingam.LongitudinalLiNGAM(n_lags=n_lags)\n",
    "model = model.fit(X_t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Using the `causal_orders_` property, we can see the causal ordering in time-points as a result of the causal discovery. \n",
    "All elements are nan because the causal order of B(t,t) at t=0 is not calculated.\n",
    "So access to the time points above t=1."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[nan, nan, nan, nan, nan]\n",
      "[3, 1, 2, 4, 0]\n",
      "[0, 4, 2, 3, 1]\n"
     ]
    }
   ],
   "source": [
    "print(model.causal_orders_[0]) # nan at t=0\n",
    "print(model.causal_orders_[1])\n",
    "print(model.causal_orders_[2])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Also, using the `adjacency_matrices_` property, we can see the adjacency matrix as a result of the causal discovery.\n",
    "As with the causal order, all elements are nan because the B(t,t) and B(t,t-τ) at t=0 is not calculated. \n",
    "So access to the time points above t=1.\n",
    "Also, if we run causal discovery with n_lags=2, B(t,t-τ) at t=1 is also not computed, so all the elements are nan."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "B(0,0):\n",
      "[[nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]]\n",
      "B(0,-1):\n",
      "[[nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]\n",
      " [nan nan nan nan nan]]\n",
      "B(1,1):\n",
      "[[ 0.     0.099  0.     0.    -0.52 ]\n",
      " [ 0.     0.     0.     0.398  0.   ]\n",
      " [ 0.     0.384  0.    -0.162  0.   ]\n",
      " [ 0.     0.     0.     0.     0.   ]\n",
      " [ 0.    -0.249 -0.074  0.     0.   ]]\n",
      "B(1,0):\n",
      "[[ 0.025  0.116 -0.202  0.054 -0.216]\n",
      " [ 0.139 -0.211 -0.43   0.558  0.051]\n",
      " [-0.135  0.178  0.421  0.173  0.031]\n",
      " [ 0.384 -0.083 -0.495 -0.072 -0.323]\n",
      " [-0.206 -0.354 -0.199 -0.293  0.468]]\n",
      "B(2,2):\n",
      "[[ 0.     0.     0.     0.     0.   ]\n",
      " [ 0.     0.    -0.67   0.     0.46 ]\n",
      " [ 0.187  0.     0.     0.     0.   ]\n",
      " [ 0.     0.    -0.341  0.     0.   ]\n",
      " [ 0.25   0.     0.     0.     0.   ]]\n",
      "B(2,1):\n",
      "[[ 0.194  0.2    0.031 -0.473 -0.002]\n",
      " [-0.384 -0.037  0.158  0.255  0.095]\n",
      " [ 0.126  0.275 -0.048  0.502 -0.019]\n",
      " [ 0.238 -0.469  0.475 -0.029 -0.176]\n",
      " [-0.177  0.309 -0.112  0.295 -0.273]]\n"
     ]
    }
   ],
   "source": [
    "t = 0 # nan at t=0\n",
    "print('B(0,0):')\n",
    "print(model.adjacency_matrices_[t, 0])\n",
    "print('B(0,-1):')\n",
    "print(model.adjacency_matrices_[t, 1])\n",
    "\n",
    "t = 1\n",
    "print('B(1,1):')\n",
    "print(model.adjacency_matrices_[t, 0])\n",
    "print('B(1,0):')\n",
    "print(model.adjacency_matrices_[t, 1])\n",
    "\n",
    "t = 2\n",
    "print('B(2,2):')\n",
    "print(model.adjacency_matrices_[t, 0])\n",
    "print('B(2,1):')\n",
    "print(model.adjacency_matrices_[t, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for t in range(1, n_timepoints):\n",
    "    B_t, B_tau = model.adjacency_matrices_[t]\n",
    "    plt.figure(figsize=(7, 3))\n",
    "\n",
    "    plt.subplot(1,2,1)\n",
    "    plt.plot([-1, 1],[-1, 1], marker=\"\", color=\"blue\", label=\"support\")\n",
    "    plt.scatter(B_t_true[t], B_t, facecolors='none', edgecolors='black')\n",
    "    plt.xlim(-1, 1)\n",
    "    plt.ylim(-1, 1)\n",
    "    plt.xlabel('True')\n",
    "    plt.ylabel('Estimated')\n",
    "    plt.title(f'B({t},{t})')\n",
    "\n",
    "    plt.subplot(1,2,2)\n",
    "    plt.plot([-1, 1],[-1, 1], marker=\"\", color=\"blue\", label=\"support\")\n",
    "    plt.scatter(B_tau_true[t], B_tau, facecolors='none', edgecolors='black')\n",
    "    plt.xlim(-1, 1)\n",
    "    plt.ylim(-1, 1)\n",
    "    plt.xlabel('True')\n",
    "    plt.ylabel('Estimated')\n",
    "    plt.title(f'B({t},{t-1})')\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "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": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_values_list = model.get_error_independence_p_values()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.    0.167 0.107 0.534 0.313]\n",
      " [0.167 0.    0.195 0.821 0.204]\n",
      " [0.107 0.195 0.    0.005 0.105]\n",
      " [0.534 0.821 0.005 0.    0.049]\n",
      " [0.313 0.204 0.105 0.049 0.   ]]\n"
     ]
    }
   ],
   "source": [
    "t = 1\n",
    "print(p_values_list[t])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.    0.723 0.596 0.579 0.564]\n",
      " [0.723 0.    0.612 0.688 0.412]\n",
      " [0.596 0.612 0.    0.267 0.636]\n",
      " [0.579 0.688 0.267 0.    0.421]\n",
      " [0.564 0.412 0.636 0.421 0.   ]]\n"
     ]
    }
   ],
   "source": [
    "t = 2\n",
    "print(p_values_list[2])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bootstrapping\n",
    "We call `bootstrap()` method instead of `fit()`. Here, the second argument specifies the number of bootstrap sampling."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = lingam.LongitudinalLiNGAM()\n",
    "result = model.bootstrap(X_t, n_sampling=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Causal Directions\n",
    "Since `LongitudinalBootstrapResult` object is returned, we can get the ranking of the causal directions extracted by `get_causal_direction_counts()` method. In the following sample code, `n_directions` option is limited to the causal directions of the top 8 rankings, and `min_causal_effect` option is limited to causal directions with a coefficient of 0.01 or more."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "cdc_list = result.get_causal_direction_counts(n_directions=12, min_causal_effect=0.01, split_by_causal_effect_sign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x4(1) <--- x4(0) (b>0) (100.0%)\n",
      "x2(1) <--- x0(0) (b<0) (100.0%)\n",
      "x3(1) <--- x0(0) (b>0) (100.0%)\n",
      "x1(1) <--- x3(0) (b>0) (100.0%)\n",
      "x1(1) <--- x2(0) (b<0) (100.0%)\n",
      "x3(1) <--- x2(0) (b<0) (100.0%)\n",
      "x3(1) <--- x4(0) (b<0) (100.0%)\n",
      "x1(1) <--- x3(1) (b>0) (100.0%)\n",
      "x0(1) <--- x4(1) (b<0) (100.0%)\n",
      "x4(1) <--- x1(0) (b<0) (100.0%)\n",
      "x4(1) <--- x1(1) (b<0) (100.0%)\n",
      "x2(1) <--- x2(0) (b>0) (100.0%)\n"
     ]
    }
   ],
   "source": [
    "t = 1\n",
    "labels = [f'x{i}({u})' for u in [t, t-1] for i in range(5)]\n",
    "print_causal_directions(cdc_list[t], 100, labels=labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x0(2) <--- x0(1) (b>0) (100.0%)\n",
      "x4(2) <--- x1(1) (b>0) (100.0%)\n",
      "x3(2) <--- x2(1) (b>0) (100.0%)\n",
      "x3(2) <--- x1(1) (b<0) (100.0%)\n",
      "x3(2) <--- x0(1) (b>0) (100.0%)\n",
      "x3(2) <--- x2(2) (b<0) (100.0%)\n",
      "x2(2) <--- x3(1) (b>0) (100.0%)\n",
      "x2(2) <--- x1(1) (b>0) (100.0%)\n",
      "x4(2) <--- x3(1) (b>0) (100.0%)\n",
      "x1(2) <--- x3(1) (b>0) (100.0%)\n",
      "x1(2) <--- x2(1) (b>0) (100.0%)\n",
      "x1(2) <--- x0(1) (b<0) (100.0%)\n"
     ]
    }
   ],
   "source": [
    "t = 2\n",
    "labels = [f'x{i}({u})' for u in [t, t-1] for i in range(5)]\n",
    "print_causal_directions(cdc_list[t], 100, labels=labels)"
   ]
  },
  {
   "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": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "dagc_list = result.get_directed_acyclic_graph_counts(n_dags=3, min_causal_effect=0.01, split_by_causal_effect_sign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DAG[0]: 2.0%\n",
      "\tx0(1) <--- x4(1) (b<0)\n",
      "\tx0(1) <--- x0(0) (b>0)\n",
      "\tx0(1) <--- x1(0) (b>0)\n",
      "\tx0(1) <--- x2(0) (b<0)\n",
      "\tx0(1) <--- x3(0) (b>0)\n",
      "\tx0(1) <--- x4(0) (b<0)\n",
      "\tx1(1) <--- x3(1) (b>0)\n",
      "\tx1(1) <--- x0(0) (b>0)\n",
      "\tx1(1) <--- x1(0) (b<0)\n",
      "\tx1(1) <--- x2(0) (b<0)\n",
      "\tx1(1) <--- x3(0) (b>0)\n",
      "\tx1(1) <--- x4(0) (b>0)\n",
      "\tx2(1) <--- x1(1) (b>0)\n",
      "\tx2(1) <--- x0(0) (b<0)\n",
      "\tx2(1) <--- x1(0) (b>0)\n",
      "\tx2(1) <--- x2(0) (b>0)\n",
      "\tx2(1) <--- x3(0) (b>0)\n",
      "\tx2(1) <--- x4(0) (b>0)\n",
      "\tx3(1) <--- x0(0) (b>0)\n",
      "\tx3(1) <--- x1(0) (b<0)\n",
      "\tx3(1) <--- x2(0) (b<0)\n",
      "\tx3(1) <--- x4(0) (b<0)\n",
      "\tx4(1) <--- x1(1) (b<0)\n",
      "\tx4(1) <--- x0(0) (b<0)\n",
      "\tx4(1) <--- x1(0) (b<0)\n",
      "\tx4(1) <--- x2(0) (b<0)\n",
      "\tx4(1) <--- x3(0) (b<0)\n",
      "\tx4(1) <--- x4(0) (b>0)\n",
      "DAG[1]: 1.0%\n",
      "\tx0(1) <--- x2(1) (b<0)\n",
      "\tx0(1) <--- x4(1) (b<0)\n",
      "\tx0(1) <--- x0(0) (b>0)\n",
      "\tx0(1) <--- x1(0) (b<0)\n",
      "\tx0(1) <--- x2(0) (b<0)\n",
      "\tx0(1) <--- x3(0) (b>0)\n",
      "\tx0(1) <--- x4(0) (b<0)\n",
      "\tx1(1) <--- x3(1) (b>0)\n",
      "\tx1(1) <--- x0(0) (b>0)\n",
      "\tx1(1) <--- x1(0) (b<0)\n",
      "\tx1(1) <--- x2(0) (b<0)\n",
      "\tx1(1) <--- x3(0) (b>0)\n",
      "\tx1(1) <--- x4(0) (b>0)\n",
      "\tx2(1) <--- x1(1) (b>0)\n",
      "\tx2(1) <--- x0(0) (b<0)\n",
      "\tx2(1) <--- x2(0) (b>0)\n",
      "\tx2(1) <--- x3(0) (b>0)\n",
      "\tx2(1) <--- x4(0) (b>0)\n",
      "\tx3(1) <--- x0(0) (b>0)\n",
      "\tx3(1) <--- x1(0) (b>0)\n",
      "\tx3(1) <--- x2(0) (b<0)\n",
      "\tx3(1) <--- x3(0) (b<0)\n",
      "\tx3(1) <--- x4(0) (b<0)\n",
      "\tx4(1) <--- x1(1) (b<0)\n",
      "\tx4(1) <--- x2(1) (b<0)\n",
      "\tx4(1) <--- x3(1) (b>0)\n",
      "\tx4(1) <--- x0(0) (b<0)\n",
      "\tx4(1) <--- x1(0) (b<0)\n",
      "\tx4(1) <--- x2(0) (b>0)\n",
      "\tx4(1) <--- x3(0) (b>0)\n",
      "\tx4(1) <--- x4(0) (b>0)\n",
      "DAG[2]: 1.0%\n",
      "\tx0(1) <--- x1(1) (b>0)\n",
      "\tx0(1) <--- x4(1) (b<0)\n",
      "\tx0(1) <--- x1(0) (b>0)\n",
      "\tx0(1) <--- x2(0) (b<0)\n",
      "\tx0(1) <--- x3(0) (b>0)\n",
      "\tx0(1) <--- x4(0) (b<0)\n",
      "\tx1(1) <--- x3(1) (b>0)\n",
      "\tx1(1) <--- x0(0) (b>0)\n",
      "\tx1(1) <--- x1(0) (b<0)\n",
      "\tx1(1) <--- x2(0) (b<0)\n",
      "\tx1(1) <--- x3(0) (b>0)\n",
      "\tx1(1) <--- x4(0) (b>0)\n",
      "\tx2(1) <--- x1(1) (b>0)\n",
      "\tx2(1) <--- x0(0) (b<0)\n",
      "\tx2(1) <--- x1(0) (b>0)\n",
      "\tx2(1) <--- x2(0) (b>0)\n",
      "\tx2(1) <--- x3(0) (b>0)\n",
      "\tx2(1) <--- x4(0) (b>0)\n",
      "\tx3(1) <--- x0(0) (b>0)\n",
      "\tx3(1) <--- x1(0) (b<0)\n",
      "\tx3(1) <--- x2(0) (b<0)\n",
      "\tx3(1) <--- x3(0) (b<0)\n",
      "\tx3(1) <--- x4(0) (b<0)\n",
      "\tx4(1) <--- x1(1) (b<0)\n",
      "\tx4(1) <--- x2(1) (b<0)\n",
      "\tx4(1) <--- x3(1) (b>0)\n",
      "\tx4(1) <--- x0(0) (b<0)\n",
      "\tx4(1) <--- x1(0) (b<0)\n",
      "\tx4(1) <--- x2(0) (b<0)\n",
      "\tx4(1) <--- x3(0) (b<0)\n",
      "\tx4(1) <--- x4(0) (b>0)\n"
     ]
    }
   ],
   "source": [
    "t = 1\n",
    "labels = [f'x{i}({u})' for u in [t, t-1] for i in range(5)]\n",
    "print_dagc(dagc_list[t], 100, labels=labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DAG[0]: 3.0%\n",
      "\tx0(2) <--- x0(1) (b>0)\n",
      "\tx0(2) <--- x1(1) (b>0)\n",
      "\tx0(2) <--- x2(1) (b>0)\n",
      "\tx0(2) <--- x3(1) (b<0)\n",
      "\tx0(2) <--- x4(1) (b>0)\n",
      "\tx1(2) <--- x2(2) (b<0)\n",
      "\tx1(2) <--- x4(2) (b>0)\n",
      "\tx1(2) <--- x0(1) (b<0)\n",
      "\tx1(2) <--- x1(1) (b<0)\n",
      "\tx1(2) <--- x2(1) (b>0)\n",
      "\tx1(2) <--- x3(1) (b>0)\n",
      "\tx1(2) <--- x4(1) (b>0)\n",
      "\tx2(2) <--- x0(2) (b>0)\n",
      "\tx2(2) <--- x0(1) (b>0)\n",
      "\tx2(2) <--- x1(1) (b>0)\n",
      "\tx2(2) <--- x2(1) (b<0)\n",
      "\tx2(2) <--- x3(1) (b>0)\n",
      "\tx2(2) <--- x4(1) (b<0)\n",
      "\tx3(2) <--- x2(2) (b<0)\n",
      "\tx3(2) <--- x0(1) (b>0)\n",
      "\tx3(2) <--- x1(1) (b<0)\n",
      "\tx3(2) <--- x2(1) (b>0)\n",
      "\tx3(2) <--- x3(1) (b>0)\n",
      "\tx3(2) <--- x4(1) (b<0)\n",
      "\tx4(2) <--- x0(2) (b>0)\n",
      "\tx4(2) <--- x0(1) (b<0)\n",
      "\tx4(2) <--- x1(1) (b>0)\n",
      "\tx4(2) <--- x2(1) (b<0)\n",
      "\tx4(2) <--- x3(1) (b>0)\n",
      "\tx4(2) <--- x4(1) (b<0)\n",
      "DAG[1]: 2.0%\n",
      "\tx0(2) <--- x0(1) (b>0)\n",
      "\tx0(2) <--- x1(1) (b>0)\n",
      "\tx0(2) <--- x2(1) (b>0)\n",
      "\tx0(2) <--- x3(1) (b<0)\n",
      "\tx0(2) <--- x4(1) (b>0)\n",
      "\tx1(2) <--- x2(2) (b<0)\n",
      "\tx1(2) <--- x4(2) (b>0)\n",
      "\tx1(2) <--- x0(1) (b<0)\n",
      "\tx1(2) <--- x1(1) (b<0)\n",
      "\tx1(2) <--- x2(1) (b>0)\n",
      "\tx1(2) <--- x3(1) (b>0)\n",
      "\tx1(2) <--- x4(1) (b<0)\n",
      "\tx2(2) <--- x0(2) (b>0)\n",
      "\tx2(2) <--- x0(1) (b>0)\n",
      "\tx2(2) <--- x1(1) (b>0)\n",
      "\tx2(2) <--- x2(1) (b<0)\n",
      "\tx2(2) <--- x3(1) (b>0)\n",
      "\tx2(2) <--- x4(1) (b>0)\n",
      "\tx3(2) <--- x2(2) (b<0)\n",
      "\tx3(2) <--- x0(1) (b>0)\n",
      "\tx3(2) <--- x1(1) (b<0)\n",
      "\tx3(2) <--- x2(1) (b>0)\n",
      "\tx3(2) <--- x3(1) (b<0)\n",
      "\tx3(2) <--- x4(1) (b<0)\n",
      "\tx4(2) <--- x0(2) (b>0)\n",
      "\tx4(2) <--- x0(1) (b<0)\n",
      "\tx4(2) <--- x1(1) (b>0)\n",
      "\tx4(2) <--- x2(1) (b<0)\n",
      "\tx4(2) <--- x3(1) (b>0)\n",
      "\tx4(2) <--- x4(1) (b<0)\n",
      "DAG[2]: 2.0%\n",
      "\tx0(2) <--- x0(1) (b>0)\n",
      "\tx0(2) <--- x1(1) (b>0)\n",
      "\tx0(2) <--- x2(1) (b<0)\n",
      "\tx0(2) <--- x3(1) (b<0)\n",
      "\tx0(2) <--- x4(1) (b<0)\n",
      "\tx1(2) <--- x2(2) (b<0)\n",
      "\tx1(2) <--- x4(2) (b>0)\n",
      "\tx1(2) <--- x0(1) (b<0)\n",
      "\tx1(2) <--- x1(1) (b<0)\n",
      "\tx1(2) <--- x2(1) (b>0)\n",
      "\tx1(2) <--- x3(1) (b>0)\n",
      "\tx1(2) <--- x4(1) (b>0)\n",
      "\tx2(2) <--- x0(1) (b>0)\n",
      "\tx2(2) <--- x1(1) (b>0)\n",
      "\tx2(2) <--- x2(1) (b<0)\n",
      "\tx2(2) <--- x3(1) (b>0)\n",
      "\tx2(2) <--- x4(1) (b<0)\n",
      "\tx3(2) <--- x2(2) (b<0)\n",
      "\tx3(2) <--- x0(1) (b>0)\n",
      "\tx3(2) <--- x1(1) (b<0)\n",
      "\tx3(2) <--- x2(1) (b>0)\n",
      "\tx3(2) <--- x3(1) (b<0)\n",
      "\tx3(2) <--- x4(1) (b<0)\n",
      "\tx4(2) <--- x0(2) (b>0)\n",
      "\tx4(2) <--- x0(1) (b<0)\n",
      "\tx4(2) <--- x1(1) (b>0)\n",
      "\tx4(2) <--- x2(1) (b<0)\n",
      "\tx4(2) <--- x3(1) (b>0)\n",
      "\tx4(2) <--- x4(1) (b<0)\n"
     ]
    }
   ],
   "source": [
    "t = 2\n",
    "labels = [f'x{i}({u})' for u in [t, t-1] for i in range(5)]\n",
    "print_dagc(dagc_list[t], 100, labels=labels)"
   ]
  },
  {
   "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": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[[0.   0.51 0.09 0.15 1.  ]\n",
      "  [0.   0.   0.   1.   0.  ]\n",
      "  [0.02 0.99 0.   0.52 0.3 ]\n",
      "  [0.   0.   0.   0.   0.  ]\n",
      "  [0.   1.   0.23 0.3  0.  ]]\n",
      "\n",
      " [[0.92 0.97 1.   0.94 0.99]\n",
      "  [0.99 0.99 1.   1.   0.94]\n",
      "  [1.   0.97 1.   0.99 0.87]\n",
      "  [1.   0.98 1.   0.92 1.  ]\n",
      "  [1.   1.   1.   1.   1.  ]]]\n"
     ]
    }
   ],
   "source": [
    "probs = result.get_probabilities(min_causal_effect=0.01)\n",
    "print(probs[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "B(1,1):\n",
      "[[0.   0.51 0.09 0.15 1.  ]\n",
      " [0.   0.   0.   1.   0.  ]\n",
      " [0.02 0.99 0.   0.52 0.3 ]\n",
      " [0.   0.   0.   0.   0.  ]\n",
      " [0.   1.   0.23 0.3  0.  ]]\n",
      "B(1,0):\n",
      "[[0.92 0.97 1.   0.94 0.99]\n",
      " [0.99 0.99 1.   1.   0.94]\n",
      " [1.   0.97 1.   0.99 0.87]\n",
      " [1.   0.98 1.   0.92 1.  ]\n",
      " [1.   1.   1.   1.   1.  ]]\n",
      "B(2,2):\n",
      "[[0.   0.   0.   0.   0.  ]\n",
      " [0.1  0.   1.   0.06 1.  ]\n",
      " [0.78 0.   0.   0.   0.13]\n",
      " [0.13 0.   1.   0.   0.16]\n",
      " [0.88 0.   0.   0.   0.  ]]\n",
      "B(2,1):\n",
      "[[1.   1.   0.91 1.   0.92]\n",
      " [1.   0.86 1.   1.   0.95]\n",
      " [0.95 1.   0.96 1.   0.8 ]\n",
      " [1.   1.   1.   0.92 1.  ]\n",
      " [0.99 1.   0.96 1.   1.  ]]\n"
     ]
    }
   ],
   "source": [
    "t = 1\n",
    "print('B(1,1):')\n",
    "print(probs[t, 0])\n",
    "print('B(1,0):')\n",
    "print(probs[t, 1])\n",
    "\n",
    "t = 2\n",
    "print('B(2,2):')\n",
    "print(probs[t, 0])\n",
    "print('B(2,1):')\n",
    "print(probs[t, 1])"
   ]
  },
  {
   "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": 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>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>x1(1)</td>\n",
       "      <td>x0(1)</td>\n",
       "      <td>0.269441</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>x0(2)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>0.119620</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>-0.109855</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>0.260481</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>0.297682</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>x2(2)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>-0.394208</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>-0.152984</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>-0.284373</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>0.425542</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>-0.263069</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>x0(2)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.177046</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>-0.110188</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.524608</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.329232</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>x4(2)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>0.113916</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>x2(2)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>-0.429614</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>x0(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.202225</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.154852</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>-0.145485</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x0(1)</td>\n",
       "      <td>0.116298</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>x0(1)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>-0.462228</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x0(1)</td>\n",
       "      <td>-0.562721</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>-0.238794</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x1(1)</td>\n",
       "      <td>0.317693</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>0.222208</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x2(1)</td>\n",
       "      <td>0.187445</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x4(1)</td>\n",
       "      <td>-0.280015</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>x4(2)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>-0.059277</td>\n",
       "      <td>0.92</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>-0.139972</td>\n",
       "      <td>0.91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>x4(2)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.033740</td>\n",
       "      <td>0.69</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x2(1)</td>\n",
       "      <td>-0.050954</td>\n",
       "      <td>0.54</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x4(1)</td>\n",
       "      <td>-0.102010</td>\n",
       "      <td>0.46</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.034217</td>\n",
       "      <td>0.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x1(2)</td>\n",
       "      <td>0.161172</td>\n",
       "      <td>0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>x2(2)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>0.029630</td>\n",
       "      <td>0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>x0(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>0.106614</td>\n",
       "      <td>0.19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>x0(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.136141</td>\n",
       "      <td>0.15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>-0.089162</td>\n",
       "      <td>0.12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>x3(2)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>-0.081235</td>\n",
       "      <td>0.08</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     from     to    effect  probability\n",
       "0   x1(1)  x0(1)  0.269441         1.00\n",
       "1   x0(2)  x4(2)  0.119620         1.00\n",
       "2   x4(1)  x4(2) -0.109855         1.00\n",
       "3   x3(1)  x4(2)  0.260481         1.00\n",
       "4   x1(1)  x4(2)  0.297682         1.00\n",
       "5   x2(2)  x3(2) -0.394208         1.00\n",
       "6   x4(1)  x3(2) -0.152984         1.00\n",
       "7   x3(1)  x3(2) -0.284373         1.00\n",
       "8   x2(1)  x3(2)  0.425542         1.00\n",
       "9   x1(1)  x3(2) -0.263069         1.00\n",
       "10  x0(2)  x2(2)  0.177046         1.00\n",
       "11  x4(1)  x2(2) -0.110188         1.00\n",
       "12  x3(1)  x2(2)  0.524608         1.00\n",
       "13  x1(1)  x2(2)  0.329232         1.00\n",
       "14  x4(2)  x1(2)  0.113916         1.00\n",
       "15  x2(2)  x1(2) -0.429614         1.00\n",
       "16  x0(1)  x2(2)  0.202225         1.00\n",
       "17  x1(1)  x0(2)  0.154852         1.00\n",
       "18  x1(1)  x1(2) -0.145485         1.00\n",
       "19  x3(1)  x0(1)  0.116298         1.00\n",
       "20  x0(1)  x1(2) -0.462228         1.00\n",
       "21  x4(1)  x0(1) -0.562721         1.00\n",
       "22  x3(1)  x0(2) -0.238794         1.00\n",
       "23  x3(1)  x1(1)  0.317693         1.00\n",
       "24  x4(1)  x1(2)  0.222208         1.00\n",
       "25  x1(1)  x2(1)  0.187445         1.00\n",
       "26  x1(1)  x4(1) -0.280015         1.00\n",
       "27  x4(2)  x3(2) -0.059277         0.92\n",
       "28  x4(1)  x0(2) -0.139972         0.91\n",
       "29  x4(2)  x2(2)  0.033740         0.69\n",
       "30  x4(1)  x2(1) -0.050954         0.54\n",
       "31  x2(1)  x4(1) -0.102010         0.46\n",
       "32  x2(1)  x0(2)  0.034217         0.35\n",
       "33  x2(1)  x1(2)  0.161172         0.34\n",
       "34  x2(2)  x4(2)  0.029630         0.31\n",
       "35  x0(1)  x3(2)  0.106614         0.19\n",
       "36  x0(1)  x0(2)  0.136141         0.15\n",
       "37  x2(1)  x2(2) -0.089162         0.12\n",
       "38  x3(2)  x4(2) -0.081235         0.08"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "causal_effects = result.get_total_causal_effects(min_causal_effect=0.01)\n",
    "\n",
    "df = pd.DataFrame(causal_effects)\n",
    "\n",
    "labels = [f'x{i}({t})' for t in range(3) for i in range(5)]\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": 24,
   "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>from</th>\n",
       "      <th>to</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.524608</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x3(2)</td>\n",
       "      <td>0.425542</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x2(2)</td>\n",
       "      <td>0.329232</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x1(1)</td>\n",
       "      <td>0.317693</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x4(2)</td>\n",
       "      <td>0.297682</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     from     to    effect  probability\n",
       "12  x3(1)  x2(2)  0.524608          1.0\n",
       "8   x2(1)  x3(2)  0.425542          1.0\n",
       "13  x1(1)  x2(2)  0.329232          1.0\n",
       "23  x3(1)  x1(1)  0.317693          1.0\n",
       "4   x1(1)  x4(2)  0.297682          1.0"
      ]
     },
     "execution_count": 24,
     "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 x0(2)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "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>from</th>\n",
       "      <th>to</th>\n",
       "      <th>effect</th>\n",
       "      <th>probability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>x1(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.154852</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>x3(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>-0.238794</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>x4(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>-0.139972</td>\n",
       "      <td>0.91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>x2(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.034217</td>\n",
       "      <td>0.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>x0(1)</td>\n",
       "      <td>x0(2)</td>\n",
       "      <td>0.136141</td>\n",
       "      <td>0.15</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     from     to    effect  probability\n",
       "17  x1(1)  x0(2)  0.154852         1.00\n",
       "22  x3(1)  x0(2) -0.238794         1.00\n",
       "28  x4(1)  x0(2) -0.139972         0.91\n",
       "32  x2(1)  x0(2)  0.034217         0.35\n",
       "36  x0(1)  x0(2)  0.136141         0.15"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[df['to']=='x0(2)'].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": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 9.,  6.,  0.,  4., 38.,  0.,  0.,  0.,  0., 43.]),\n",
       " array([0.139, 0.152, 0.165, 0.178, 0.192, 0.205, 0.218, 0.231, 0.245,\n",
       "        0.258, 0.271]),\n",
       " <a list of 10 Patch objects>)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXkAAAEBCAYAAACdctWRAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvnQurowAADxJJREFUeJzt3H+MZfVZx/H3zC7MbtnZSpchu1taG0UeUOOCuhgD2KhoghY3qUVSiELNlhDbWhPUaLq2UG2TBqFNm7aSIELd1tKALa6Af0iNhZD+oEqbiDzBZqvSncZ1xLBL2S3LjH/cOzJsl5l7z/398H79NffOOfd85uycz3z3e+79Ti0tLSFJqml61AEkSYNjyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBW2fgTHnAF2AvPA8yM4viRNonXANuArwNFOdxpFye8EHhzBcSWpgouAhzrdeBQlPw/w1FPPsLjY+wqYW7ZsYmHhcM+vM2yTmHsSM4O5h83cgzE9PcWpp54C7Q7t1ChK/nmAxcWlvpT88mtNoknMPYmZwdzDZu6B6mqa2xuvklSYJS9JhVnyklSYJS9JhVnyklSYJS9JhVnyklTYKN4nL0kjNbt5Ixtmvrf+5uZmB37sI0ePcejpZwd+nGWWvKSXnQ0z67n0untGcux9N+3i0BCP53SNJBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBXW8SdeI+JPgdMy8+qIOBe4FdgMfAG4NjOPDSijJKmhjkbyEfHzwFUrntoLvD0zzwKmgLcOIJskqUdrlnxEvAp4H/D+9uPvBzZm5hfbm9wOXDaogJKk5joZyd8CvAt4qv14OzC/4vvzwBl9ziVJ6oNV5+QjYjfwn5n5QERc3X56GlhasdkUsNjtgbds2dTtLi9pGMuDDsIk5p7EzGDuYZvU3MMyzPOz1o3Xy4FtEfEo8CpgE62C37Zim63AgW4PvLBwmMXFpbU3XMPc3CwHDw5z4c7+mMTck5gZzD1sk5B71H+Empyf6empRoPjVadrMvMXMvNHM/Nc4N3A32TmW4AjEXFBe7NfB+7v+siSpIFr+j75K4EPRsTjtEb3H+5fJElSv3T8PvnMvJ3WO2nIzK8B5w8mkiSpX/zEqyQVZslLUmGWvCQVZslLUmEd33iVhml280Y2zPTv17PT90UfOXqMQ08/27fjSqNmyWssbZhZz6XX3TP04+67aRfj/TEeqTtO10hSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYes72Sgi3gu8CVgC/jwzb46Ii4GbgY3AnZm5Z3AxJUlNrDmSj4jXAz8H/Bjwk8A7ImIHcBuwCzgH2BkRlwwyqCSpe2uWfGb+I/CzmXkMOJ3W6P/7gCcyc3/7+b3AZQNNKknqWkdz8pn5XETcADwGPABsB+ZXbDIPnNH/eJKkXnQ0Jw+Qme+JiA8A+4CzaM3PL5sCFrs58JYtm7rZfFVzc7N9e61hmsTck5i5W+P0M45Tlm5Mau5hGeb5WbPkI+JsYENmPpqZ34mIv6Z1E/b5FZttBQ50c+CFhcMsLi6tveEa5uZmOXjwUM+vM2yTmHuYmUdZEuPy7zKJvyMwGblH/UeoyfmZnp5qNDjuZCT/A8ANEXEhrdH7LuAW4MaIOBPYD1xB60asJGmMdHLj9T7gXuCfga8CD2fmp4GrgbtpzdM/Dtw1uJiSpCY6mpPPzOuB64977gFgR/8jSZL6xU+8SlJhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1JhlrwkFWbJS1Jh6zvZKCLeA/xa++G9mfn7EXExcDOwEbgzM/cMKKMkqaE1R/LtMv9F4DzgXOAnIuLNwG3ALuAcYGdEXDLIoJKk7nUyXTMPXJeZ383M54B/Bc4CnsjM/Zl5DNgLXDbAnJKkBtacrsnMf1n+OiJ+iNa0zUdolf+yeeCMvqeTJPWkozl5gIj4EeBe4PeAY7RG88umgMVuDrxly6ZuNl/V3Nxs315rmCYx9yRm7tY4/YzjlKUbk5p7WIZ5fjq98XoBcDfwO5n56Yh4PbBtxSZbgQPdHHhh4TCLi0vd7HJCc3OzHDx4qOfXGbZJzD3MzKMsiXH5d5nE3xGYjNyj/iPU5PxMT081GhyvWfIR8Rrgc8Dlmfn59tNfan0rzgT2A1fQuhErSRojnYzkfxfYANwcEcvP/RlwNa3R/QbgPuCuAeSTJPWgkxuv7wTe+RLf3tHfOJKkfvITr5JUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJUmCUvSYVZ8pJU2PpON4yIzcDDwBsy85sRcTFwM7ARuDMz9wwooySpoY5G8hHxU8BDwFntxxuB24BdwDnAzoi4ZFAhJUnNdDpd81bgbcCB9uPzgScyc39mHgP2ApcNIJ8kqQcdTddk5m6AiFh+ajswv2KTeeCMviaTJPWs4zn540wDSyseTwGL3bzAli2bGh76e83NzfbttYZpEnNPYuZujdPPOE5ZujGpuYdlmOenack/CWxb8XgrL0zldGRh4TCLi0trb7iGublZDh481PPrDNsk5h5m5lGWxLj8u0zi7whMRu5R/xFqcn6mp6caDY6blvyXgIiIM4H9wBW0bsRKksZIo/fJZ+YR4GrgbuAx4HHgrv7FkiT1Q1cj+cx83YqvHwB29DuQJKl/mk7XjMzs5o1smHlx7GHNrx05eoxDTz87lGNJUj9MXMlvmFnPpdfdM5Jj77tpF+N9O0mSXsy1aySpMEtekgqz5CWpMEtekgqz5CWpMEtekgqz5CWpMEtekgqz5CWpMEtekgqz5CWpMEtekgqbuAXKRum7zz3f1xUvO30tV7+U1JQl34WTT1o3khUwXf1SUlNO10hSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBVmyUtSYZa8JBXmh6G0qtnNG9kw88KvST8/8Stp8Cx5rWrDzPqRfcpXUu+crpGkwix5SSrMkpekwix5SSrMkpekwix5SSrMkpekwix5SSrMkpekwix5SSrMkpekwix5SSrMkpekwix5SSqsp6WGI+IKYA9wEvChzPxoX1JJkvqi8Ug+Il4NvA+4EDgXuCYifrhfwSRJvetlJH8x8PnM/B+AiLgLeBPw3jX2WwcwPT3V+MCnn7qx8b69GtWxezlfvRrVz/xyPNfHG6cs3ZiE3KPskSbnZ8U+67rZb2ppaanrgwFExB8Cp2Tmnvbj3cD5mXnNGrteCDzY6KCSpIuAhzrduJeR/DSw8i/EFLDYwX5foRVyHni+h+NL0svJOmAbrQ7tWC8l/yStsl62FTjQwX5H6eKvkCTp/32j2x16Kfm/B66PiDngGeBXgbWmaiRJQ9T43TWZ+S3gXcA/AI8Cn8rML/crmCSpd41vvEqSxp+feJWkwix5SSrMkpekwix5SSqspwXKBqnTxc8i4hO0lle4/bjnzwO+mJkzg8563HEb5Y6IbcCtwHbgO8CVmfnNYWRuH79p7tcBnwA2A/8LXJWZ/z6MzO3jr5o7InYBN9D6sN5+4C2Z+VREvBbYC5wOJK3zfXgCcl8AfBA4GVgAfnMSzveK74/ldbnK+R7pddkPYzmS72Txs4jYHhH7aK2Xc/z+rwA+QutCGJoec/8lsC8zz2t//YEhRF7O1EvuPwb+KjPPBe5uv85QrJU7IjYDHwd+OTN3AF8Hrm9/+2PAxzLzbOAR4I8mJPcngd3t8/1J4MMTkntsr8s1co/suuyXsSx5Vix+lpnPAMuLn610JXAP8JkT7H8T8KHBRjyhRrkj4jRgB3BL+6m/oDXqGJZezvc6WqN4gFOAZwcZ9Dhr5T4JeFv7Mx3QunhfGxEnAT/T3h7gduCy4UQGmueeAfZk5tdXPj+s0DTMveL743pdvtT5HvV12RfjOl2zndbaNsvmgfNXbpCZNwJExIUrn4+IXwFekZl3RcSgcx6vae4fBP4DuCkiLgK+Dbx9sFFfpPH5pjUCfjgifpvWCO2nB5jzeKvmzswF4LMAEbER+ANaI8nTgKcz89iK/c4YRuC2Rrkz8yitKSYiYprWaPNzw4kMND/fY31drpJ71NdlX4zrSL7R4mcRsZXWX9p3DCjXWpou2rYeOI/WaGMnrRHzHf2P95Ka5oZWzmsy89XAtcBnI2JY68x2lDsiXgncC3wtM+84wX6caL8Bapp7+fmTaU3VrAfeP9ioL9Io96Rclyc436O+LvtiXEv+SVqrrS3rdPGzNwBbgC9ExKMAEfFoRMz2P+IJNc39beBQZv5t+/GnOG4kPWCNcrfXLTo7M+8ByMy72/ueNoiQJ7Bm7vaNswdp/Rd8d/vp/wJeGRHL63JvO36/AWuam4jYBPwdrQLalZnPDTztC5rmHvvr8iVyj/q67Itxna5ptPhZZt5K6044ABGx1L5BNSxNc38jIp6MiEsy837gUuCrg436Ik0Xm/tv4EhEXJSZD7bf+XEoMw8OMOtKq+Zul/g+4DOZ+SfLz2fmcxHxIHA5rQv3N4D7h5S5ce62vcC/Addm5jD/9wHNz/dYX5er5B71ddkXY1nymfmtiFhe/Oxk4NbM/HJE3Ae8OzMfGW3CE+sx9xuBWyLiRuBp4KrBJ25pmjszlyLijcBH2nOZh2hdQGORG3gN8OPA+ohYvtH2SGbuBn4LuCMi9tCad33zuOcGPgrsAh4D/qk9t30gM39pnHO3z/fI9Jh7ZNdlv7hAmSQVNq5z8pKkPrDkJakwS16SCrPkJakwS16SCrPkJakwS16SCrPkJamw/wNdWe6OrvF5DQAAAABJRU5ErkJggg==\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 = 5 # index of x0(1). (index:0)+(n_features:5)*(timepoint:1) = 5\n",
    "to_index = 12 # index of x2(2). (index:2)+(n_features:5)*(timepoint:2) = 12\n",
    "plt.hist(result.total_effects_[:, to_index, from_index])"
   ]
  }
 ],
 "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
