{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# DirectLiNGAM by Kernel Method"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import and settings\n",
    "In this example, we need to import `numpy`, `pandas`, and `graphviz` in addition to `lingam`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.097825Z",
     "start_time": "2019-09-09T02:01:33.841227Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1.16.2', '0.24.2', '0.11.1', '1.3']\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import graphviz\n",
    "import lingam\n",
    "from lingam.utils import make_dot\n",
    "\n",
    "print([np.__version__, pd.__version__, graphviz.__version__, lingam.__version__])\n",
    "\n",
    "np.set_printoptions(precision=3, suppress=True)\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test data\n",
    "We create test data consisting of 6 variables."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.159633Z",
     "start_time": "2019-09-09T02:01:39.110757Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.205260</td>\n",
       "      <td>1.077322</td>\n",
       "      <td>0.236319</td>\n",
       "      <td>0.102727</td>\n",
       "      <td>-0.150883</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-1.121347</td>\n",
       "      <td>-1.001230</td>\n",
       "      <td>-3.736839</td>\n",
       "      <td>0.562784</td>\n",
       "      <td>-0.494015</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.857091</td>\n",
       "      <td>0.122282</td>\n",
       "      <td>0.019467</td>\n",
       "      <td>0.230076</td>\n",
       "      <td>-0.997795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.237355</td>\n",
       "      <td>-0.492237</td>\n",
       "      <td>0.568712</td>\n",
       "      <td>0.094054</td>\n",
       "      <td>-0.133962</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.090289</td>\n",
       "      <td>-0.558081</td>\n",
       "      <td>-2.480684</td>\n",
       "      <td>-0.165689</td>\n",
       "      <td>-2.380579</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0        x1        x2        x3        x4\n",
       "0  0.205260  1.077322  0.236319  0.102727 -0.150883\n",
       "1 -1.121347 -1.001230 -3.736839  0.562784 -0.494015\n",
       "2  0.857091  0.122282  0.019467  0.230076 -0.997795\n",
       "3  1.237355 -0.492237  0.568712  0.094054 -0.133962\n",
       "4  0.090289 -0.558081 -2.480684 -0.165689 -2.380579"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n = 1000\n",
    "e = lambda n: np.random.laplace(0, 1, n)\n",
    "x3 = e(n)\n",
    "x2 = 0.3*x3 + e(n)\n",
    "x1 = 0.3*x3 + 0.3*x2 + e(n)\n",
    "x0 = 0.3*x2 + 0.3*x1 + e(n)\n",
    "x4 = 0.3*x1 + 0.3*x0 + e(n)\n",
    "X = pd.DataFrame(np.array([x0, x1, x2, x3, x4]).T ,columns=['x0', 'x1', 'x2', 'x3', 'x4'])\n",
    "X.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.420171Z",
     "start_time": "2019-09-09T02:01:39.165610Z"
    }
   },
   "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=\"127pt\" height=\"392pt\"\r\n",
       " viewBox=\"0.00 0.00 127.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 123,-388 123,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"92\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"47\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"47\" 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=\"M83.3235,-87.6111C76.8492,-75.3817 67.8815,-58.4429 60.4767,-44.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"63.422,-42.5388 55.6498,-35.3385 57.2355,-45.8141 63.422,-42.5388\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"84.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</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=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" 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=\"M35.0856,-174.522C40.3965,-164.411 47.8521,-151.444 56,-141 59.7785,-136.157 64.2046,-131.328 68.6355,-126.873\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.2123,-129.25 75.9834,-119.79 66.3544,-124.21 71.2123,-129.25\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x4 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x1&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M26.6537,-173.981C26.4632,-153.313 26.8729,-117.439 31,-87 32.8714,-73.1981 36.2837,-58.0945 39.4778,-45.6348\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"42.8851,-46.4406 42.0709,-35.8771 36.1199,-44.6427 42.8851,-46.4406\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"43.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</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=\"92\" cy=\"-279\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x0 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M92,-260.879C92,-231.001 92,-169.113 92,-133.274\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"95.5001,-133.052 92,-123.052 88.5001,-133.052 95.5001,-133.052\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"104.5\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</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=\"M75.9834,-264.21C69.3743,-258.085 61.8981,-250.56 56,-243 50.08,-235.412 44.5255,-226.492 39.8936,-218.303\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"42.9432,-216.585 35.0856,-209.478 36.7963,-219.933 42.9432,-216.585\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</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=\"47\" cy=\"-366\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"47\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x1 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M42.0709,-348.123C38.3154,-334.466 33.3954,-314.666 31,-297 27.4855,-271.08 26.6667,-241.218 26.6187,-220.161\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"30.1191,-220.031 26.6537,-210.019 23.1191,-220.007 30.1191,-220.031\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"43.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M55.6765,-348.611C62.1508,-336.382 71.1185,-319.443 78.5233,-305.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"81.7645,-306.814 83.3502,-296.339 75.578,-303.539 81.7645,-306.814\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"84.5\" 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 0x1bba4a38470>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m = np.array([[0.0, 0.3, 0.3, 0.0, 0.0],\n",
    "              [0.0, 0.0, 0.3, 0.3, 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.3, 0.3, 0.0, 0.0, 0.0]])\n",
    "\n",
    "make_dot(m)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Causal Discovery\n",
    "To run causal discovery, we create a `DirectLiNGAM` object by specifying 'kernel' in the `measure` parameter. Then, we call the `fit` method. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.557802Z",
     "start_time": "2019-09-09T02:01:39.423164Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<lingam.direct_lingam.DirectLiNGAM at 0x1bba4a38550>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = lingam.DirectLiNGAM(measure='kernel')\n",
    "model.fit(X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Using the `causal_order_` properties, we can see the causal ordering as a result of the causal discovery."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.568772Z",
     "start_time": "2019-09-09T02:01:39.560796Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[3, 2, 1, 0, 4]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.causal_order_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T01:24:30.429100Z",
     "start_time": "2019-09-09T01:24:30.422118Z"
    }
   },
   "source": [
    "Also, using the `adjacency_matrix_` properties, we can see the adjacency matrix as a result of the causal discovery."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.583732Z",
     "start_time": "2019-09-09T02:01:39.574757Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.   , 0.34 , 0.273, 0.   , 0.   ],\n",
       "       [0.   , 0.   , 0.304, 0.275, 0.   ],\n",
       "       [0.   , 0.   , 0.   , 0.261, 0.   ],\n",
       "       [0.   , 0.   , 0.   , 0.   , 0.   ],\n",
       "       [0.26 , 0.239, 0.   , 0.   , 0.   ]])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.adjacency_matrix_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We can draw a causal graph by utility funciton."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-09-09T02:01:39.863981Z",
     "start_time": "2019-09-09T02:01:39.589716Z"
    }
   },
   "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=\"127pt\" height=\"392pt\"\r\n",
       " viewBox=\"0.00 0.00 127.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 123,-388 123,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"92\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"47\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"47\" 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=\"M83.3235,-87.6111C76.8492,-75.3817 67.8815,-58.4429 60.4767,-44.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"63.422,-42.5388 55.6498,-35.3385 57.2355,-45.8141 63.422,-42.5388\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"84.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.26</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=\"-192\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" 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=\"M35.0856,-174.522C40.3965,-164.411 47.8521,-151.444 56,-141 59.7785,-136.157 64.2046,-131.328 68.6355,-126.873\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"71.2123,-129.25 75.9834,-119.79 66.3544,-124.21 71.2123,-129.25\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.5\" y=\"-144.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.34</text>\r\n",
       "</g>\r\n",
       "<!-- x1&#45;&gt;x4 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x1&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M26.6537,-173.981C26.4632,-153.313 26.8729,-117.439 31,-87 32.8714,-73.1981 36.2837,-58.0945 39.4778,-45.6348\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"42.8851,-46.4406 42.0709,-35.8771 36.1199,-44.6427 42.8851,-46.4406\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"43.5\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.24</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=\"92\" cy=\"-279\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"92\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x2</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x0 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M92,-260.879C92,-231.001 92,-169.113 92,-133.274\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"95.5001,-133.052 92,-123.052 88.5001,-133.052 95.5001,-133.052\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"104.5\" y=\"-188.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.27</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=\"M75.9834,-264.21C69.3743,-258.085 61.8981,-250.56 56,-243 50.08,-235.412 44.5255,-226.492 39.8936,-218.303\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"42.9432,-216.585 35.0856,-209.478 36.7963,-219.933 42.9432,-216.585\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"68.5\" y=\"-231.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.30</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=\"47\" cy=\"-366\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"47\" y=\"-362.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x1 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x3&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M42.0709,-348.123C38.3154,-334.466 33.3954,-314.666 31,-297 27.4855,-271.08 26.6667,-241.218 26.6187,-220.161\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"30.1191,-220.031 26.6537,-210.019 23.1191,-220.007 30.1191,-220.031\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"43.5\" y=\"-275.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.28</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M55.6765,-348.611C62.1508,-336.382 71.1185,-319.443 78.5233,-305.456\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"81.7645,-306.814 83.3502,-296.339 75.578,-303.539 81.7645,-306.814\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"84.5\" y=\"-318.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.26</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x1bba0b46a20>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
