{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from graph_modelling.Graph.Node import Node\n",
    "from graph_modelling.Graph.NodeType import NodeType\n",
    "from graph_modelling.Graph.Graph import GeneralGraph\n",
    "\n",
    "from graph_modelling.Utils.GraphUtils import print_path, is_connected_to, is_E_connected_to, generate_DMG, calculate_E_separation_triple, generate_lifted_dependence_graph\n",
    "from graph_modelling.Utils.Utils import convert_independence_triples\n",
    "\n",
    "import numpy as np\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080340> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080370> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X3_1 \n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080340> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080370> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107c7fa30> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107c7fac0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080340> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d360> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080370> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c3a0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9cd30> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d780> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d840> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d1e0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080340> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d360> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080370> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c3a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9cd30> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d720> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d780> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 <--- X2_1 \n",
      "Triple config:  X3_1 <--- X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 <--- X2_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d840> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d060> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d120> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d150> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d180> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d1b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d1e0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d360> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c3a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c460> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9cd30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d720> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d780> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d7b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d7e0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080340> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804c0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X2_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X2_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X2_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 <--> X2_0 \n",
      "Triple config:  X1_1 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 <--- X3_1 \n",
      "Triple config:  X4_1 <--- X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090ca0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090cd0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 <--- X3_0 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 <--- X3_1 \n",
      "Triple config:  X4_1 <--- X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_0 \n",
      "Triple config:  X2_1 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_1 and X3_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X2_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_0 \n",
      "Triple config:  X2_1 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0<--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0<--> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_1 and X3_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 <--> X2_0 \n",
      "Triple config:  X1_1 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "Triple config:  X1_1 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 <--- X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 <--- X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090cd0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d00> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 <--- X3_0 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 <--- X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_1 and X1_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_1 \n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_1 and X1_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 ---> X4_1 <--- X1_0 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 ---> X4_1 <--- X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090dc0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X4_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0<--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X4_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c490> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X1_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0<--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0<--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090e20> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X3_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X3_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X2_0 ---- X3_1 and X3_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "Triple config:  X1_1 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d60> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090e20> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ff0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "Triple config:  X3_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 \n",
      "Triple config:  X1_1 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X4_0 \n",
      "Triple config:  X2_1 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 ---> X4_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 \n",
      "Triple config:  X4_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "Triple config:  X3_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 ---> X4_0 <--> X2_1 ---> X3_1 <--> X1_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082140> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X2_0\n",
      "edge:  X2_0 ---- X3_0 and X2_0 added\n",
      "Current path: \n",
      "X2_0---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "Triple config:  X3_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 \n",
      "Triple config:  X1_1 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X4_0 \n",
      "Triple config:  X2_1 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X2_0---> X3_0 <--> X1_0 <--> X2_1 <--> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082170> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X3_1 \n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_1 and X1_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082050> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 \n",
      "Triple config:  X3_1 <--- X2_1 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_0 \n",
      "Triple config:  X2_1 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_0 ---> X4_1 <--- X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f90> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 \n",
      "Triple config:  X3_1 <--- X2_1 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_0 \n",
      "Triple config:  X2_1 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_1 <--- X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X4_0 \n",
      "Triple config:  X2_0 <--> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d060> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d120> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d150> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d840> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d180> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d7b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080250> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_0 \n",
      "Triple config:  X1_1 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107c7fac0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9c3a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107c7ffd0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180805b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X4_1 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X3_0 ---- X1_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 \n",
      "Triple config:  X1_1 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_1 <--> X2_1 <--> X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 <--> X4_0 \n",
      "Triple config:  X2_1 <--> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 <--> X4_0 ---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X4_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0<--> X1_0 <--> X2_0 <--> X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 \n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_0 \n",
      "Triple config:  X1_1 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X2_1 \n",
      "Triple config:  X1_1 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_1 <--- X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 <--- X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d60> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d60> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090dc0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090e20> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d360> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0<--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X3_0\n",
      "edge:  X3_0 ---- X2_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0<--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X3_0 ---- X4_0 and X3_0 added\n",
      "Current path: \n",
      "X3_0---> X4_0 \n",
      "Triple config:  X3_0 ---> X4_0 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 ---> X4_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 \n",
      "Triple config:  X1_1 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X3_0---> X4_0 <--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d00> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d30> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d60> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090dc0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_1 \n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107c7fa30> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X2_1 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X3_1 \n",
      "Triple config:  X1_0 <--> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "Triple config:  X2_1 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d30> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090d60> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 ---> X4_1 \n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 <--- X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ed0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 ---> X4_1 \n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 \n",
      "Triple config:  X1_1 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_1 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 <--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--> X1_0 <--> X2_0 <--> X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 \n",
      "Triple config:  X2_0 ---> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 ---> X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 \n",
      "Triple config:  X3_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 ---> X3_0 <--> X1_0 <--> X2_1 ---> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "Triple config:  X1_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 \n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 \n",
      "Triple config:  X2_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_0 <--> X4_1 \n",
      "Triple config:  X2_0 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 <--> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 <--> X2_1 <--> X4_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X2_1 <--> X4_1 \n",
      "Triple config:  X2_1 <--> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_1 <--> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 \n",
      "Triple config:  X1_0 <--> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 <--> X1_1 \n",
      "Triple config:  X3_0 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_0 <--> X1_1 ---> X4_1 \n",
      "Triple config:  X1_1 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_1 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X3_0 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180804f0> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_0 added\n",
      "Current path: \n",
      "X4_0---> X4_1 \n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--- X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X4_0 ---> X4_1 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X4_0 ---- X2_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--> X2_0 \n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--> X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 \n",
      "Triple config:  X2_0 <--> X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_0 <--> X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 \n",
      "Triple config:  X1_0 <--> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 <--> X2_1 <--> X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 \n",
      "Triple config:  X2_1 <--> X1_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_0 \n",
      "Triple config:  X1_1 <--> X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X2_1 <--> X1_1 <--> X3_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X4_0<--> X2_0 <--> X1_0 <--> X2_1 <--> X1_1 <--> X3_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080040> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090c70> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118090ca0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d840> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081de0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 \n",
      "Triple config:  X2_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X2_0 ---> X3_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 ---> X3_1 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820e0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180821d0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080430> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e70> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x107d9d060> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080280> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 <--- X2_0 \n",
      "Triple config:  X3_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X3_0 <--- X2_0 <--> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X3_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180802b0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080580> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_1  the wanted endnode\n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080070> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082080> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803d0> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081fc0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X4_0<--- X1_0 ---> X4_1 \n",
      "LDG: \n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082020> TAIL ARROW\n",
      "X1_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180800a0> ARROW ARROW\n",
      "X1_0 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180820b0> TAIL ARROW\n",
      "X1_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080100> ARROW ARROW\n",
      "X1_0 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118082110> TAIL ARROW\n",
      "X2_1 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080130> ARROW ARROW\n",
      "X2_1 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080160> TAIL ARROW\n",
      "X3_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080190> ARROW ARROW\n",
      "X1_0 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180801f0> TAIL ARROW\n",
      "X1_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080220> ARROW ARROW\n",
      "X1_0 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080310> ARROW ARROW\n",
      "X2_0 <--> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x1180803a0> ARROW ARROW\n",
      "X1_1 <--> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080400> ARROW ARROW\n",
      "X1_1 <--> X2_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080460> ARROW ARROW\n",
      "X2_0 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080490> TAIL ARROW\n",
      "X3_0 ---> X4_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080520> TAIL ARROW\n",
      "X3_1 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118080550> ARROW ARROW\n",
      "X1_1 <--> X2_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e10> TAIL ARROW\n",
      "X2_0 ---> X3_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081e40> ARROW ARROW\n",
      "X2_1 <--> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081ea0> ARROW ARROW\n",
      "X1_1 <--> X3_0\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f00> TAIL ARROW\n",
      "X4_0 ---> X4_1\n",
      "<graph_modelling.Graph.Edge.Edge object at 0x118081f30> TAIL ARROW\n",
      "X2_0 ---> X3_0\n",
      "Algorithm just started and Initial node:  X4_0\n",
      "edge:  X4_0 ---- X1_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X1_0 \n",
      "Triple config:  X4_0 <--- X1_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X1_0 <--> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X3_0 and X4_0 added\n",
      "Current path: \n",
      "X4_0<--- X3_0 \n",
      "Triple config:  X4_0 <--- X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X3_0 <--> X1_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  True right_out_of:  False blockable_noncollider:  True\n",
      "edge:  X4_0 ---- X4_1 and X4_1  the wanted endnode\n",
      "[('X1', 'X1', ()), ('X2', 'X2', ()), ('X3', 'X2', ()), ('X3', 'X2', ('X2',)), ('X3', 'X3', ('X2',))]\n",
      "[('X1', 'X1', ()), ('X2', 'X2', ()), ('X3', 'X2', ()), ('X3', 'X2', ('X2',)), ('X3', 'X3', ('X2',))]\n",
      "[('X1', 'X1', ()), ('X2', 'X2', ()), ('X3', 'X2', ()), ('X3', 'X2', ('X2',)), ('X3', 'X3', ('X2',))]\n",
      "[('X1', 'X1', ()), ('X2', 'X2', ()), ('X3', 'X2', ()), ('X3', 'X2', ('X2',)), ('X3', 'X3', ('X2',))]\n",
      "[('X1', 'X1', ()), ('X2', 'X2', ()), ('X3', 'X2', ()), ('X3', 'X2', ('X2',)), ('X3', 'X3', ('X2',))]\n"
     ]
    }
   ],
   "source": [
    "def example_graph_DMG():\n",
    "    node1 = Node(\"X1\", NodeType.OBSERVED)\n",
    "    node2 = Node(\"X2\", NodeType.OBSERVED)\n",
    "    node3 = Node(\"X3\", NodeType.OBSERVED)\n",
    "    node4 = Node(\"X4\", NodeType.OBSERVED)\n",
    "    node5 = Node(\"X5\", NodeType.OBSERVED)\n",
    "    \n",
    "\n",
    "    graph = GeneralGraph([node1, node2, node3, node4, node5])\n",
    "    graph.add_directed_edge(node1, node2)\n",
    "    graph.add_directed_edge(node2, node1)\n",
    "    \n",
    "    graph.add_directed_edge(node2, node3)\n",
    "\n",
    "    graph.add_directed_edge(node3, node4)\n",
    "    graph.add_directed_edge(node4, node3)\n",
    "\n",
    "    graph.add_directed_edge(node4, node5)\n",
    "\n",
    "    graph.add_bidirected_edge(node1, node5)\n",
    "\n",
    "    graph.calculate_strongly_connected_components()\n",
    "    bool_help, path = is_connected_to(node1, node4, [node2], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node4.get_name(), \"given\", [node2.get_name()], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node4, [node2, node5], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node4.get_name(), \"given\", [node2.get_name(), node5.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_4 | {X_2}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node4, [node3], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node4.get_name(), \"given\", [node3.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_4 | {X_3}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "def example_graph_DG(): \n",
    "    node1 = Node(\"X1\", NodeType.OBSERVED)\n",
    "    node2 = Node(\"X2\", NodeType.OBSERVED)\n",
    "    node3 = Node(\"X3\", NodeType.OBSERVED)\n",
    "    node4 = Node(\"X4\", NodeType.OBSERVED)\n",
    "    node5 = Node(\"X5\", NodeType.OBSERVED)\n",
    "    node6 = Node(\"X6\", NodeType.OBSERVED)\n",
    "    node7 = Node(\"X7\", NodeType.OBSERVED)\n",
    "\n",
    "    graph = GeneralGraph([node1, node2, node3, node4, node5, node6, node7])\n",
    "    graph.add_directed_edge(node1, node2)\n",
    "    graph.add_directed_edge(node1, node6)\n",
    "    graph.add_directed_edge(node2, node1)\n",
    "    graph.add_directed_edge(node2, node3)\n",
    "    graph.add_directed_edge(node3, node4)\n",
    "    graph.add_directed_edge(node4, node5)\n",
    "    graph.add_directed_edge(node5, node3)\n",
    "    graph.add_directed_edge(node5, node6)\n",
    "    graph.add_directed_edge(node5, node7)\n",
    "    graph.add_directed_edge(node6, node7)\n",
    "    graph.add_directed_edge(node7, node6)\n",
    "\n",
    "    graph.calculate_strongly_connected_components()\n",
    "    bool_help, path = is_connected_to(node2, node5, [], graph,connectivity_type=\"sigma\", verbose = False)\n",
    "    print(node2.get_name(), \"indep.\", node5.get_name(), \"given\", [], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node4, [node2], graph,connectivity_type=\"sigma\", verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node4.get_name(), \"given\", [node2.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_4 | {X_2}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node4, [node3], graph,connectivity_type=\"sigma\", verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node4.get_name(), \"given\", [node3.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_4 | {X_3}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "def example_graph_causality_lecture_DAG():\n",
    "    node1 = Node(\"X1\", NodeType.OBSERVED)\n",
    "    node2 = Node(\"X2\", NodeType.OBSERVED)\n",
    "    node3 = Node(\"X3\", NodeType.OBSERVED)\n",
    "    node4 = Node(\"X4\", NodeType.OBSERVED)\n",
    "    node5 = Node(\"X5\", NodeType.OBSERVED)\n",
    "    node6 = Node(\"X6\", NodeType.OBSERVED)\n",
    "    node7 = Node(\"X7\", NodeType.OBSERVED)\n",
    "\n",
    "    graph = GeneralGraph([node1, node2, node3, node4, node5, node6, node7])\n",
    "    graph.add_directed_edge(node1, node2)\n",
    "    graph.add_directed_edge(node1, node7)\n",
    "    graph.add_directed_edge(node2, node4)\n",
    "    graph.add_directed_edge(node3, node2)\n",
    "    graph.add_directed_edge(node3, node5)\n",
    "    graph.add_directed_edge(node3, node6)\n",
    "    graph.add_directed_edge(node5, node7)\n",
    "    graph.add_directed_edge(node6, node5)\n",
    "\n",
    "    bool_help, path = is_connected_to(node2, node5, [], graph, verbose = False)\n",
    "    print(node2.get_name(), \"indep.\", node5.get_name(), \"given\", [], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node3, [], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node3.get_name(), \"given\", [], \"? ->\",not bool_help) # X_1 \\indep X_3 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node7, node4, [], graph, verbose = False)\n",
    "    print(node7.get_name(), \"indep.\", node4.get_name(), \"given\", [], \"? ->\",not bool_help) # X_7 \\indep X_4 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node6, [], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node6.get_name(), \"given\", [], \"? ->\",not bool_help) # X_1 \\indep X_6 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node7, node4, [node2], graph, verbose = False)\n",
    "    print(node7.get_name(), \"indep.\", node4.get_name(), \"given\", [node2.get_name()], \"? ->\",not bool_help) # X_7 \\indep X_4 | {X_2}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node4], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node4.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_4}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node2, node7], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node2.get_name(), node7.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_2, X_7}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node3], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node3.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_3}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node6, node1, [node5, node3, node2, node4, node7], graph, verbose = False)\n",
    "    print(node6.get_name(), \"indep.\", node1.get_name(), \"given\", [node5.get_name(), node3.get_name(), node2.get_name(), node4.get_name(), node7.get_name()], \"? ->\",not bool_help)\n",
    "    # X_6 \\indep X_1 | {X_5, X_3, X_2, X_4, X_7}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "def example_graph_causality_lecture_ADMG():\n",
    "    node1 = Node(\"X1\", NodeType.OBSERVED)\n",
    "    node2 = Node(\"X2\", NodeType.OBSERVED)\n",
    "    node3 = Node(\"X3\", NodeType.OBSERVED)\n",
    "    node4 = Node(\"X4\", NodeType.OBSERVED)\n",
    "    node5 = Node(\"X5\", NodeType.OBSERVED)\n",
    "    node6 = Node(\"X6\", NodeType.OBSERVED)\n",
    "    node7 = Node(\"X7\", NodeType.OBSERVED)\n",
    "\n",
    "    graph = GeneralGraph([node1, node2, node3, node4, node5, node6, node7])\n",
    "    graph.add_directed_edge(node1, node2)\n",
    "    graph.add_directed_edge(node1, node7)\n",
    "    graph.add_bidirected_edge(node1, node7)\n",
    "    graph.add_bidirected_edge(node2, node4)\n",
    "    graph.add_directed_edge(node3, node2)\n",
    "    graph.add_directed_edge(node3, node5)\n",
    "    graph.add_directed_edge(node3, node6)\n",
    "    graph.add_bidirected_edge(node3, node5)\n",
    "    graph.add_directed_edge(node5, node7)\n",
    "    graph.add_bidirected_edge(node6, node5)\n",
    "    bool_help, path = is_connected_to(node2, node5, [], graph, verbose = False)\n",
    "    print(node2.get_name(), \"indep.\", node5.get_name(), \"given\", [], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node3, [], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node3.get_name(), \"given\", [], \"? ->\",not bool_help) # X_1 \\indep X_3 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node7, node4, [], graph, verbose = False)\n",
    "    print(node7.get_name(), \"indep.\", node4.get_name(), \"given\", [], \"? ->\",not bool_help) # X_7 \\indep X_4 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node1, node6, [], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node6.get_name(), \"given\", [], \"? ->\",not bool_help) # X_1 \\indep X_6 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node7, node4, [node2], graph, verbose = False)\n",
    "    print(node7.get_name(), \"indep.\", node4.get_name(), \"given\", [node2.get_name()], \"? ->\",not bool_help) # X_7 \\indep X_4 | {X_2}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node4], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node4.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_4}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node2, node7], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node2.get_name(), node7.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_2, X_7}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "    \n",
    "    bool_help, path = is_connected_to(node1, node5, [node3], graph, verbose = False)\n",
    "    print(node1.get_name(), \"indep.\", node5.get_name(), \"given\", [node3.get_name()], \"? ->\",not bool_help) # X_1 \\indep X_5 | {X_3}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_connected_to(node6, node1, [node5, node3, node2, node4, node7], graph, verbose = False)\n",
    "    print(node6.get_name(), \"indep.\", node1.get_name(), \"given\", [node5.get_name(), node3.get_name(), node2.get_name(), node4.get_name(), node7.get_name()], \"? ->\",not bool_help)\n",
    "    # X_6 \\indep X_1 | {X_5, X_3, X_2, X_4, X_7}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "def example_lifted_DG():\n",
    "    node1 = Node(\"X1\", NodeType.OBSERVED)\n",
    "    node2 = Node(\"X2\", NodeType.OBSERVED)\n",
    "    graph = GeneralGraph([node1, node2])\n",
    "    graph.add_directed_edge(node1, node2)\n",
    "    graph.add_directed_edge(node1, node1)\n",
    "\n",
    "    bool_help, path = is_E_connected_to(node1, node2, [], graph, verbose = False)\n",
    "    print(node1.get_name(), \"E-indep.\", node2.get_name(), \"given\", [], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_E_connected_to(node2, node1, [], graph, verbose = False)\n",
    "    print(node2.get_name(), \"E-indep.\", node1.get_name(), \"given\", [], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "    bool_help, path = is_E_connected_to(node2, node1, [node1], graph, verbose = False)\n",
    "    print(node2.get_name(), \"E-indep.\", node1.get_name(), \"given\", [node1.get_name()], \"? ->\",not bool_help) # X_2 \\indep X_5 | {}\n",
    "    if bool_help:\n",
    "        print_path(path)\n",
    "\n",
    "# example_graph_causality_lecture_ADMG()\n",
    "# example_graph_causality_lecture_DAG()\n",
    "# example_graph_DG()\n",
    "# example_graph_DMG()\n",
    "\n",
    "# example_lifted_DG()\n",
    "\n",
    "directed_matrix_1 = np.array([[0, 0, 0, 0],\n",
    "                              [0, 0, 0, 0],\n",
    "                              [0, 1, 0, 0],\n",
    "                              [1, 0, 1, 1]])\n",
    "\n",
    "symmetric_matrix = np.array([[0, 1, 1, 0],\n",
    "                             [1, 0, 0, 1],\n",
    "                             [1, 0, 0, 0],\n",
    "                             [0, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_2 = np.array([[0, 0, 0, 0],\n",
    "                              [0, 0, 0, 0],\n",
    "                              [0, 1, 0, 0],\n",
    "                              [1, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_3 = np.array([[0, 0, 0, 0],\n",
    "                              [0, 0, 0, 0],\n",
    "                              [0, 1, 0, 0],\n",
    "                              [1, 1, 1, 1]])\n",
    "\n",
    "directed_matrix_4 = np.array([[0, 0, 0, 0],\n",
    "                              [0, 0, 0, 0],\n",
    "                              [0, 1, 0, 0],\n",
    "                              [1, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_5 = np.array([[0, 0, 0, 0],\n",
    "                              [0, 0, 0, 0],\n",
    "                              [0, 1, 0, 0],\n",
    "                              [1, 0, 1, 0]])\n",
    "\n",
    "graph_1 = generate_DMG(directed_matrix_1, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_1 = convert_independence_triples(calculate_E_separation_triple(graph_1, True))\n",
    "\n",
    "graph_2 = generate_DMG(directed_matrix_2, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_2 = convert_independence_triples(calculate_E_separation_triple(graph_2))\n",
    "\n",
    "graph_3 = generate_DMG(directed_matrix_3, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_3 = convert_independence_triples(calculate_E_separation_triple(graph_3))\n",
    "\n",
    "graph_4 = generate_DMG(directed_matrix_4, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_4 = convert_independence_triples(calculate_E_separation_triple(graph_4))\n",
    "\n",
    "graph_5 = generate_DMG(directed_matrix_5, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_5 = convert_independence_triples(calculate_E_separation_triple(graph_5))\n",
    "\n",
    "print(independence_triple_1)\n",
    "print(independence_triple_2)\n",
    "\n",
    "print(independence_triple_4)\n",
    "print(independence_triple_5)\n",
    "print(independence_triple_3)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Algorithm just started and Initial node:  X1_0\n",
      "edge:  X1_0 ---- X3_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X3_0 \n",
      "Triple config:  X1_0 ---> X3_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X3_1 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X3_1 \n",
      "Triple config:  X1_0 ---> X3_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X3_1 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "Triple config:  X1_0 ---> X3_1 <--- X2_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  False\n",
      "edge:  X1_0 ---- X4_0 and X1_0 added\n",
      "Current path: \n",
      "X1_0---> X4_0 \n",
      "Triple config:  X1_0 ---> X4_0 <--- X2_0\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 <--- X2_0 \n",
      "Triple config:  X4_0 <--- X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 <--- X2_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X2_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  False blockable_noncollider:  False\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X2_0 \n",
      "Triple config:  X4_0 ---> X2_0 ---> X3_0\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 ---> X2_0 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 ---> X2_0 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X1_0 ---> X4_0 ---> X2_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X2_1 \n",
      "Triple config:  X4_0 ---> X2_1 ---> X3_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  True blockable_noncollider:  True\n",
      "Triple config:  X4_0 ---> X2_1 ---> X4_1\n",
      "Is node_b middle a collider:  False\n",
      "left_out_of:  False right_out_of:  False blockable_noncollider:  False\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X2_1 ---> X4_1 \n",
      "Triple config:  X2_1 ---> X4_1 <--- X1_1\n",
      "Is node_b middle a collider:  True\n",
      "Is node_b middle an ancestor:  True\n",
      "Current path: \n",
      "X1_0---> X4_0 ---> X2_1 ---> X4_1 <--- X1_1 \n",
      "True\n",
      "X1_0---> X4_0 ---> X2_1 ---> X4_1 <--- X1_1 \n",
      "------------------------------------------------------------------------------------------------------------------------\n",
      "True\n",
      "X1_0---> X2_0 ---> X4_0 ---> X2_1 ---> X4_1 \n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n",
      "[('X1', 'X1', ()), ('X2', 'X1', ()), ('X2', 'X1', ('X1',)), ('X3', 'X1', ()), ('X3', 'X1', ('X1',)), ('X3', 'X1', ('X1', 'X2')), ('X3', 'X1', ('X1', 'X2', 'X4')), ('X3', 'X2', ('X1', 'X2')), ('X3', 'X2', ('X1', 'X2', 'X4')), ('X3', 'X3', ('X1', 'X2')), ('X3', 'X3', ('X1', 'X2', 'X4')), ('X3', 'X4', ('X1', 'X2')), ('X3', 'X4', ('X1', 'X2', 'X4')), ('X4', 'X1', ()), ('X4', 'X1', ('X1',)), ('X4', 'X3', ('X1', 'X2')), ('X4', 'X3', ('X1', 'X2', 'X3'))]\n"
     ]
    }
   ],
   "source": [
    "symmetric_matrix = np.array([[0, 0, 0, 0],\n",
    "                             [0, 0, 0, 0],\n",
    "                             [0, 0, 0, 0],\n",
    "                             [0, 0, 0, 0]])\n",
    "\n",
    "directed_matrix_1 = np.array([[0, 0, 0, 0], # \n",
    "                              [0, 0, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 0]])\n",
    "\n",
    "\n",
    "directed_matrix_2 = np.array([[0, 0, 0, 0], # \n",
    "                              [0, 0, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_3 = np.array([[0, 0, 0, 0], # \n",
    "                              [0, 1, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_4 = np.array([[0, 0, 0, 0], # \n",
    "                              [0, 1, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_5 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 0, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_6 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 0, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_7 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 1, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_8 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 1, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [1, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_9 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 0, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [0, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_10 = np.array([[0, 0, 0, 0],\n",
    "                               [1, 0, 0, 1],\n",
    "                               [1, 1, 0, 0],\n",
    "                               [0, 1, 0, 1]])\n",
    "\n",
    "directed_matrix_11 = np.array([[0, 0, 0, 0],\n",
    "                              [1, 1, 0, 1],\n",
    "                              [1, 1, 0, 0],\n",
    "                              [0, 1, 0, 0]])\n",
    "\n",
    "directed_matrix_12 = np.array([[0, 0, 0, 0],\n",
    "                               [1, 1, 0, 1],\n",
    "                               [1, 1, 0, 0],\n",
    "                               [0, 1, 0, 1]])\n",
    "\n",
    "graph_1 = generate_DMG(directed_matrix_1, symmetric_matrix, graph_type=\"DMG\")\n",
    "LDG = generate_lifted_dependence_graph(graph_1)\n",
    "LDG.calculate_strongly_connected_components()\n",
    "node1_past = LDG.get_node(\"X1_0\")\n",
    "node2_future = LDG.get_node(\"X1_1\")\n",
    "cond_set = [LDG.get_node(\"X2_0\"), LDG.get_node(\"X2_1\")]\n",
    "bool_help, path = is_connected_to(node1_past, node2_future, cond_set, LDG,connectivity_type=\"sigma\", verbose = True)\n",
    "print(bool_help)\n",
    "if bool_help:\n",
    "    print_path(path)\n",
    "independence_triple_1 = convert_independence_triples(calculate_E_separation_triple(graph_1, verbose = False))\n",
    "\n",
    "\n",
    "\n",
    "graph_2 = generate_DMG(directed_matrix_2, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_2 = convert_independence_triples(calculate_E_separation_triple(graph_2))\n",
    "\n",
    "graph_3 = generate_DMG(directed_matrix_3, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_3 = convert_independence_triples(calculate_E_separation_triple(graph_3, verbose = False))\n",
    "\n",
    "graph_4 = generate_DMG(directed_matrix_4, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_4 = convert_independence_triples(calculate_E_separation_triple(graph_4))\n",
    "\n",
    "graph_5 = generate_DMG(directed_matrix_5, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_5 = convert_independence_triples(calculate_E_separation_triple(graph_5))\n",
    "\n",
    "graph_6 = generate_DMG(directed_matrix_6, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_6 = convert_independence_triples(calculate_E_separation_triple(graph_6))\n",
    "\n",
    "graph_7 = generate_DMG(directed_matrix_7, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_7 = convert_independence_triples(calculate_E_separation_triple(graph_7))\n",
    "\n",
    "graph_8 = generate_DMG(directed_matrix_8, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_8 = convert_independence_triples(calculate_E_separation_triple(graph_8))\n",
    "\n",
    "graph_9 = generate_DMG(directed_matrix_9, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_9 = convert_independence_triples(calculate_E_separation_triple(graph_9, verbose = False))\n",
    "\n",
    "graph_10 = generate_DMG(directed_matrix_10, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_10 = convert_independence_triples(calculate_E_separation_triple(graph_10))\n",
    "\n",
    "graph_11 = generate_DMG(directed_matrix_11, symmetric_matrix, graph_type=\"DMG\")\n",
    "independence_triple_11 = convert_independence_triples(calculate_E_separation_triple(graph_11))\n",
    "\n",
    "graph_12 = generate_DMG(directed_matrix_12, symmetric_matrix, graph_type=\"DMG\")\n",
    "print(\"---\"*40)\n",
    "independence_triple_12 = convert_independence_triples(calculate_E_separation_triple(graph_12, verbose = False))\n",
    "\n",
    "bool_help, path = is_E_connected_to(graph_12.get_node(\"X1\"), graph_12.get_node(\"X4\"), list([graph_12.get_node(\"X2\"), graph_12.get_node(\"X3\")]), graph_12, verbose = False)\n",
    "print(bool_help)\n",
    "if bool_help:\n",
    "    print_path(path)\n",
    "\n",
    "print(independence_triple_1)\n",
    "print(independence_triple_2)\n",
    "print(independence_triple_3)\n",
    "print(independence_triple_4)\n",
    "print(independence_triple_5)\n",
    "print(independence_triple_6)\n",
    "print(independence_triple_7)\n",
    "print(independence_triple_8)\n",
    "print(independence_triple_9)\n",
    "print(independence_triple_10)\n",
    "print(independence_triple_11)\n",
    "print(independence_triple_12)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jax_env",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
