{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Adding a noise feature (even dummy) would cause catastrophic degradation in model performance"
   ]
  },
  {
   "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 0x76807dd1ace0>"
      ]
     },
     "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",
       "      <th>x6</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.326424</td>\n",
       "      <td>14.372850</td>\n",
       "      <td>3.556934</td>\n",
       "      <td>0.567612</td>\n",
       "      <td>15.265695</td>\n",
       "      <td>9.692582</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>3.853230</td>\n",
       "      <td>25.261702</td>\n",
       "      <td>6.477434</td>\n",
       "      <td>0.981760</td>\n",
       "      <td>24.763071</td>\n",
       "      <td>15.471854</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1.087121</td>\n",
       "      <td>7.039875</td>\n",
       "      <td>1.716736</td>\n",
       "      <td>0.187131</td>\n",
       "      <td>7.558155</td>\n",
       "      <td>5.008439</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.455624</td>\n",
       "      <td>9.494270</td>\n",
       "      <td>2.335811</td>\n",
       "      <td>0.362901</td>\n",
       "      <td>10.058472</td>\n",
       "      <td>6.797906</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>3.219329</td>\n",
       "      <td>21.966800</td>\n",
       "      <td>5.851249</td>\n",
       "      <td>0.879001</td>\n",
       "      <td>20.211653</td>\n",
       "      <td>13.133479</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0         x1        x2        x3         x4         x5   x6\n",
       "0  2.326424  14.372850  3.556934  0.567612  15.265695   9.692582  1.0\n",
       "1  3.853230  25.261702  6.477434  0.981760  24.763071  15.471854  1.0\n",
       "2  1.087121   7.039875  1.716736  0.187131   7.558155   5.008439  1.0\n",
       "3  1.455624   9.494270  2.335811  0.362901  10.058472   6.797906  1.0\n",
       "4  3.219329  21.966800  5.851249  0.879001  20.211653  13.133479  1.0"
      ]
     },
     "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",
    "x6 = np.ones(1000)\n",
    "X = pd.DataFrame(np.array([x0, x1, x2, x3, x4, x5, x6]).T, columns=[\"x0\", \"x1\", \"x2\", \"x3\", \"x4\", \"x5\", \"x6\"])\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 0x76807dd6feb0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plugin = Plugins().get(\"scm\", cd_method=\"direct-lingam\", strict=False)\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",
       "      <th>x6</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.548814</td>\n",
       "      <td>4.228141</td>\n",
       "      <td>2.080083</td>\n",
       "      <td>0.720310</td>\n",
       "      <td>2.583537</td>\n",
       "      <td>2.560463</td>\n",
       "      <td>0.374794</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.715189</td>\n",
       "      <td>4.747374</td>\n",
       "      <td>1.771649</td>\n",
       "      <td>0.907008</td>\n",
       "      <td>4.503259</td>\n",
       "      <td>3.156334</td>\n",
       "      <td>0.428686</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.602763</td>\n",
       "      <td>4.468443</td>\n",
       "      <td>1.834207</td>\n",
       "      <td>1.056618</td>\n",
       "      <td>3.109776</td>\n",
       "      <td>2.477927</td>\n",
       "      <td>0.683057</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.544883</td>\n",
       "      <td>4.317998</td>\n",
       "      <td>1.566334</td>\n",
       "      <td>1.090990</td>\n",
       "      <td>3.129601</td>\n",
       "      <td>2.530500</td>\n",
       "      <td>0.600948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.423655</td>\n",
       "      <td>2.850203</td>\n",
       "      <td>1.390319</td>\n",
       "      <td>1.024951</td>\n",
       "      <td>2.039887</td>\n",
       "      <td>1.925602</td>\n",
       "      <td>0.070483</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         x0        x1        x2        x3        x4        x5        x6\n",
       "0  0.548814  4.228141  2.080083  0.720310  2.583537  2.560463  0.374794\n",
       "1  0.715189  4.747374  1.771649  0.907008  4.503259  3.156334  0.428686\n",
       "2  0.602763  4.468443  1.834207  1.056618  3.109776  2.477927  0.683057\n",
       "3  0.544883  4.317998  1.566334  1.090990  3.129601  2.530500  0.600948\n",
       "4  0.423655  2.850203  1.390319  1.024951  2.039887  1.925602  0.070483"
      ]
     },
     "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=\"244pt\" height=\"312pt\"\n",
       " viewBox=\"0.00 0.00 244.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 240,-307.75 240,4 -4,4\"/>\n",
       "<!-- x0 -->\n",
       "<g id=\"node1\" class=\"node\">\n",
       "<title>x0</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"122\" cy=\"-285.75\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"122\" y=\"-281.07\" 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=\"27\" cy=\"-196.5\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"27\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">x1</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x1 -->\n",
       "<g id=\"edge1\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x1</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M96.49,-278.93C79.61,-273.85 58.16,-264.87 44.5,-249.75 38.37,-242.96 34.37,-233.96 31.78,-225.33\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"34.98,-224.69 29.18,-215.82 28.18,-226.36 34.98,-224.69\"/>\n",
       "<text text-anchor=\"middle\" x=\"60.75\" y=\"-236.45\" font-family=\"Times,serif\" font-size=\"14.00\">6.63</text>\n",
       "</g>\n",
       "<!-- x2 -->\n",
       "<g id=\"node3\" class=\"node\">\n",
       "<title>x2</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"69\" cy=\"-107.25\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"69\" y=\"-102.58\" font-family=\"Times,serif\" font-size=\"14.00\">x2</text>\n",
       "</g>\n",
       "<!-- x0&#45;&gt;x2 -->\n",
       "<g id=\"edge2\" class=\"edge\">\n",
       "<title>x0&#45;&gt;x2</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M116.92,-267.83C107.76,-237.33 88.41,-172.9 77.31,-135.91\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"80.37,-134.95 74.14,-126.38 73.67,-136.97 80.37,-134.95\"/>\n",
       "<text text-anchor=\"middle\" x=\"119\" y=\"-191.82\" font-family=\"Times,serif\" font-size=\"14.00\">&#45;1.43</text>\n",
       "</g>\n",
       "<!-- x4 -->\n",
       "<g id=\"node5\" class=\"node\">\n",
       "<title>x4</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"137\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"137\" 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=\"M127.66,-267.66C132.02,-253.58 137.67,-232.99 140,-214.5 147.47,-155.29 143.26,-85.2 139.9,-47.1\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"143.31,-46.98 138.89,-37.35 136.34,-47.63 143.31,-46.98\"/>\n",
       "<text text-anchor=\"middle\" x=\"160.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">8.08</text>\n",
       "</g>\n",
       "<!-- x5 -->\n",
       "<g id=\"node6\" class=\"node\">\n",
       "<title>x5</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"209\" cy=\"-196.5\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"209\" y=\"-191.82\" 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=\"M140.34,-272.45C149.13,-266.15 159.56,-258.06 168,-249.75 176.5,-241.37 184.83,-231.23 191.74,-222.12\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"195.01,-224.58 198.12,-214.45 189.37,-220.43 195.01,-224.58\"/>\n",
       "<text text-anchor=\"middle\" x=\"197.75\" y=\"-236.45\" font-family=\"Times,serif\" font-size=\"14.00\">4.00</text>\n",
       "</g>\n",
       "<!-- x1&#45;&gt;x2 -->\n",
       "<g id=\"edge3\" class=\"edge\">\n",
       "<title>x1&#45;&gt;x2</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M31.34,-178.54C34.34,-168.07 38.82,-154.53 44.5,-143.25 46.31,-139.66 48.45,-136.02 50.7,-132.52\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"54,-134.9 56.77,-124.67 48.22,-130.94 54,-134.9\"/>\n",
       "<text text-anchor=\"middle\" x=\"60.75\" y=\"-147.2\" font-family=\"Times,serif\" font-size=\"14.00\">0.48</text>\n",
       "</g>\n",
       "<!-- x3 -->\n",
       "<g id=\"node4\" class=\"node\">\n",
       "<title>x3</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"48\" cy=\"-18\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"48\" y=\"-13.32\" font-family=\"Times,serif\" font-size=\"14.00\">x3</text>\n",
       "</g>\n",
       "<!-- x2&#45;&gt;x3 -->\n",
       "<g id=\"edge4\" class=\"edge\">\n",
       "<title>x2&#45;&gt;x3</title>\n",
       "<path fill=\"none\" stroke=\"black\" d=\"M58.16,-90.57C54.72,-84.76 51.35,-77.96 49.5,-71.25 47.4,-63.61 46.55,-55.1 46.36,-47.2\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"49.87,-47.28 46.46,-37.25 42.87,-47.21 49.87,-47.28\"/>\n",
       "<text text-anchor=\"middle\" x=\"65.75\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">0.15</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=\"M78.76,-90.22C85.44,-79.63 94.74,-65.61 104,-54 107.34,-49.81 111.08,-45.53 114.8,-41.46\"/>\n",
       "<polygon fill=\"black\" stroke=\"black\" points=\"116.99,-44.17 121.3,-34.5 111.9,-39.37 116.99,-44.17\"/>\n",
       "<text text-anchor=\"middle\" x=\"122\" y=\"-57.95\" font-family=\"Times,serif\" font-size=\"14.00\">&#45;1.05</text>\n",
       "</g>\n",
       "<!-- x6 -->\n",
       "<g id=\"node7\" class=\"node\">\n",
       "<title>x6</title>\n",
       "<ellipse fill=\"none\" stroke=\"black\" cx=\"194\" cy=\"-285.75\" rx=\"27\" ry=\"18\"/>\n",
       "<text text-anchor=\"middle\" x=\"194\" y=\"-281.07\" font-family=\"Times,serif\" font-size=\"14.00\">x6</text>\n",
       "</g>\n",
       "</g>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<graphviz.graphs.Digraph at 0x7680544f1b40>"
      ]
     },
     "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
}
