{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Using sample data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:49.386559Z",
     "start_time": "2019-12-12T06:27:47.059613Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1.21.3', '1.3.2', '0.17', '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 make_prior_knowledge, 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": [
    "## Standard data\n",
    "* 6 variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[3, 0, 2, 4, 5, 1]\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=\"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\">2.99</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\">3.91</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\">1.97</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.04</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 0x2652e70ef08>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = pd.read_csv('data/6vars.csv')\n",
    "model = lingam.DirectLiNGAM()\n",
    "model.fit(X)\n",
    "print(model.causal_order_)\n",
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Time series data for VAR\n",
    "* 5 variables"
   ]
  },
  {
   "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=\"602pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 602.19 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 598.194,-214 598.194,4 -4,4\"/>\r\n",
       "<!-- x0(t) -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"379.097\" cy=\"-105\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"379.097\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0(t)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t) -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"305.097\" cy=\"-105\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"305.097\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1(t)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(t) -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"91.0969\" cy=\"-18\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"91.0969\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2(t)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t)&#45;&gt;x2(t) -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x1(t)&#45;&gt;x2(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M293.906,-88.0193C285.171,-76.7706 272.036,-62.2938 257.097,-54 217.074,-31.7808 164.463,-23.6403 129.3,-20.6733\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"129.212,-17.1573 118.98,-19.9088 128.694,-24.1382 129.212,-17.1573\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"289.597\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.14</text>\r\n",
       "</g>\r\n",
       "<!-- x4(t) -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"327.097\" cy=\"-18\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"327.097\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4(t)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t)&#45;&gt;x4(t) -->\r\n",
       "<g id=\"edge11\" class=\"edge\"><title>x1(t)&#45;&gt;x4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M309.443,-87.2067C312.497,-75.4091 316.646,-59.3781 320.155,-45.8221\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"323.567,-46.6073 322.684,-36.0493 316.79,-44.8533 323.567,-46.6073\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"332.597\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.44</text>\r\n",
       "</g>\r\n",
       "<!-- x3(t) -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"231.097\" cy=\"-105\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"231.097\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3(t)</text>\r\n",
       "</g>\r\n",
       "<!-- x3(t)&#45;&gt;x4(t) -->\r\n",
       "<g id=\"edge12\" class=\"edge\"><title>x3(t)&#45;&gt;x4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M226.894,-86.7419C225.39,-76.3366 225.448,-63.3349 232.097,-54 245.094,-35.7514 268.701,-26.9981 289.129,-22.8086\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"289.899,-26.227 299.144,-21.0522 288.69,-19.3322 289.899,-26.227\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"244.597\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.22</text>\r\n",
       "</g>\r\n",
       "<!-- x0(t&#45;1) -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x0(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"559.097\" cy=\"-105\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"559.097\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- x0(t&#45;1)&#45;&gt;x4(t) -->\r\n",
       "<g id=\"edge13\" class=\"edge\"><title>x0(t&#45;1)&#45;&gt;x4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M542.762,-88.8611C529.72,-77.59 510.479,-62.7054 491.097,-54 450.061,-35.5691 398.816,-26.6364 364.635,-22.4507\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"364.939,-18.9627 354.605,-21.2988 364.141,-25.917 364.939,-18.9627\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"531.597\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.39</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t&#45;1) -->\r\n",
       "<g id=\"node7\" class=\"node\"><title>x1(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"172.097\" cy=\"-192\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"172.097\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t&#45;1)&#45;&gt;x0(t) -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x1(t&#45;1)&#45;&gt;x0(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M191.505,-176.91C207.945,-165.614 232.536,-150.182 256.097,-141 292.482,-126.82 305.011,-135.229 342.097,-123 344.01,-122.369 345.956,-121.668 347.904,-120.92\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"349.638,-123.989 357.511,-116.899 346.935,-117.531 349.638,-123.989\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"268.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.14</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t&#45;1)&#45;&gt;x2(t) -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x1(t&#45;1)&#45;&gt;x2(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M152.465,-176.912C136.882,-164.57 115.969,-145.172 105.097,-123 93.2947,-98.9312 90.4345,-68.1731 90.1361,-46.3666\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"93.6368,-46.1688 90.1735,-36.156 86.6368,-46.1431 93.6368,-46.1688\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"119.597\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.41</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t&#45;1)&#45;&gt;x3(t) -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x1(t&#45;1)&#45;&gt;x3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M175.929,-173.756C178.741,-163.605 183.277,-150.866 190.097,-141 194.102,-135.207 199.295,-129.795 204.631,-125.042\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"206.963,-127.655 212.431,-118.58 202.498,-122.264 206.963,-127.655\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"202.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.13</text>\r\n",
       "</g>\r\n",
       "<!-- x1(t&#45;1)&#45;&gt;x4(t) -->\r\n",
       "<g id=\"edge14\" class=\"edge\"><title>x1(t&#45;1)&#45;&gt;x4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M165.53,-174.203C158.19,-152.483 149.267,-114.219 165.097,-87 190.294,-43.6739 249.887,-27.9515 289.34,-22.247\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"289.927,-25.7002 299.395,-20.9451 289.028,-18.7581 289.927,-25.7002\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"179.597\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.32</text>\r\n",
       "</g>\r\n",
       "<!-- x2(t&#45;1) -->\r\n",
       "<g id=\"node8\" class=\"node\"><title>x2(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"433.097\" cy=\"-192\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"433.097\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- x2(t&#45;1)&#45;&gt;x0(t) -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2(t&#45;1)&#45;&gt;x0(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M427.247,-174.092C423.396,-164.061 417.828,-151.329 411.097,-141 408.193,-136.545 404.718,-132.109 401.143,-127.967\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"403.599,-125.466 394.273,-120.437 398.427,-130.183 403.599,-125.466\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"434.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.45</text>\r\n",
       "</g>\r\n",
       "<!-- x2(t&#45;1)&#45;&gt;x3(t) -->\r\n",
       "<g id=\"edge9\" class=\"edge\"><title>x2(t&#45;1)&#45;&gt;x3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M412.528,-177.342C403.145,-170.995 391.954,-163.26 382.097,-156 373.434,-149.619 372.886,-145.463 363.097,-141 323.996,-123.173 309.035,-136.067 268.097,-123 265.963,-122.319 263.79,-121.546 261.621,-120.714\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"262.842,-117.431 252.267,-116.795 260.138,-123.887 262.842,-117.431\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"394.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.28</text>\r\n",
       "</g>\r\n",
       "<!-- x2(t&#45;1)&#45;&gt;x4(t) -->\r\n",
       "<g id=\"edge15\" class=\"edge\"><title>x2(t&#45;1)&#45;&gt;x4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M445.476,-175.023C451.479,-165.322 456.693,-152.61 453.097,-141 438.028,-92.3474 388.856,-55.1876 356.581,-35.2737\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"358.347,-32.2513 347.969,-30.119 354.752,-38.2578 358.347,-32.2513\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"460.597\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.35</text>\r\n",
       "</g>\r\n",
       "<!-- x3(t&#45;1) -->\r\n",
       "<g id=\"node9\" class=\"node\"><title>x3(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"309.097\" cy=\"-192\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"309.097\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- x3(t&#45;1)&#45;&gt;x0(t) -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x3(t&#45;1)&#45;&gt;x0(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M315.294,-174.145C319.582,-163.891 325.975,-150.907 334.097,-141 339.015,-135.001 345.139,-129.395 351.271,-124.503\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"353.629,-127.109 359.523,-118.306 349.425,-121.512 353.629,-127.109\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"348.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.19</text>\r\n",
       "</g>\r\n",
       "<!-- x3(t&#45;1)&#45;&gt;x1(t) -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3(t&#45;1)&#45;&gt;x1(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M295.962,-175.261C291.988,-169.556 288.139,-162.827 286.097,-156 283.572,-147.559 285.528,-138.508 288.991,-130.457\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"292.104,-132.056 293.569,-121.563 285.88,-128.852 292.104,-132.056\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"298.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.31</text>\r\n",
       "</g>\r\n",
       "<!-- x4(t&#45;1) -->\r\n",
       "<g id=\"node10\" class=\"node\"><title>x4(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"35.0969\" cy=\"-192\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"35.0969\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- x4(t&#45;1)&#45;&gt;x2(t) -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x4(t&#45;1)&#45;&gt;x2(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M33.9429,-173.861C33.1106,-152.766 33.6,-116.159 44.0969,-87 50.0211,-70.5435 60.957,-54.3441 70.79,-41.8868\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"73.7046,-43.8525 77.3461,-33.9031 68.2949,-39.4101 73.7046,-43.8525\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"56.5969\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.14</text>\r\n",
       "</g>\r\n",
       "<!-- x4(t&#45;1)&#45;&gt;x3(t) -->\r\n",
       "<g id=\"edge10\" class=\"edge\"><title>x4(t&#45;1)&#45;&gt;x3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M61.1242,-179.713C96.8351,-164.226 160.963,-136.415 199.419,-119.738\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"200.828,-122.942 208.61,-115.752 198.043,-116.52 200.828,-122.942\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"157.597\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.20</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2651dc422c8>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = pd.read_csv('data/5vars_var.csv')\n",
    "model = lingam.VARLiNGAM()\n",
    "model.fit(X)\n",
    "labels = ['x0(t)', 'x1(t)', 'x2(t)', 'x3(t)', 'x4(t)', 'x0(t-1)', 'x1(t-1)', 'x2(t-1)', 'x3(t-1)', 'x4(t-1)']\n",
    "make_dot(np.hstack(model.adjacency_matrices_), ignore_shape=True, lower_limit=0.05, labels=labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Time series data for VARMA\n",
    "* 5 variables"
   ]
  },
  {
   "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=\"463pt\" height=\"392pt\"\r\n",
       " viewBox=\"0.00 0.00 463.00 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 459,-388 459,4 -4,4\"/>\r\n",
       "<!-- y0(t) -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>y0(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"279\" cy=\"-279\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"279\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y0(t)</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t) -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>y1(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"206\" cy=\"-192\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"206\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y1(t)</text>\r\n",
       "</g>\r\n",
       "<!-- y0(t)&#45;&gt;y1(t) -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>y0(t)&#45;&gt;y1(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M261.213,-264.737C253.594,-258.59 244.886,-250.903 238,-243 231.337,-235.354 225.069,-226.198 219.875,-217.822\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"222.827,-215.939 214.694,-209.149 216.818,-219.529 222.827,-215.939\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"252.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.41</text>\r\n",
       "</g>\r\n",
       "<!-- y4(t) -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>y4(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"283\" cy=\"-105\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"283\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y4(t)</text>\r\n",
       "</g>\r\n",
       "<!-- y0(t)&#45;&gt;y4(t) -->\r\n",
       "<g id=\"edge13\" class=\"edge\"><title>y0(t)&#45;&gt;y4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M279.398,-260.879C280.093,-231.001 281.532,-169.113 282.366,-133.274\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"285.87,-133.13 282.603,-123.052 278.872,-132.967 285.87,-133.13\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"294.5\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.42</text>\r\n",
       "</g>\r\n",
       "<!-- y2(t) -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>y2(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"56\" cy=\"-105\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"56\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y2(t)</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t)&#45;&gt;y2(t) -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>y1(t)&#45;&gt;y2(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M185.77,-179.537C159.938,-164.898 115.043,-139.458 85.4245,-122.674\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"86.814,-119.438 76.3882,-117.553 83.3629,-125.529 86.814,-119.438\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"152.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">1.25</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t) -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>y3(t)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"137\" cy=\"-18\" rx=\"27.8951\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"137\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y3(t)</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t)&#45;&gt;y3(t) -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>y1(t)&#45;&gt;y3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M204.028,-173.756C200.271,-146.512 190.189,-92.6449 166,-54 163.415,-49.8696 160.389,-45.6954 157.286,-41.7389\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"159.981,-39.5056 150.925,-34.0069 154.576,-43.953 159.981,-39.5056\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"208.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.92</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t)&#45;&gt;y4(t) -->\r\n",
       "<g id=\"edge14\" class=\"edge\"><title>y1(t)&#45;&gt;y4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M216.121,-174.941C222.883,-164.75 232.292,-151.545 242,-141 246.77,-135.819 252.278,-130.659 257.679,-125.957\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"260.019,-128.562 265.415,-119.444 255.511,-123.207 260.019,-128.562\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"254.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.52</text>\r\n",
       "</g>\r\n",
       "<!-- y2(t)&#45;&gt;y3(t) -->\r\n",
       "<g id=\"edge9\" class=\"edge\"><title>y2(t)&#45;&gt;y3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M70.1091,-89.1941C82.7693,-75.9087 101.524,-56.2284 115.955,-41.0842\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"118.688,-43.2901 123.053,-33.6362 113.62,-38.461 118.688,-43.2901\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"114.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.66</text>\r\n",
       "</g>\r\n",
       "<!-- y0(t&#45;1) -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>y0(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"367\" cy=\"-366\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"367\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y0(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t&#45;1) -->\r\n",
       "<g id=\"node7\" class=\"node\"><title>y1(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"359\" cy=\"-192\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"359\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y1(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- y1(t&#45;1)&#45;&gt;y4(t) -->\r\n",
       "<g id=\"edge15\" class=\"edge\"><title>y1(t&#45;1)&#45;&gt;y4(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M345.06,-175.41C333.346,-162.308 316.448,-143.409 303.242,-128.639\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"305.616,-126.043 296.341,-120.921 300.398,-130.709 305.616,-126.043\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"340.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.32</text>\r\n",
       "</g>\r\n",
       "<!-- y2(t&#45;1) -->\r\n",
       "<g id=\"node8\" class=\"node\"><title>y2(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"137\" cy=\"-105\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"137\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y2(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- y2(t&#45;1)&#45;&gt;y3(t) -->\r\n",
       "<g id=\"edge10\" class=\"edge\"><title>y2(t&#45;1)&#45;&gt;y3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M137,-86.799C137,-75.1626 137,-59.5479 137,-46.2368\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"140.5,-46.1754 137,-36.1754 133.5,-46.1755 140.5,-46.1754\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"149.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.36</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t&#45;1) -->\r\n",
       "<g id=\"node9\" class=\"node\"><title>y3(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"97\" cy=\"-366\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"97\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y3(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t&#45;1)&#45;&gt;y0(t) -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>y3(t&#45;1)&#45;&gt;y0(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M122.306,-353.181C155.072,-337.879 212.168,-311.213 247.646,-294.644\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"249.461,-297.658 257.041,-290.256 246.499,-291.316 249.461,-297.658\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"211.5\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.50</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t&#45;1)&#45;&gt;y1(t) -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>y3(t&#45;1)&#45;&gt;y1(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M107.451,-348.508C126.626,-318.251 167.526,-253.711 190.143,-218.022\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"193.343,-219.511 195.739,-209.191 187.43,-215.764 193.343,-219.511\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"177.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.31</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t&#45;1)&#45;&gt;y2(t) -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>y3(t&#45;1)&#45;&gt;y2(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M94.3099,-348.006C87.3597,-304.102 68.759,-186.6 60.2974,-133.147\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"63.7206,-132.386 58.7,-123.056 56.8067,-133.481 63.7206,-132.386\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"90.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">1.10</text>\r\n",
       "</g>\r\n",
       "<!-- y3(t&#45;1)&#45;&gt;y3(t) -->\r\n",
       "<g id=\"edge11\" class=\"edge\"><title>y3(t&#45;1)&#45;&gt;y3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M69.4632,-354.652C40.7857,-341.875 0,-317.169 0,-280 0,-280 0,-280 0,-104 0,-56.7788 59.4959,-34.8813 100.072,-25.4381\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"100.903,-28.8394 109.933,-23.2978 99.4183,-21.9987 100.903,-28.8394\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"14.5\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.32</text>\r\n",
       "</g>\r\n",
       "<!-- y4(t&#45;1) -->\r\n",
       "<g id=\"node10\" class=\"node\"><title>y4(t&#45;1)</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"279\" cy=\"-366\" rx=\"35.194\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"279\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">y4(t&#45;1)</text>\r\n",
       "</g>\r\n",
       "<!-- y4(t&#45;1)&#45;&gt;y0(t) -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>y4(t&#45;1)&#45;&gt;y0(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M279,-347.799C279,-336.163 279,-320.548 279,-307.237\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"282.5,-307.175 279,-297.175 275.5,-307.175 282.5,-307.175\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"291.5\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.39</text>\r\n",
       "</g>\r\n",
       "<!-- y4(t&#45;1)&#45;&gt;y1(t) -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>y4(t&#45;1)&#45;&gt;y1(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M259.273,-351.029C243.692,-338.756 222.97,-319.394 213,-297 202.171,-272.674 201.478,-241.955 202.846,-220.227\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"206.351,-220.311 203.678,-210.059 199.374,-219.741 206.351,-220.311\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"227.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.30</text>\r\n",
       "</g>\r\n",
       "<!-- y4(t&#45;1)&#45;&gt;y3(t) -->\r\n",
       "<g id=\"edge12\" class=\"edge\"><title>y4(t&#45;1)&#45;&gt;y3(t)</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M304.615,-353.502C347.696,-333.77 430,-294.214 430,-280 430,-280 430,-280 430,-104 430,-51.4097 253.69,-29.2621 174.604,-21.9729\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"174.836,-18.4797 164.565,-21.0796 174.215,-25.4522 174.836,-18.4797\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"442.5\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.33</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2652e84f4c8>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = pd.read_csv('data/5vars_varma.csv')\n",
    "model = lingam.VARMALiNGAM(order=(1, 1), criterion=None)\n",
    "model.fit(X)\n",
    "labels = ['y0(t)', 'y1(t)', 'y2(t)', 'y3(t)', 'y4(t)', 'y0(t-1)', 'y1(t-1)', 'y2(t-1)', 'y3(t-1)', 'y4(t-1)']\n",
    "make_dot(np.hstack(model.adjacency_matrices_[0]), lower_limit=0.3, ignore_shape=True, labels=labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Longitudinal data\n",
    "* 5 variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": [
    "n_features = 5\n",
    "n_samples = 200\n",
    "n_lags = 1\n",
    "n_timepoints = 3\n",
    "\n",
    "X_t = np.empty((n_timepoints, n_samples, n_features))\n",
    "for t in range(n_timepoints):\n",
    "    X_t[t] = pd.read_csv(f\"data/5vars_longitudinal_t{t}.csv\").values\n",
    "\n",
    "model = lingam.LongitudinalLiNGAM(n_lags=n_lags)\n",
    "model = model.fit(X_t)\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": "markdown",
   "metadata": {},
   "source": [
    "## The top variable is the latent variable\n",
    "* 6 variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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=\"241pt\" height=\"218pt\"\r\n",
       " viewBox=\"0.00 0.00 241.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 237,-214 237,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"158\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"158\" 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=\"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\">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=\"M139.231,-91.8216C116.954,-77.3673 79.6303,-53.1494 54.1922,-36.6438\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"56.0282,-33.6629 45.7343,-31.1558 52.218,-39.5351 56.0282,-33.6629\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"113.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.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=\"122\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"122\" 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=\"edge4\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M150.888,-87.2067C145.776,-75.1377 138.788,-58.6384 132.965,-44.8906\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"136.098,-43.3123 128.975,-35.4692 129.652,-46.0423 136.098,-43.3123\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"155.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.45</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=\"206\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"206\" 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=\"M167.028,-88.0122C174.024,-75.625 183.844,-58.235 191.876,-44.0109\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"194.979,-45.6337 196.849,-35.2052 188.884,-42.1917 194.979,-45.6337\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"197.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.48</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=\"68\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68\" y=\"-188.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=\"M56.4427,-175.472C47.3531,-162.274 35.3595,-142.425 30,-123 23.045,-97.7928 22.9966,-67.8374 24.2677,-46.5646\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"27.7794,-46.5329 25.0231,-36.303 20.7983,-46.019 27.7794,-46.5329\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"42.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.49</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=\"158\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"158\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</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=\"M105.164,-192C110.404,-192 115.644,-192 120.883,-192\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"105.07,-188.5 95.0703,-192 105.07,-195.5 105.07,-188.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"120.96,-195.5 130.96,-192 120.96,-188.5 120.96,-195.5\"/>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M67.9037,-173.648C68.3984,-146.72 71.9778,-93.8255 91,-54 93.2598,-49.2688 96.3528,-44.6969 99.7147,-40.5051\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"102.371,-42.7847 106.363,-32.9706 97.1221,-38.1534 102.371,-42.7847\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"93.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.45</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=\"M158,-173.799C158,-162.163 158,-146.548 158,-133.237\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"161.5,-133.175 158,-123.175 154.5,-133.175 161.5,-133.175\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"170.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.51</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2652d2ff6c8>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = pd.read_csv('data/6vars_top_latent.csv')\n",
    "model = lingam.BottomUpParceLiNGAM()\n",
    "model.fit(X)\n",
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## The middle variable is the latent variable\n",
    "* 6 variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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=\"152pt\" height=\"305pt\"\r\n",
       " viewBox=\"0.00 0.00 152.00 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 148,-301 148,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"61\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"61\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</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=\"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\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x2 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x0&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M54.2827,-87.2067C49.4551,-75.1377 42.8553,-58.6384 37.3563,-44.8906\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"40.5513,-43.454 33.5877,-35.4692 34.052,-46.0538 40.5513,-43.454\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"59.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.75</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=\"117\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"117\" 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=\"M71.5332,-88.0122C79.8243,-75.4274 91.5175,-57.6788 100.969,-43.3325\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"103.935,-45.1924 106.514,-34.9162 98.0897,-41.3412 103.935,-45.1924\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"105.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">1.02</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=\"31\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"31\" y=\"-188.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=\"M36.927,-174.207C41.1181,-162.332 46.8229,-146.168 51.6271,-132.557\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"55.0575,-133.353 55.0853,-122.758 48.4565,-131.023 55.0575,-133.353\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"60.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.94</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=\"M64.1643,-18C69.404,-18 74.6437,-18 79.8835,-18\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"64.0703,-14.5001 54.0703,-18 64.0703,-21.5001 64.0703,-14.5001\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"79.9599,-21.5001 89.9599,-18 79.9599,-14.5001 79.9599,-21.5001\"/>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"103\" cy=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"103\" 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=\"edge2\" class=\"edge\"><title>x3&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M94.902,-174.611C88.8592,-162.382 80.4894,-145.443 73.5783,-131.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"76.641,-129.753 69.0732,-122.339 70.3653,-132.854 76.641,-129.753\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"97.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.99</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=\"70\" cy=\"-279\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"70\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x1 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x5&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M62.4804,-261.611C56.8693,-249.382 49.0973,-232.443 42.6798,-218.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"45.8479,-216.968 38.4965,-209.339 39.4857,-219.887 45.8479,-216.968\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"65.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.56</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x3 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x5&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M76.5197,-261.207C81.1751,-249.216 87.5284,-232.851 92.8449,-219.157\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"96.1373,-220.347 96.4938,-209.758 89.6118,-217.814 96.1373,-220.347\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"101.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.56</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2652e873388>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = pd.read_csv('data/6vars_mid_latent.csv')\n",
    "model = lingam.RCD()\n",
    "model.fit(X)\n",
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.10"
  },
  "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
}
