{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# How to use prior knowledge in BottomUpParceLiNGAM"
   ]
  },
  {
   "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-12-12T06:27:49.386559Z",
     "start_time": "2019-12-12T06:27:47.059613Z"
    }
   },
   "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 graphviz\n",
    "import lingam\n",
    "from lingam.utils import make_prior_knowledge, 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": [
    "## Utility function\n",
    "We define a utility function to draw the directed acyclic graph."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:49.416479Z",
     "start_time": "2019-12-12T06:27:49.404510Z"
    }
   },
   "outputs": [],
   "source": [
    "def make_prior_knowledge_graph(prior_knowledge_matrix):\n",
    "    d = graphviz.Digraph(engine='dot')\n",
    "    \n",
    "    labels = [f'x{i}' for i in range(prior_knowledge_matrix.shape[0])]\n",
    "    for label in labels:\n",
    "        d.node(label, label)\n",
    "\n",
    "    dirs = np.where(prior_knowledge_matrix > 0)\n",
    "    for to, from_ in zip(dirs[0], dirs[1]):\n",
    "        d.edge(labels[from_], labels[to])\n",
    "\n",
    "    dirs = np.where(prior_knowledge_matrix < 0)\n",
    "    for to, from_ in zip(dirs[0], dirs[1]):\n",
    "        if to != from_:\n",
    "            d.edge(labels[from_], labels[to], style='dashed')\n",
    "    return d"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test data\n",
    "We create test data consisting of 6 variables."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:49.484297Z",
     "start_time": "2019-12-12T06:27:49.420469Z"
    }
   },
   "outputs": [],
   "source": [
    "np.random.seed(1000)\n",
    "\n",
    "x6 = np.random.uniform(size=1000)\n",
    "x3 = 2.0*x6 + np.random.uniform(size=1000)\n",
    "x0 = 0.5*x3 + np.random.uniform(size=1000)\n",
    "x2 = 2.0*x6 + np.random.uniform(size=1000)\n",
    "x1 = 0.5*x0 + 0.5*x2 + np.random.uniform(size=1000)\n",
    "x5 = 0.5*x0 + np.random.uniform(size=1000)\n",
    "x4 = 0.5*x0 - 0.5*x2 + np.random.uniform(size=1000)\n",
    "\n",
    "# The latent variable x6 is not included.\n",
    "X = pd.DataFrame(np.array([x0, x1, x2, x3, x4, x5]).T, columns=['x0', 'x1', 'x2', 'x3', 'x4', 'x5'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:49.947772Z",
     "start_time": "2019-12-12T06:27:49.486292Z"
    }
   },
   "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.50</text>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"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.50</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"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.50</text>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"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.50</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.50</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2f1555460f0>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m = np.array([[0.0, 0.0,    0.0,    0.5, 0.0, 0.0],\n",
    "              [0.5, 0.0,    0.5,    0.0, 0.0, 0.0],\n",
    "              [0.0, 0.0,    0.0, np.nan, 0.0, 0.0],\n",
    "              [0.0, 0.0, np.nan,    0.0, 0.0, 0.0],\n",
    "              [0.5, 0.0,   -0.5,    0.0, 0.0, 0.0],\n",
    "              [0.5, 0.0,    0.0,    0.0, 0.0, 0.0]])\n",
    "\n",
    "make_dot(m)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Make Prior Knowledge Matrix\n",
    "We create prior knowledge so that x0, x1 and x4 are sink variables.\n",
    "\n",
    "The elements of prior knowledge matrix are defined as follows:\n",
    "* ``0`` : :math:`x_i` does not have a directed path to :math:`x_j`\n",
    "* ``1`` : :math:`x_i` has a directed path to :math:`x_j`\n",
    "* ``-1`` : No prior knowledge is available to know if either of the two cases above (0 or 1) is true."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:50.380209Z",
     "start_time": "2019-12-12T06:27:49.950763Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[-1  0 -1 -1  0 -1]\n",
      " [ 0 -1 -1 -1  0 -1]\n",
      " [ 0  0 -1 -1  0 -1]\n",
      " [ 0  0 -1 -1  0 -1]\n",
      " [ 0  0 -1 -1 -1 -1]\n",
      " [ 0  0 -1 -1  0 -1]]\n"
     ]
    }
   ],
   "source": [
    "prior_knowledge = make_prior_knowledge(\n",
    "    n_variables=6,\n",
    "    sink_variables=[0, 1, 4],\n",
    ")\n",
    "print(prior_knowledge)"
   ]
  },
  {
   "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=\"228pt\" height=\"260pt\"\r\n",
       " viewBox=\"0.00 0.00 228.45 260.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 256)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-256 224.454,-256 224.454,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"121.454\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"121.454\" y=\"-14.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=\"193.454\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"193.454\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</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=\"103.454\" cy=\"-234\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"103.454\" y=\"-230.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=\"edge1\" class=\"edge\"><title>x2&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M117.204,-218.069C125.415,-208.1 135.073,-194.247 139.454,-180 153.553,-134.153 140.878,-77.9389 130.846,-45.5177\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"134.131,-44.304 127.718,-35.8707 127.473,-46.4626 134.131,-44.304\"/>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M120.442,-219.951C132.007,-210.173 146.741,-195.804 155.454,-180 179.122,-137.067 188.122,-79.804 191.492,-46.4114\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"195.014,-46.3327 192.432,-36.0572 188.042,-45.6997 195.014,-46.3327\"/>\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.454\" cy=\"-162\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"103.454\" y=\"-158.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=\"edge9\" class=\"edge\"><title>x2&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M97.6142,-216.411C96.7516,-208.507 96.5022,-198.852 96.866,-189.935\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"100.357,-190.179 97.5747,-179.956 93.375,-189.683 100.357,-190.179\"/>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"39.4541\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"39.4541\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge11\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M86.3048,-219.55C61.5689,-198.819 17.3216,-156.353 3.45413,-108 -0.956794,-92.62 -1.24867,-87.2933 3.45413,-72 6.73989,-61.3149 12.994,-50.851 19.3796,-42.0814\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"22.3385,-43.9774 25.7038,-33.9312 16.8081,-39.6861 22.3385,-43.9774\"/>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"39.4541\" cy=\"-90\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"39.4541\" y=\"-86.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x5 -->\r\n",
       "<g id=\"edge14\" class=\"edge\"><title>x2&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M85.814,-220.15C76.243,-209.801 65.5287,-194.618 58.4541,-180 48.8257,-160.105 41.5064,-136.133 38.1332,-118.083\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"41.5564,-117.314 36.5861,-107.957 34.6367,-118.371 41.5564,-117.314\"/>\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\" stroke-dasharray=\"5,2\" d=\"M105.625,-143.871C108.693,-119.67 114.329,-75.2108 117.982,-46.3932\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"121.49,-46.55 119.275,-36.1893 114.545,-45.6697 121.49,-46.55\"/>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x1 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M113.43,-145.261C129.04,-120.631 159.367,-72.7827 177.874,-43.582\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"181.037,-45.1296 183.434,-34.8095 175.124,-41.3823 181.037,-45.1296\"/>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x2 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x3&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M109.334,-179.956C110.168,-187.827 110.403,-197.374 110.037,-206.187\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"106.528,-206.184 109.294,-216.411 113.51,-206.691 106.528,-206.184\"/>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x4 -->\r\n",
       "<g id=\"edge12\" class=\"edge\"><title>x3&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M99.6883,-144.043C95.2629,-125.712 87.0264,-95.9117 75.4541,-72 70.5843,-61.9375 63.9898,-51.6074 57.7753,-42.7707\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"60.4743,-40.5307 51.7655,-34.4969 54.8107,-44.6446 60.4743,-40.5307\"/>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x5 -->\r\n",
       "<g id=\"edge15\" class=\"edge\"><title>x3&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M86.0048,-147.834C76.263,-138.618 64.418,-126.041 55.0039,-115.06\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"57.4367,-112.511 48.3539,-107.057 52.0527,-116.985 57.4367,-112.511\"/>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x0 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x5&#45;&gt;x0</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M55.6547,-75.1703C67.6369,-64.9415 84.1456,-50.8487 97.6292,-39.3383\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"100.233,-41.7175 105.566,-32.5628 95.6881,-36.3935 100.233,-41.7175\"/>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x1 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x5&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M61.2587,-79.3553C84.9832,-68.8266 124.002,-51.4093 157.454,-36 159.243,-35.1758 161.08,-34.3245 162.932,-33.4622\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"164.596,-36.5481 172.165,-29.1351 161.625,-30.2096 164.596,-36.5481\"/>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x2 -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x5&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M49.4824,-106.963C56.3451,-125.196 64.6702,-155.651 76.4541,-180 81.009,-189.412 87.0726,-199.057 92.4774,-207.496\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"89.6479,-209.569 97.9809,-216.112 95.547,-205.8 89.6479,-209.569\"/>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x3 -->\r\n",
       "<g id=\"edge10\" class=\"edge\"><title>x5&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M57.0775,-104.331C66.7508,-113.498 78.461,-125.934 87.8024,-136.821\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"85.3249,-139.316 94.4112,-144.765 90.7061,-134.839 85.3249,-139.316\"/>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x4 -->\r\n",
       "<g id=\"edge13\" class=\"edge\"><title>x5&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" stroke-dasharray=\"5,2\" d=\"M39.4541,-71.6966C39.4541,-63.9827 39.4541,-54.7125 39.4541,-46.1124\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"42.9542,-46.1043 39.4541,-36.1043 35.9542,-46.1044 42.9542,-46.1043\"/>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2f15a4aa908>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Draw a graph of prior knowledge\n",
    "make_prior_knowledge_graph(prior_knowledge)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Causal Discovery\n",
    "To run causal discovery using prior knowledge, we create a `DirectLiNGAM` object with the prior knowledge matrix."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:50.531152Z",
     "start_time": "2019-12-12T06:27:50.383201Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0, 2, 3, 5], 4, 1]\n",
      "[[ 0.     0.       nan    nan  0.       nan]\n",
      " [ 0.     0.     0.479  0.219  0.     0.212]\n",
      " [   nan  0.     0.       nan  0.       nan]\n",
      " [   nan  0.       nan  0.     0.       nan]\n",
      " [ 0.     0.    -0.494  0.212  0.     0.199]\n",
      " [   nan  0.       nan    nan  0.     0.   ]]\n"
     ]
    }
   ],
   "source": [
    "model = lingam.BottomUpParceLiNGAM(prior_knowledge=prior_knowledge)\n",
    "model.fit(X)\n",
    "print(model.causal_order_)\n",
    "print(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We can see that x0, x1, and x4 are output as sink variables, as specified in the prior knowledge."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2019-12-12T06:27:51.009585Z",
     "start_time": "2019-12-12T06:27:50.572914Z"
    }
   },
   "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=\"339pt\" height=\"145pt\"\r\n",
       " viewBox=\"0.00 0.00 339.00 144.83\" 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 140.826)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-140.826 335,-140.826 335,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" 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=\"117\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"117\" y=\"-101.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=\"edge7\" class=\"edge\"><title>x0&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M64.1643,-105C69.404,-105 74.6437,-105 79.8835,-105\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"64.0703,-101.5 54.0703,-105 64.0703,-108.5 64.0703,-101.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"79.9599,-108.5 89.9599,-105 79.9599,-101.5 79.9599,-108.5\"/>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"207\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"207\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x3 -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x0&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M57.1172,-120.839C67.2779,-125.379 78.8697,-129.715 90,-132 113.51,-136.826 120.49,-136.826 144,-132 155.13,-129.715 166.722,-125.379 176.883,-120.839\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"58.4137,-117.581 47.8758,-116.484 55.4298,-123.913 58.4137,-117.581\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"178.57,-123.913 186.124,-116.484 175.586,-117.581 178.57,-123.913\"/>\r\n",
       "</g>\r\n",
       "<!-- x5 -->\r\n",
       "<g id=\"node6\" class=\"node\"><title>x5</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"297\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"297\" y=\"-101.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=\"edge10\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M57.1172,-120.839C67.2779,-125.379 78.8697,-129.715 90,-132 121.346,-138.434 202.654,-138.434 234,-132 245.13,-129.715 256.722,-125.379 266.883,-120.839\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"58.4137,-117.581 47.8758,-116.484 55.4298,-123.913 58.4137,-117.581\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"268.57,-123.913 276.124,-116.484 265.586,-117.581 268.57,-123.913\"/>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"228\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"228\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M134.344,-90.7188C152.672,-76.6838 181.76,-54.4092 202.657,-38.4071\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"204.966,-41.0467 210.778,-32.188 200.711,-35.489 204.966,-41.0467\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"191.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.48</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x3 -->\r\n",
       "<g id=\"edge9\" class=\"edge\"><title>x2&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M154.164,-105C159.404,-105 164.644,-105 169.883,-105\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"154.07,-101.5 144.07,-105 154.07,-108.5 154.07,-101.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"169.96,-108.5 179.96,-105 169.96,-101.5 169.96,-108.5\"/>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"132\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"132\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M98.4891,-91.6914C86.2828,-81.9417 73.7737,-67.7236 81,-54 85.4827,-45.4869 93.0743,-38.6457 101.05,-33.3488\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"102.911,-36.314 109.726,-28.2012 99.3395,-30.2938 102.911,-36.314\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"95.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.49</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x5 -->\r\n",
       "<g id=\"edge11\" class=\"edge\"><title>x2&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M147.117,-120.839C157.278,-125.379 168.87,-129.715 180,-132 203.51,-136.826 210.49,-136.826 234,-132 245.13,-129.715 256.722,-125.379 266.883,-120.839\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"148.414,-117.581 137.876,-116.484 145.43,-123.913 148.414,-117.581\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"268.57,-123.913 276.124,-116.484 265.586,-117.581 268.57,-123.913\"/>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x3&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M211.149,-87.2067C214.064,-75.4091 218.024,-59.3781 221.373,-45.8221\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"224.787,-46.5969 223.788,-36.0493 217.991,-44.9179 224.787,-46.5969\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"230.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.22</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x4 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x3&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M183.571,-95.994C164.186,-88.8458 138.908,-78.1266 133,-69 128.67,-62.3106 127.316,-53.9909 127.361,-46.0697\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"130.854,-46.2855 128.093,-36.0568 123.873,-45.7749 130.854,-46.2855\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"145.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.21</text>\r\n",
       "</g>\r\n",
       "<!-- x3&#45;&gt;x5 -->\r\n",
       "<g id=\"edge12\" class=\"edge\"><title>x3&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M244.164,-105C249.404,-105 254.644,-105 259.883,-105\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"244.07,-101.5 234.07,-105 244.07,-108.5 244.07,-101.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"259.96,-108.5 269.96,-105 259.96,-101.5 259.96,-108.5\"/>\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=\"M303.585,-87.4856C306.591,-77.1127 308.254,-63.8763 302,-54 293.413,-40.4397 278,-32.0322 263.456,-26.8701\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"264.209,-23.4384 253.62,-23.7915 262.118,-30.1188 264.209,-23.4384\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"318.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.21</text>\r\n",
       "</g>\r\n",
       "<!-- x5&#45;&gt;x4 -->\r\n",
       "<g id=\"edge6\" class=\"edge\"><title>x5&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M284.978,-88.4208C275.697,-77.3717 261.948,-62.9688 247,-54 243.392,-51.8349 198.669,-38.5013 166.079,-28.934\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"166.994,-25.555 156.413,-26.1023 165.026,-32.2727 166.994,-25.555\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"277.5\" y=\"-57.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 0x2f155521d30>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Next, let's specify the prior knowledge so that x0 is an exogenous variable."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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=\"296pt\" height=\"144pt\"\r\n",
       " viewBox=\"0.00 0.00 296.00 143.62\" 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 139.619)\">\r\n",
       "<title>%3</title>\r\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-139.619 292,-139.619 292,4 -4,4\"/>\r\n",
       "<!-- x0 -->\r\n",
       "<g id=\"node1\" class=\"node\"><title>x0</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"81\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"81\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x0</text>\r\n",
       "</g>\r\n",
       "<!-- x1 -->\r\n",
       "<g id=\"node2\" class=\"node\"><title>x1</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\">x1</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x1 -->\r\n",
       "<g id=\"edge1\" class=\"edge\"><title>x0&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M90.4503,-87.7038C97.4303,-76.8892 107.811,-63.0683 120,-54 124.906,-50.35 153.452,-39.4922 177.1,-30.8279\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"178.322,-34.1076 186.52,-27.3961 175.926,-27.5304 178.322,-34.1076\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"132.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.50</text>\r\n",
       "</g>\r\n",
       "<!-- x2 -->\r\n",
       "<g id=\"node3\" class=\"node\"><title>x2</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"171\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"171\" y=\"-101.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=\"edge6\" class=\"edge\"><title>x0&#45;&gt;x2</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M118.164,-105C123.404,-105 128.644,-105 133.883,-105\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"118.07,-101.5 108.07,-105 118.07,-108.5 118.07,-101.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"133.96,-108.5 143.96,-105 133.96,-101.5 133.96,-108.5\"/>\r\n",
       "</g>\r\n",
       "<!-- x3 -->\r\n",
       "<g id=\"node4\" class=\"node\"><title>x3</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"261\" cy=\"-105\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"261\" y=\"-101.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x3</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x3 -->\r\n",
       "<g id=\"edge7\" class=\"edge\"><title>x0&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M111.117,-120.839C121.278,-125.379 132.87,-129.715 144,-132 167.51,-136.826 174.49,-136.826 198,-132 209.13,-129.715 220.722,-125.379 230.883,-120.839\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"112.414,-117.581 101.876,-116.484 109.43,-123.913 112.414,-117.581\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"232.57,-123.913 240.124,-116.484 229.586,-117.581 232.57,-123.913\"/>\r\n",
       "</g>\r\n",
       "<!-- x4 -->\r\n",
       "<g id=\"node5\" class=\"node\"><title>x4</title>\r\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"125\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"125\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x4</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x4 -->\r\n",
       "<g id=\"edge3\" class=\"edge\"><title>x0&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M74.9083,-87.3784C72.2247,-77.2127 70.7307,-64.2392 76,-54 80.1259,-45.9826 87.0337,-39.3946 94.3805,-34.183\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"96.4826,-36.995 103.066,-28.6941 92.7431,-31.0775 96.4826,-36.995\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"88.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">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=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-14.3\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">x5</text>\r\n",
       "</g>\r\n",
       "<!-- x0&#45;&gt;x5 -->\r\n",
       "<g id=\"edge5\" class=\"edge\"><title>x0&#45;&gt;x5</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M63.7485,-90.8209C56.8224,-84.7996 49.2524,-77.1863 44,-69 39.5246,-62.0247 36.0902,-53.7417 33.5197,-45.944\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"36.8092,-44.7248 30.6231,-36.1235 30.0952,-46.7052 36.8092,-44.7248\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"56.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.48</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x1 -->\r\n",
       "<g id=\"edge2\" class=\"edge\"><title>x2&#45;&gt;x1</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M186.081,-89.9254C191.592,-83.9808 197.361,-76.6631 201,-69 204.33,-61.9888 206.434,-53.8896 207.761,-46.2788\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"211.231,-46.7363 209.132,-36.3514 204.297,-45.7784 211.231,-46.7363\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"218.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">0.50</text>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x3 -->\r\n",
       "<g id=\"edge8\" class=\"edge\"><title>x2&#45;&gt;x3</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M208.164,-105C213.404,-105 218.644,-105 223.883,-105\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"208.07,-101.5 198.07,-105 208.07,-108.5 208.07,-101.5\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"223.96,-108.5 233.96,-105 223.96,-101.5 223.96,-108.5\"/>\r\n",
       "</g>\r\n",
       "<!-- x2&#45;&gt;x4 -->\r\n",
       "<g id=\"edge4\" class=\"edge\"><title>x2&#45;&gt;x4</title>\r\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M164.615,-87.4152C160.574,-77.4985 154.995,-64.7732 149,-54 147.002,-50.4088 144.735,-46.7208 142.411,-43.1488\"/>\r\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"145.146,-40.9451 136.639,-34.6295 139.35,-44.8715 145.146,-40.9451\"/>\r\n",
       "<text text-anchor=\"middle\" x=\"171.5\" y=\"-57.8\" font-family=\"Times New Roman,serif\" font-size=\"14.00\">&#45;0.45</text>\r\n",
       "</g>\r\n",
       "</g>\r\n",
       "</svg>\r\n"
      ],
      "text/plain": [
       "<graphviz.dot.Digraph at 0x2f15a4356d8>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "prior_knowledge = make_prior_knowledge(\n",
    "    n_variables=6,\n",
    "    exogenous_variables=[0],\n",
    ")\n",
    "\n",
    "model = lingam.BottomUpParceLiNGAM(prior_knowledge=prior_knowledge)\n",
    "model.fit(X)\n",
    "\n",
    "make_dot(model.adjacency_matrix_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
