{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Template for analysis notebook\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Step 1: Prepare environment\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "- Set up the runtime\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Project directory: /home/xj265/phd/codebase/Euphratica/Euphratica-dev\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "\n",
    "project_dir = os.getcwd()\n",
    "while not os.path.exists(os.path.join(project_dir, \".git\")):\n",
    "    project_dir = os.path.dirname(project_dir)\n",
    "print(f\"Project directory: {project_dir}\")\n",
    "sys.path.insert(0, project_dir)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "- Import customised libraries\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import lingam\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from lingam.utils import make_dot\n",
    "from tabeval.plugins import Plugins"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Step 2: Specify the results of interest"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* GT causal graph of the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<!-- Generated by graphviz version 8.1.0 (20230707.2238)\n",
       " -->\n",
       "<!-- Pages: 1 -->\n",
       "<svg width=\"266pt\" height=\"223pt\"\n",
       " viewBox=\"0.00 0.00 266.00 222.50\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 218.5)\">\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-218.5 262,-218.5 262,4 -4,4\"/>\n",
       "<!-- x0 -->\n",
       "<g id=\"node1\" class=\"node\">\n",
       "<title>x0</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"157\" cy=\"-107.25\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"157\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">x0</text>\n",
       "</g>\n",
       "<!-- x1 -->\n",
       "<g id=\"node2\" class=\"node\">\n",
       "<title>x1</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"139\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"139\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x1</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x1 -->\n",
       "<g id=\"edge2\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x1</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M157.5,-89.09C157.44,-78.79 156.71,-65.5 154,-54 153.33,-51.14 152.44,-48.22 151.42,-45.35\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"154.37,-44.3 147.39,-36.33 147.88,-46.92 154.37,-44.3\"/>\n",
       "<text text-anchor=\"middle\" x=\"171.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">3.00</text>\n",
       "</g>\n",
       "<!-- x4 -->\n",
       "<g id=\"node5\" class=\"node\">\n",
       "<title>x4</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x4</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x4 -->\n",
       "<g id=\"edge5\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x4</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M141.57,-92.25C124.79,-77.05 100.18,-54.8 99,-54 86.81,-45.79 72.41,-38.39 59.7,-32.53\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"61.51,-29.06 50.95,-28.18 58.65,-35.45 61.51,-29.06\"/>\n",
       "<text text-anchor=\"middle\" x=\"132.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">8.00</text>\n",
       "</g>\n",
       "<!-- x5 -->\n",
       "<g id=\"node6\" class=\"node\">\n",
       "<title>x5</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"231\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"231\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x5</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x5 -->\n",
       "<g id=\"edge7\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x5</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M172.13,-92.06C178.48,-85.87 185.81,-78.4 192,-71.25 199.59,-62.48 207.34,-52.37 213.92,-43.39\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"217.29,-45.7 220.3,-35.54 211.61,-41.61 217.29,-45.7\"/>\n",
       "<text text-anchor=\"middle\" x=\"220.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">4.00</text>\n",
       "</g>\n",
       "<!-- x2 -->\n",
       "<g id=\"node3\" class=\"node\">\n",
       "<title>x2</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"66\" cy=\"-107.25\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"66\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">x2</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x1 -->\n",
       "<g id=\"edge3\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x1</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M62.27,-89.41C60.81,-78.47 60.82,-64.38 67.5,-54 75.61,-41.41 89.67,-33.2 103.18,-27.93\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"103.99,-31.01 112.31,-24.44 101.71,-24.39 103.99,-31.01\"/>\n",
       "<text text-anchor=\"middle\" x=\"83.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">2.00</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x4 -->\n",
       "<g id=\"edge6\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x4</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M41.96,-98.32C29.45,-92.83 15.28,-84.15 8,-71.25 3.17,-62.7 5.18,-52.7 9.36,-43.74\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"12.87,-45.64 14.74,-35.21 6.77,-42.2 12.87,-45.64\"/>\n",
       "<text text-anchor=\"middle\" x=\"26\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">&#45;1.00</text>\n",
       "</g>\n",
       "<!-- x3 -->\n",
       "<g id=\"node4\" class=\"node\">\n",
       "<title>x3</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"101\" cy=\"-196.5\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"101\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">x3</text>\n",
       "</g>\n",
       "<!-- x3&#45;&gt;x0 -->\n",
       "<g id=\"edge1\" class=\"edge\">\n",
       "<title>x3&#45;&gt;x0</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M111.27,-179.5C119.56,-166.58 131.37,-148.18 140.91,-133.32\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"144.34,-135.46 146.79,-125.15 138.45,-131.68 144.34,-135.46\"/>\n",
       "<text text-anchor=\"middle\" x=\"150.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">3.00</text>\n",
       "</g>\n",
       "<!-- x3&#45;&gt;x2 -->\n",
       "<g id=\"edge4\" class=\"edge\">\n",
       "<title>x3&#45;&gt;x2</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M94.25,-178.68C89.31,-166.37 82.51,-149.4 76.82,-135.21\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"79.7,-134 72.73,-126.02 73.2,-136.61 79.7,-134\"/>\n",
       "<text text-anchor=\"middle\" x=\"102.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">6.00</text>\n",
       "</g>\n",
       "</g>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<graphviz.graphs.Digraph at 0x7c6dfa77f0d0>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m = np.array(\n",
    "    [\n",
    "        [0.0, 0.0, 0.0, 3.0, 0.0, 0.0],\n",
    "        [3.0, 0.0, 2.0, 0.0, 0.0, 0.0],\n",
    "        [0.0, 0.0, 0.0, 6.0, 0.0, 0.0],\n",
    "        [0.0, 0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "        [8.0, 0.0, -1.0, 0.0, 0.0, 0.0],\n",
    "        [4.0, 0.0, 0.0, 0.0, 0.0, 0.0],\n",
    "    ]\n",
    ")\n",
    "\n",
    "dot = make_dot(m)\n",
    "\n",
    "# # Save pdf\n",
    "# dot.render(\"dag\")\n",
    "\n",
    "# # Save png\n",
    "# dot.format = \"png\"\n",
    "# dot.render(\"dag\")\n",
    "\n",
    "dot"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Generate the data with known causal structure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>3.202848</td>\n",
       "      <td>22.854805</td>\n",
       "      <td>6.427770</td>\n",
       "      <td>0.993039</td>\n",
       "      <td>19.641298</td>\n",
       "      <td>13.305871</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>3.217161</td>\n",
       "      <td>21.784452</td>\n",
       "      <td>5.794593</td>\n",
       "      <td>0.948473</td>\n",
       "      <td>20.481265</td>\n",
       "      <td>13.314621</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3.220023</td>\n",
       "      <td>20.241581</td>\n",
       "      <td>5.060788</td>\n",
       "      <td>0.796272</td>\n",
       "      <td>21.104802</td>\n",
       "      <td>13.084657</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.644764</td>\n",
       "      <td>8.674112</td>\n",
       "      <td>1.661672</td>\n",
       "      <td>0.229072</td>\n",
       "      <td>12.132156</td>\n",
       "      <td>7.066599</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.272907</td>\n",
       "      <td>9.281740</td>\n",
       "      <td>2.384406</td>\n",
       "      <td>0.337687</td>\n",
       "      <td>8.601990</td>\n",
       "      <td>5.131803</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0         x1        x2        x3         x4         x5\n",
       "0  3.202848  22.854805  6.427770  0.993039  19.641298  13.305871\n",
       "1  3.217161  21.784452  5.794593  0.948473  20.481265  13.314621\n",
       "2  3.220023  20.241581  5.060788  0.796272  21.104802  13.084657\n",
       "3  1.644764   8.674112  1.661672  0.229072  12.132156   7.066599\n",
       "4  1.272907   9.281740  2.384406  0.337687   8.601990   5.131803"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x3 = np.random.uniform(size=1000)\n",
    "x0 = 3.0 * x3 + np.random.uniform(size=1000)\n",
    "x2 = 6.0 * x3 + np.random.uniform(size=1000)\n",
    "x1 = 3.0 * x0 + 2.0 * x2 + np.random.uniform(size=1000)\n",
    "x5 = 4.0 * x0 + np.random.uniform(size=1000)\n",
    "x4 = 8.0 * x0 - 1.0 * x2 + np.random.uniform(size=1000)\n",
    "X = pd.DataFrame(np.array([x0, x1, x2, x3, x4, x5]).T, columns=[\"x0\", \"x1\", \"x2\", \"x3\", \"x4\", \"x5\"])\n",
    "X.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Step 3: Export results\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Generate synthetic data with SCM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<tabeval.plugins.generic.plugin_scm.SCMPlugin at 0x7c6dfa77f190>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plugin = Plugins().get(\"scm\", cd_method=\"direct-lingam\")\n",
    "plugin.fit(X, task_type=\"regression\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.139499</td>\n",
       "      <td>14.623853</td>\n",
       "      <td>3.908991</td>\n",
       "      <td>0.548814</td>\n",
       "      <td>9.856119</td>\n",
       "      <td>8.860105</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.811492</td>\n",
       "      <td>17.407129</td>\n",
       "      <td>4.331472</td>\n",
       "      <td>0.715189</td>\n",
       "      <td>13.097219</td>\n",
       "      <td>11.824928</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.629319</td>\n",
       "      <td>16.204944</td>\n",
       "      <td>4.117920</td>\n",
       "      <td>0.602763</td>\n",
       "      <td>10.648771</td>\n",
       "      <td>10.666323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.495043</td>\n",
       "      <td>15.853570</td>\n",
       "      <td>4.001133</td>\n",
       "      <td>0.544883</td>\n",
       "      <td>9.098859</td>\n",
       "      <td>10.340924</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2.148678</td>\n",
       "      <td>11.881998</td>\n",
       "      <td>2.603836</td>\n",
       "      <td>0.423655</td>\n",
       "      <td>8.039785</td>\n",
       "      <td>8.657436</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0         x1        x2        x3         x4         x5\n",
       "0  2.139499  14.623853  3.908991  0.548814   9.856119   8.860105\n",
       "1  2.811492  17.407129  4.331472  0.715189  13.097219  11.824928\n",
       "2  2.629319  16.204944  4.117920  0.602763  10.648771  10.666323\n",
       "3  2.495043  15.853570  4.001133  0.544883   9.098859  10.340924\n",
       "4  2.148678  11.881998  2.603836  0.423655   8.039785   8.657436"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "syn_loader = plugin.generate(1000)\n",
    "X = syn_loader.dataframe()\n",
    "X.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Analyse the causal structures of synthetic data from SCM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       " \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<!-- Generated by graphviz version 8.1.0 (20230707.2238)\n",
       " -->\n",
       "<!-- Pages: 1 -->\n",
       "<svg width=\"242pt\" height=\"312pt\"\n",
       " viewBox=\"0.00 0.00 242.00 311.75\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n",
       "<g id=\"graph0\" class=\"graph\" transform=\"scale(1 1) rotate(0) translate(4 307.75)\">\n",
       "<polygon fill=\"white\" stroke=\"none\" points=\"-4,4 -4,-307.75 238,-307.75 238,4 -4,4\"/>\n",
       "<!-- x0 -->\n",
       "<g id=\"node1\" class=\"node\">\n",
       "<title>x0</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"57\" cy=\"-107.25\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"57\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">x0</text>\n",
       "</g>\n",
       "<!-- x1 -->\n",
       "<g id=\"node2\" class=\"node\">\n",
       "<title>x1</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"114\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"114\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x1</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x1 -->\n",
       "<g id=\"edge3\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x1</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M64.13,-89.66C68.98,-79.09 75.88,-65.3 83.5,-54 86.26,-49.9 89.45,-45.76 92.7,-41.83\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"95.87,-44.52 99.78,-34.67 90.58,-39.93 95.87,-44.52\"/>\n",
       "<text text-anchor=\"middle\" x=\"98.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">2.97</text>\n",
       "</g>\n",
       "<!-- x5 -->\n",
       "<g id=\"node6\" class=\"node\">\n",
       "<title>x5</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"27\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x5</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x5 -->\n",
       "<g id=\"edge8\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x5</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M41.79,-91.96C36.58,-86.1 31.34,-78.89 28.5,-71.25 25.66,-63.62 24.63,-54.92 24.48,-46.84\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"28.01,-47.09 24.78,-37 21.01,-46.9 28.01,-47.09\"/>\n",
       "<text text-anchor=\"middle\" x=\"44.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">4.00</text>\n",
       "</g>\n",
       "<!-- x2 -->\n",
       "<g id=\"node3\" class=\"node\">\n",
       "<title>x2</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"129\" cy=\"-196.5\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"129\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">x2</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x0 -->\n",
       "<g id=\"edge1\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x0</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M109.68,-183.53C100.91,-177.42 90.88,-169.4 83.5,-160.5 77.15,-152.85 71.79,-143.42 67.58,-134.69\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"70.48,-133.6 63.19,-125.91 64.1,-136.47 70.48,-133.6\"/>\n",
       "<text text-anchor=\"middle\" x=\"98.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">0.11</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x1 -->\n",
       "<g id=\"edge4\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x1</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M127.53,-178.26C124.94,-147.68 119.5,-83.71 116.36,-46.82\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"119.81,-46.98 115.47,-37.31 112.83,-47.58 119.81,-46.98\"/>\n",
       "<text text-anchor=\"middle\" x=\"137.75\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">2.02</text>\n",
       "</g>\n",
       "<!-- x3 -->\n",
       "<g id=\"node4\" class=\"node\">\n",
       "<title>x3</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"207\" cy=\"-107.25\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"207\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">x3</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x3 -->\n",
       "<g id=\"edge6\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x3</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M137.8,-179.5C144.17,-168.66 153.4,-154.34 163.5,-143.25 168.59,-137.66 174.61,-132.23 180.52,-127.38\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"182.28,-129.67 187.99,-120.74 177.96,-124.16 182.28,-129.67\"/>\n",
       "<text text-anchor=\"middle\" x=\"178.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">0.05</text>\n",
       "</g>\n",
       "<!-- x4 -->\n",
       "<g id=\"node5\" class=\"node\">\n",
       "<title>x4</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"129\" cy=\"-285.75\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"129\" y=\"-281.07\" font-family=\"Times,serif\" font-size=\"14.00\">x4</text>\n",
       "</g>\n",
       "<!-- x4&#45;&gt;x0 -->\n",
       "<g id=\"edge2\" class=\"edge\">\n",
       "<title>x4&#45;&gt;x0</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M110.89,-272.07C94.67,-259.54 71.87,-238.76 61.5,-214.5 50.87,-189.63 50.93,-158.44 52.93,-136.3\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"56.49,-136.95 54.1,-126.63 49.53,-136.19 56.49,-136.95\"/>\n",
       "<text text-anchor=\"middle\" x=\"76.75\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">0.13</text>\n",
       "</g>\n",
       "<!-- x4&#45;&gt;x2 -->\n",
       "<g id=\"edge5\" class=\"edge\">\n",
       "<title>x4&#45;&gt;x2</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M129,-267.51C129,-255.56 129,-239.38 129,-225.58\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"132.5,-225.7 129,-215.7 125.5,-225.7 132.5,-225.7\"/>\n",
       "<text text-anchor=\"middle\" x=\"144.75\" y=\"-236.45\" font-family=\"Times,serif\" font-size=\"14.00\">0.34</text>\n",
       "</g>\n",
       "<!-- x4&#45;&gt;x3 -->\n",
       "<g id=\"edge7\" class=\"edge\">\n",
       "<title>x4&#45;&gt;x3</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M145.79,-271.5C152.53,-265.47 159.89,-257.86 165,-249.75 187.4,-214.18 198.34,-166.09 203.3,-136.14\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"206.86,-137.02 204.93,-126.61 199.95,-135.96 206.86,-137.02\"/>\n",
       "<text text-anchor=\"middle\" x=\"208.75\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">0.04</text>\n",
       "</g>\n",
       "</g>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<graphviz.graphs.Digraph at 0x7c6dfa77c580>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cd_method = lingam.DirectLiNGAM()\n",
    "cd_method.fit(X)\n",
    "make_dot(cd_method.adjacency_matrix_)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gnn",
   "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.10.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
