{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "GRaSP completed in: 0.08s \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from causallearn.search.PermutationBased.GRaSP import grasp\n",
    "from experiments.checkmark_dag.dataset import checkmark_dataset\n",
    "\n",
    "x_train, s_train, dag = checkmark_dataset(1000, 1, 0.1, return_y=False)\n",
    "# default parameters\n",
    "G = grasp(s_train.numpy(), score_func='local_score_BDeu')\n",
    "\n",
    "from causallearn.utils.GraphUtils import GraphUtils\n",
    "import matplotlib.image as mpimg\n",
    "import matplotlib.pyplot as plt\n",
    "import io\n",
    "\n",
    "pyd = GraphUtils.to_pydot(G)\n",
    "tmp_png = pyd.create_png(f=\"png\")\n",
    "fp = io.BytesIO(tmp_png)\n",
    "img = mpimg.imread(fp, format='png')\n",
    "plt.axis('off')\n",
    "plt.imshow(img)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2 only supports OpenSSL 1.1.1+, currently the 'ssl' module is compiled with 'LibreSSL 2.8.3'. See: https://github.com/urllib3/urllib3/issues/3020\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 6    \n",
      "GRaSP completed in: 0.12s \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from experiments.checkmark_dag.dataset import checkmark_dataset\n",
    "from experiments.dsprites.dataset import load_preprocessed_data\n",
    "import torch\n",
    "\n",
    "x_train, c_train, y_train, x_test, c_test, y_test = load_preprocessed_data()\n",
    "s_train = torch.cat([c_train, y_train], dim=1)\n",
    "\n",
    "G = grasp(s_train.numpy(), score_func='local_score_BDeu')\n",
    "\n",
    "from causallearn.utils.GraphUtils import GraphUtils\n",
    "import matplotlib.image as mpimg\n",
    "import matplotlib.pyplot as plt\n",
    "import io\n",
    "\n",
    "pyd = GraphUtils.to_pydot(G)\n",
    "tmp_png = pyd.create_png(f=\"png\")\n",
    "fp = io.BytesIO(tmp_png)\n",
    "img = mpimg.imread(fp, format='png')\n",
    "plt.axis('off')\n",
    "plt.imshow(img)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Smiling', 'Attractive', 'Mouth_Slig', 'High_Cheek', 'Wearing_Li', 'Heavy_Make', 'Male', 'Wavy_Hair', 'Big_Lips', 'Oval_Face', 'Makeup', 'Fem_Model']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 33    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 32    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 33    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 32    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 34    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 34    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 34    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 33    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 34    "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n",
      "/Users/gabri/Desktop/USI/PhD/causal-cbm/venv/lib/python3.9/site-packages/causallearn/score/LocalScoreFunction.py:126: FutureWarning: When grouping with a length-1 list-like, you will need to pass a length-1 tuple to get_group in a future version of pandas. Pass `(name,)` instead of `name` to silence this warning.\n",
      "  ij: Data_pd_group_Nij.get_group(ij)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRaSP edge count: 34    \n",
      "GRaSP completed in: 18.21s \n"
     ]
    }
   ],
   "source": [
    "from experiments.celeba.dataset import load_celeba_data\n",
    "x, s, label_names = load_celeba_data('./experiments/data', split='test')\n",
    "print(label_names)\n",
    "G = grasp(s.numpy(), score_func='local_score_BDeu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0 -1 -1 -1 -1  0  0  0  0 -1  0 -1]\n",
      " [ 1  0  1  0  1 -1  0 -1  0 -1 -1 -1]\n",
      " [-1 -1  0 -1  0  0  0  0  0  0  0  0]\n",
      " [ 1  0  1  0  1  0  0  0  0  1  0  0]\n",
      " [-1 -1  0 -1  0 -1 -1 -1 -1 -1 -1 -1]\n",
      " [ 0  1  0  0  1  0 -1  0  0  1  0  1]\n",
      " [ 0  0  0  0  1  1  0 -1  0  0  0  1]\n",
      " [ 0  1  0  0  1  0  1  0  0  0  1  0]\n",
      " [ 0  0  0  0  1  0  0  0  0 -1  1  1]\n",
      " [ 1  1  0 -1  1 -1  0  0  1  0  0  1]\n",
      " [ 0  1  0  0  1  0  0 -1 -1  0  0 -1]\n",
      " [ 1  1  0  0  1 -1 -1  0 -1 -1  1  0]]\n",
      "[(2, 0), (4, 0)] 32.0\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "print(G.graph)\n",
    "adj = np.zeros(G.graph.shape)\n",
    "to_check = []\n",
    "for j in range(G.graph.shape[0]):\n",
    "    for i in range(G.graph.shape[1]):\n",
    "        if G.graph[j, i] == 1 and G.graph[i, j] == -1:\n",
    "            adj[i, j] = 1\n",
    "        if G.graph[j, i] == -1 and G.graph[i, j] == -1:\n",
    "            # adj[i, j] = 1\n",
    "            # adj[j, i] = 1\n",
    "            if (i, j) not in to_check and (j, i) not in to_check:\n",
    "                to_check.append((i, j))\n",
    "print(to_check, adj.sum())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pyd = GraphUtils.to_pydot(G)\n",
    "tmp_png = pyd.create_png(f=\"png\")\n",
    "fp = io.BytesIO(tmp_png)\n",
    "img = mpimg.imread(fp, format='png')\n",
    "plt.axis('off')\n",
    "plt.imshow(img)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.9.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
