{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os,sys\n",
    "cwd = os.path.abspath(os.path.curdir)\n",
    "parent_dir = os.path.abspath(os.path.join(cwd, os.pardir))\n",
    "\n",
    "sys.path.append(cwd)  # workplace\n",
    "from src.utils import *\n",
    "from inter_gt import *\n",
    "import numpy as np\n",
    "import pandas as pd\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating counterfactual inference questions and answers \n",
    "* 10 causal graphs with 51 nodes\n",
    "* saved in ./data/table/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 637.98it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 443.44it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 525.80it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 370.73it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 275.50it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 222.78it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 241.56it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 169.48it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 215.14it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 50: 100%|██████████| 51/51 [00:00<00:00, 279.90it/s]\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/136942453.py:21: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for sindex in range(1,11):\n",
    "    np.random.seed(77)\n",
    "    intervention_ls = np.random.randn(51)*5\n",
    "    dataname = 'sim_lu'\n",
    "\n",
    "    data_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_data.csv'\n",
    "    data_df = pd.read_csv(data_path)\n",
    "    adj_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_target.csv'\n",
    "    adj_df = pd.read_csv(adj_path)\n",
    "\n",
    "    gcm_gt ,causal_model_gt, causal_graph_gt = train_scm_model(adj_df,data_df)\n",
    "\n",
    "    answers = []\n",
    "    with open(cwd+f'/data/table/counterfactual_questions_{sindex}.txt', 'w') as file:\n",
    "        for v_i in range(51):\n",
    "            v_o = np.random.randint(0, high=51, size=1, dtype=int)[0]\n",
    "            int_i = intervention_ls[v_i]        \n",
    "            \n",
    "            input_sample = 'Given the values of V0 to V51 are' \n",
    "            for i in range(51):\n",
    "                input_sample += f' {data_df.loc[0][i]:.3f},'    \n",
    "            \n",
    "            question = input_sample + f' what is the expectation of the distribution of V{v_o} if the value of V{v_i} is {int_i}?\\n'\n",
    "            \n",
    "            file.write(question)\n",
    "        \n",
    "            data = data_df.iloc[:1,:51]\n",
    "            data.columns = list(causal_graph_gt.nodes)\n",
    "            samples = gcm_gt.counterfactual_samples(causal_model_gt, {v_i: lambda y: int_i},observed_data=data)[v_o]\n",
    "            answers.append(samples)\n",
    "\n",
    "    with open(cwd+f'/data/table/counterfactual_answers_{sindex}.txt', 'w') as file:\n",
    "        for i in answers:\n",
    "            file.write(f\"{i[0]}\\n\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating counterfactual inference questions and answers \n",
    "* 10 causal graphs with 10 nodes\n",
    "* saved in ./data/table/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 448.81it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 1302.94it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 195.83it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 526.40it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 393.26it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 887.55it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 299.51it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 318.78it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 389.53it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "Fitting causal mechanism of node 9: 100%|██████████| 10/10 [00:00<00:00, 505.17it/s]\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n",
      "/tmp/jupyter_kernel/3896064560.py:20: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  input_sample += f' {data_df.loc[0][i]:.3f},'\n"
     ]
    }
   ],
   "source": [
    "for sindex in range(100,110):\n",
    "    np.random.seed(77)\n",
    "    intervention_ls = np.random.randn(10)*5\n",
    "    dataname = 'sim_lu'\n",
    "\n",
    "    data_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_data.csv'\n",
    "    data_df = pd.read_csv(data_path)\n",
    "    adj_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_target.csv'\n",
    "    adj_df = pd.read_csv(adj_path)\n",
    "    gcm_gt ,causal_model_gt, causal_graph_gt = train_scm_model(adj_df,data_df)\n",
    "\n",
    "    answers = []\n",
    "    with open(cwd+f'/data/table/counterfactual_questions_{sindex}.txt', 'w') as file:\n",
    "        for v_i in range(10):\n",
    "            v_o = np.random.randint(0, high=10, size=1, dtype=int)[0]\n",
    "            int_i = intervention_ls[v_i]        \n",
    "            \n",
    "            input_sample = 'Given the values of V0 to V9 are' \n",
    "            for i in range(10):\n",
    "                input_sample += f' {data_df.loc[0][i]:.3f},'    \n",
    "            \n",
    "            question = input_sample + f' what is the expectation of the distribution of V{v_o} if the value of V{v_i} is {int_i}?\\n'\n",
    "            \n",
    "            file.write(question)\n",
    "        \n",
    "            data = data_df.iloc[:1,:10]\n",
    "            data.columns = list(causal_graph_gt.nodes)\n",
    "            samples = gcm_gt.counterfactual_samples(causal_model_gt, {v_i: lambda y: int_i},observed_data=data)[v_o]\n",
    "            answers.append(samples)\n",
    "\n",
    "    with open(cwd+f'/data/table/counterfactual_answers_{sindex}.txt', 'w') as file:\n",
    "        for i in answers:\n",
    "            file.write(f\"{i[0]}\\n\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating intervention inference questions \n",
    "* 10 causal graphs with 10 nodes\n",
    "* saved in ./data/table/\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "np.random.seed(77)\n",
    "intervention_ls = np.random.randn(10)*5\n",
    "\n",
    "dataname = 'lu'\n",
    "with open(cwd+f'/data/table/intervention_questions.txt', 'w') as file:\n",
    "    for v_i in range(10):\n",
    "        v_o = np.random.randint(0, high=10, size=1, dtype=int)[0]\n",
    "        int_i = intervention_ls[v_i]        \n",
    "        question = f'Given that the intervention value on V{v_i} is {int_i}, what is the expectation of the interventional distribution of V{v_o}? \\n'\n",
    "        file.write(question)\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating intervention inference questions\n",
    "* 10 causal graphs with 51 nodes\n",
    "* saved in ./data/table/\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "dataname= 'sim_lu' # lg lu sg nn\n",
    "mae_m = []\n",
    "sindex = 1\n",
    "data_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_data.csv'\n",
    "data_df = pd.read_csv(data_path)\n",
    "adj_path = parent_dir+f'/data/{dataname}/{sindex}/generated_graph_target.csv'\n",
    "adj_df = pd.read_csv(adj_path)\n",
    "n_nodes,_ = adj_df.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "np.random.seed(77)\n",
    "intervention_ls = np.random.randn(n_nodes)*5\n",
    "dataname = 'lu'\n",
    "with open(cwd+f'/data/table/intervention_questions.txt', 'w') as file:\n",
    "    for v_i in range(n_nodes):\n",
    "        v_o = np.random.randint(0, high=n_nodes, size=1, dtype=int)[0]\n",
    "        int_i = intervention_ls[v_i]        \n",
    "        question = f'Given that the intervention value on V{v_i} is {int_i}, what is the expectation of the interventional distribution of V{v_o}? \\n'\n",
    "        file.write(question)\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation of intervention inference resutls\n",
    "* 10 causal graph 51 nodes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1: ['-0.6828']\n",
      "1: ['0.1']\n",
      "1: ['1.0']\n",
      "1: ['1.0']\n",
      "1: ['1.5338']\n",
      "1: ['4.0']\n",
      "1: ['0.42']\n",
      "1: ['0.28494']\n",
      "1: ['1.008165']\n",
      "1: ['0.0']\n",
      "1: ['0.0']\n",
      "1: ['4.0']\n",
      "1: ['7.0041']\n",
      "1: ['0.092']\n",
      "1: ['0.5424']\n",
      "1: ['-0.392']\n",
      "1: ['0.0']\n",
      "1: ['1.094']\n",
      "1: ['0.59']\n",
      "1: ['0.58']\n",
      "1: ['0.54']\n",
      "1: ['7.159']\n",
      "1: ['-0.59']\n",
      "1: ['0.9']\n",
      "1: ['-1.98']\n",
      "1: ['1.0']\n",
      "1: ['1.0']\n",
      "1: ['1.0']\n",
      "1: ['-1.5428']\n",
      "1: ['0.7']\n",
      "1: ['9.0']\n",
      "1: ['7.0']\n",
      "1: ['0.17']\n",
      "1: ['-1.2']\n",
      "1: ['0.42']\n",
      "1: ['7.6828']\n",
      "1: ['0.0', '0.0']\n",
      "1: ['1.139246']\n",
      "1: ['5.0']\n",
      "1: ['-1.58898']\n",
      "1: ['0.084']\n",
      "1: ['-0.59']\n",
      "1: ['-1.24']\n",
      "1: ['-1.52']\n",
      "1: ['0.1']\n",
      "1: ['0.17918']\n",
      "1: ['8.1426']\n",
      "1: ['-0.653']\n",
      "1: ['-0.65']\n",
      "1: ['58.0']\n",
      "1: ['-1.38']\n",
      "2.8733104609587676\n",
      "2: ['62.0']\n",
      "2: ['1.78656']\n",
      "2: ['0.62']\n",
      "2: ['62.0']\n",
      "2: ['0.62']\n",
      "2: ['0.7856']\n",
      "2: ['0.7858']\n",
      "2: ['98']\n",
      "2: ['1.56']\n",
      "2: ['1.86']\n",
      "2: ['0.6237']\n",
      "2: ['1.5337']\n",
      "2: ['62.62']\n",
      "2: ['0.87']\n",
      "2: ['7.0']\n",
      "2: ['62.0']\n",
      "2: ['-2.82', '-2.82']\n",
      "2: ['85.0']\n",
      "2: ['60.0']\n",
      "2: ['62.0']\n",
      "2: ['0.78667']\n",
      "2: ['62.0', '.2', '.4', '.0', '.0', '.8', '0.1', '.1', '.0', '.1']\n",
      "2: ['0.46']\n",
      "2: ['62.8']\n",
      "2: ['53.1']\n",
      "2: ['42.0']\n",
      "2: ['0.6238']\n",
      "2: ['62.0']\n",
      "2: ['0.7854']\n",
      "2: ['62.0']\n",
      "2: ['62.0']\n",
      "2: ['62.0']\n",
      "2: ['0.62', '0.62']\n",
      "2: ['65.0']\n",
      "2: ['0.62']\n",
      "2: ['53.94']\n",
      "2: ['62.0']\n",
      "2: ['62.0', '62.0']\n",
      "2: ['0.7867']\n",
      "2: ['58.8']\n",
      "2: ['0.62']\n",
      "2: ['62.7']\n",
      "2: ['0.62']\n",
      "2: ['0.1398']\n",
      "2: ['0.7868']\n",
      "2: ['0.7869']\n",
      "2: ['56.0']\n",
      "2: ['1.7957']\n",
      "2: ['0.7867']\n",
      "2: ['58.1']\n",
      "2: ['0.7856']\n",
      "28.99374996338548\n",
      "3: ['62.58']\n",
      "3: ['0.62391']\n",
      "3: ['0.29678']\n",
      "3: ['1.78556']\n",
      "3: ['2.0']\n",
      "3: ['-0.0058']\n",
      "3: ['0.27']\n",
      "3: ['-1.25']\n",
      "3: ['0.52']\n",
      "3: ['0.62']\n",
      "3: ['0.56']\n",
      "3: ['0.54']\n",
      "3: ['0.28568']\n",
      "3: ['2.0']\n",
      "3: ['4.58858']\n",
      "3: ['2.67']\n",
      "3: ['7.0']\n",
      "3: ['-67.0']\n",
      "3: ['0.7']\n",
      "3: ['1.0']\n",
      "3: ['0.52']\n",
      "3: ['0.7']\n",
      "3: ['-0.139']\n",
      "3: ['0.23']\n",
      "3: ['9.3']\n",
      "3: ['-2.58']\n",
      "3: ['-1.96']\n",
      "3: ['0.523']\n",
      "3: ['2.1']\n",
      "3: ['2.0']\n",
      "3: ['-1.29']\n",
      "3: ['4.38']\n",
      "3: ['0.391']\n",
      "3: ['1.2867']\n",
      "3: ['0.062354241']\n",
      "3: ['7.0']\n",
      "3: ['59.3168']\n",
      "3: ['1.2844']\n",
      "3: ['-0.61', '-0.61']\n",
      "3: ['0.284']\n",
      "3: ['4.786', '4.786']\n",
      "3: ['0.68241']\n",
      "3: ['1.3857']\n",
      "3: ['-0.623']\n",
      "3: ['2.62']\n",
      "3: ['1.0']\n",
      "3: ['0.62']\n",
      "3: ['0.63']\n",
      "3: ['-1.45']\n",
      "3: ['0.7858']\n",
      "3: ['0.78591']\n",
      "5.368311406481169\n",
      "4: ['50.0']\n",
      "4: ['8.7']\n",
      "4: ['7.8']\n",
      "4: ['2.59']\n",
      "4: ['0']\n",
      "4: ['3.86']\n",
      "4: ['8.59']\n",
      "4: ['0.59']\n",
      "4: ['1.59']\n",
      "4: ['7.36', '7.36']\n",
      "4: ['7.38']\n",
      "4: ['8.36']\n",
      "4: ['0.186']\n",
      "4: ['7.59']\n",
      "4: ['0.1348']\n",
      "4: ['0.38591']\n",
      "4: ['8.3']\n",
      "4: ['0.98']\n",
      "4: ['0.98']\n",
      "4: ['4.38']\n",
      "4: ['34.95']\n",
      "4: ['0.78']\n",
      "4: ['-1.67']\n",
      "4: ['0.87']\n",
      "4: ['7.7']\n",
      "4: ['7.38']\n",
      "4: ['38.0']\n",
      "4: ['0.1867']\n",
      "4: ['0.7859']\n",
      "4: ['0.2848']\n",
      "4: ['6.0']\n",
      "4: ['4.58']\n",
      "4: ['0.7856']\n",
      "4: ['0.7957']\n",
      "4: ['-1.50865']\n",
      "4: ['7.50']\n",
      "4: ['2.58']\n",
      "4: ['1.03556']\n",
      "4: ['8.56']\n",
      "4: ['8.0']\n",
      "4: ['8.98']\n",
      "4: ['5']\n",
      "4: ['1.786']\n",
      "4: ['7.79']\n",
      "4: ['76']\n",
      "4: ['0.7908']\n",
      "4: ['0.0']\n",
      "4: ['1.1868']\n",
      "4: ['8.7']\n",
      "4: ['0.39']\n",
      "4: ['0.7869']\n",
      "7.353292080243394\n",
      "5: ['0']\n",
      "5: ['0.18599']\n",
      "5: ['0.786']\n",
      "5: ['0.7958']\n",
      "5: ['0.5948']\n",
      "5: ['1.0']\n",
      "5: ['0.59']\n",
      "5: ['0.786']\n",
      "5: ['-0.56']\n",
      "5: ['0.2968']\n",
      "5: ['0.62384']\n",
      "5: ['0.78618']\n",
      "5: ['7.58']\n",
      "5: ['-1.1397']\n",
      "5: ['1.1865']\n",
      "5: ['-0.58']\n",
      "5: ['9.38', '9']\n",
      "5: ['-0.76']\n",
      "5: ['-1.67', '-1.67']\n",
      "5: ['0.38']\n",
      "5: ['0']\n",
      "5: ['0.49256']\n",
      "5: ['0.1389']\n",
      "5: ['-1.0']\n",
      "5: ['0.58']\n",
      "5: ['0.49']\n",
      "5: ['0.38576']\n",
      "5: ['0.2847']\n",
      "5: ['0.0']\n",
      "5: ['8.1']\n",
      "5: ['0.1384']\n",
      "5: ['-1.96']\n",
      "5: ['7.0']\n",
      "5: ['-0.14262']\n",
      "5: ['0.78', '0.78']\n",
      "5: ['0.7']\n",
      "5: ['0.45']\n",
      "5: ['0.1389', '0.1389']\n",
      "5: ['0']\n",
      "5: ['0.8']\n",
      "5: ['0.38']\n",
      "5: ['-0.72']\n",
      "5: ['0']\n",
      "5: ['0.49262']\n",
      "5: ['-0.56']\n",
      "5: ['0.7858']\n",
      "5: ['0']\n",
      "5: ['0.67']\n",
      "5: ['-0.2847']\n",
      "5: ['6.0']\n",
      "5: ['-1.78667']\n",
      "1.3544819036207456\n",
      "6: ['-1.6239']\n",
      "6: ['0.60']\n",
      "6: ['1.62']\n",
      "6: ['62']\n",
      "6: ['2.3']\n",
      "6: ['-1.58871']\n",
      "6: ['-1.62']\n",
      "6: ['1.62']\n",
      "6: ['0.1862']\n",
      "6: ['0.7848']\n",
      "6: ['0.623']\n",
      "6: ['0.6437']\n",
      "6: ['2.2', '.62391']\n",
      "6: ['0.62']\n",
      "6: ['0.7']\n",
      "6: ['3.5426']\n",
      "6: ['1.62379']\n",
      "6: ['1.65']\n",
      "6: ['1.2']\n",
      "6: ['0.13956']\n",
      "6: ['1.1392']\n",
      "6: ['3']\n",
      "6: ['0.6244']\n",
      "6: ['1.64']\n",
      "6: ['-0.544']\n",
      "6: ['0.62']\n",
      "6: ['-23']\n",
      "6: ['0.67']\n",
      "6: ['0.62']\n",
      "6: ['3.8']\n",
      "6: ['0.6239']\n",
      "6: ['-0.5887']\n",
      "6: ['1.59']\n",
      "6: ['-1.54']\n",
      "6: ['-0.62']\n",
      "6: ['0.62062']\n",
      "6: ['1.78562']\n",
      "6: ['2.3']\n",
      "6: ['1.62']\n",
      "6: ['0.623']\n",
      "6: ['-1.62', '-1.62']\n",
      "6: ['0.6238']\n",
      "6: ['1.6233']\n",
      "6: ['7.6239']\n",
      "6: ['0.62']\n",
      "6: ['-14256.0']\n",
      "6: ['1.58', '1.58']\n",
      "6: ['1.6']\n",
      "6: ['1.63']\n",
      "6: ['-0.62']\n",
      "6: ['1.59']\n",
      "3.0528532363837444\n",
      "7: ['2.6']\n",
      "7: ['0.289', '0.289']\n",
      "7: ['8.0']\n",
      "7: ['0']\n",
      "7: ['2.58']\n",
      "7: ['0.2967']\n",
      "7: ['2.8']\n",
      "7: ['0.49294']\n",
      "7: ['0.0']\n",
      "7: ['0.58']\n",
      "7: ['2.0']\n",
      "7: ['0.62']\n",
      "7: ['0.1987']\n",
      "7: ['0.91']\n",
      "7: ['2.1867']\n",
      "7: ['0.1898', '0.1898']\n",
      "7: ['1.1']\n",
      "7: ['2.5']\n",
      "7: ['98.1903']\n",
      "7: ['1.3']\n",
      "7: ['1.38']\n",
      "7: ['0.7']\n",
      "7: ['8.0702']\n",
      "7: ['2.58']\n",
      "7: ['0.79598']\n",
      "7: ['0.1399']\n",
      "7: ['0.2']\n",
      "7: ['0.62']\n",
      "7: ['2.0']\n",
      "7: ['0.38']\n",
      "7: ['1.1868']\n",
      "7: ['0.82', '0.82']\n",
      "7: ['98.1857']\n",
      "7: ['1.92']\n",
      "7: ['0.68']\n",
      "7: ['0.98']\n",
      "7: ['0.7857']\n",
      "7: ['0.1421']\n",
      "7: ['0']\n",
      "7: ['0.62']\n",
      "7: ['0.53']\n",
      "7: ['0.6']\n",
      "7: ['-58.0']\n",
      "7: ['0.78876']\n",
      "7: ['2.0']\n",
      "7: ['1.92']\n",
      "7: ['0.58']\n",
      "7: ['0.54']\n",
      "7: ['2.1']\n",
      "7: ['0.62']\n",
      "7: ['0.1918']\n",
      "6.21367900679507\n",
      "8: ['0.62358']\n",
      "8: ['0.65']\n",
      "8: ['0']\n",
      "8: ['0.7858']\n",
      "8: ['4.4860']\n",
      "8: ['0.62']\n",
      "8: []\n",
      "8: ['0.6']\n",
      "8: ['-1.68298']\n",
      "8: ['0.59']\n",
      "8: ['0.0']\n",
      "8: ['0.4868']\n",
      "8: ['0.7868', '.58']\n",
      "8: ['0']\n",
      "8: ['0.35']\n",
      "8: ['0.58138']\n",
      "8: ['0.5838']\n",
      "8: ['0.0']\n",
      "8: ['45.0']\n",
      "8: ['0.0']\n",
      "8: ['1.8']\n",
      "8: ['0.5429']\n",
      "8: ['0.48662']\n",
      "8: ['0.5888']\n",
      "8: ['0.5889']\n",
      "8: ['0.45']\n",
      "8: ['-9.0']\n",
      "8: ['6.5']\n",
      "8: []\n",
      "8: ['0.78']\n",
      "8: ['0.56']\n",
      "8: ['0.0']\n",
      "8: ['0.78582']\n",
      "8: ['0.58']\n",
      "8: ['0.28458', '0.28458']\n",
      "8: ['0.4927']\n",
      "8: ['7.0']\n",
      "8: ['0.4857']\n",
      "8: ['0.62']\n",
      "8: ['0.682']\n",
      "8: ['0.1', '.62', '0.162', '1.34558', '1.34558', '2']\n",
      "8: ['0.78659']\n",
      "8: ['7.0']\n",
      "8: ['0']\n",
      "8: ['0.5888']\n",
      "8: ['0.7864']\n",
      "8: ['0']\n",
      "8: ['0.2846662']\n",
      "8: ['0.8']\n",
      "8: ['0.54278']\n",
      "8: ['1.49698']\n",
      "2.11823073652784\n",
      "9: ['0.98']\n",
      "9: ['8.38']\n",
      "9: ['0.0']\n",
      "9: ['0.52']\n",
      "9: ['0.55', '0.55']\n",
      "9: ['7.0']\n",
      "9: ['-1.59']\n",
      "9: ['0.5421']\n",
      "9: ['0.91']\n",
      "9: ['0.98']\n",
      "9: ['8.0']\n",
      "9: ['0.58']\n",
      "9: ['0.0']\n",
      "9: ['0.2843']\n",
      "9: ['62.0']\n",
      "9: ['0.62']\n",
      "9: ['0.78694']\n",
      "9: ['0.95']\n",
      "9: ['7.94']\n",
      "9: ['8.0']\n",
      "9: ['58.0']\n",
      "9: ['8.0']\n",
      "9: ['1.0']\n",
      "9: ['0.623']\n",
      "9: ['0.786']\n",
      "9: ['0.85']\n",
      "9: ['2.5334']\n",
      "9: ['60.0']\n",
      "9: ['94.0']\n",
      "9: ['0.7', '0.58', '0.8', '0.54', '0.1', '0.59', '0.38', '0.1']\n",
      "9: ['7.77']\n",
      "9: ['1.0']\n",
      "9: ['95.0']\n",
      "9: ['0.94']\n",
      "9: ['42.9']\n",
      "9: ['0.62']\n",
      "9: ['0.533']\n",
      "9: ['0.60']\n",
      "9: ['7.0']\n",
      "9: ['0.7']\n",
      "9: ['0.58']\n",
      "9: ['-54231.8']\n",
      "9: ['0.95']\n",
      "9: ['9.0']\n",
      "9: ['7.7867']\n",
      "9: ['7.7866']\n",
      "9: ['0.58']\n",
      "9: ['54.5888']\n",
      "9: ['0.95']\n",
      "9: ['0.786']\n",
      "9: ['0.86']\n",
      "11.555621432078452\n",
      "10: ['0.56']\n",
      "10: ['6.7']\n",
      "10: ['67.0']\n",
      "10: ['7.0']\n",
      "10: ['7.0']\n",
      "10: ['7.0']\n",
      "10: ['7.0']\n",
      "10: ['0.7']\n",
      "10: ['7.0']\n",
      "10: ['-0.83']\n",
      "10: ['0.5887']\n",
      "10: ['67.0']\n",
      "10: ['9.0']\n",
      "10: ['58.0']\n",
      "10: ['6.0']\n",
      "10: ['7.0']\n",
      "10: ['58.0']\n",
      "10: ['-1.62']\n",
      "10: ['-1.78558']\n",
      "10: ['59.0']\n",
      "10: ['7.20399']\n",
      "10: ['6.0']\n",
      "10: ['98.0']\n",
      "10: ['0.58']\n",
      "10: ['58.0']\n",
      "10: ['7.0']\n",
      "10: ['6.98']\n",
      "10: []\n",
      "10: ['0.5778']\n",
      "10: ['0.59']\n",
      "10: ['60.0']\n",
      "10: ['-58.0']\n",
      "10: ['0.58']\n",
      "10: ['7.0']\n",
      "10: ['0.58']\n",
      "10: ['59.0']\n",
      "10: ['7.0']\n",
      "10: ['8.76']\n",
      "10: ['62.0']\n",
      "10: ['3.0']\n",
      "10: ['60.0']\n",
      "10: ['58.0']\n",
      "10: ['0.78']\n",
      "10: ['7.0']\n",
      "10: ['0.56']\n",
      "10: ['6.62']\n",
      "10: ['-1.0']\n",
      "10: ['7.0']\n",
      "10: ['-0.62']\n",
      "10: ['58.0']\n",
      "10: ['62.0']\n",
      "21.82525979103925\n",
      "9.071 \\pm 8.793\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "from src.utils import remove_quotes,remove_quotes_in_answer,extract_yes_no\n",
    "\n",
    "import numpy as np\n",
    "import json\n",
    "import re\n",
    "\n",
    "prefix = 'graph'\n",
    "llm = 'llama'\n",
    "result_path = 'result'\n",
    "\n",
    "pattern = r'V\\d+'\n",
    "pattern2 = r'\\d+%'\n",
    "\n",
    "def mae(gt,pred):\n",
    "    gt = np.array(gt) \n",
    "    pred = np.array(pred)\n",
    "    gt = gt[~np.isnan(pred)]\n",
    "    pred = pred[~np.isnan(pred)]\n",
    "    gt = gt[np.abs(pred)<100]\n",
    "    pred  = pred[np.abs(pred)<100]\n",
    "\n",
    "    return np.mean(np.abs(gt - pred))\n",
    "eva_ls = []\n",
    "\n",
    "\n",
    "for sim_id in range(1,11):\n",
    "    with open(cwd+f'/data/table/intervention_{sim_id}_gt.txt', 'r') as file:    \n",
    "        anw_gt = file.readlines()\n",
    "    anw_gt = [float(a.replace('\\n', '')) for a in anw_gt]\n",
    "    answers = []\n",
    "    with open(cwd+f'/result/{llm}/table_intv_response_lu{sim_id}.txt', 'r') as file:    \n",
    "        json_data_ls = file.readlines()\n",
    "\n",
    "    # Parse the JSON data from the string\n",
    "    for js_data in json_data_ls:\n",
    "        js_data = remove_quotes(js_data)\n",
    "        js_data = js_data.replace(\"\\\\\", \"\")\n",
    "        data = json.loads(js_data)\n",
    "        \n",
    "        # Remove all matches from the text\n",
    "        modified_text = re.sub(pattern, '', data['answer'])\n",
    "        modified_text = re.sub(pattern2, '', modified_text)\n",
    "        numbers  = re.findall(r\"[-+]?(?:\\d*\\.*\\d+)\",modified_text)\n",
    "        \n",
    "        print(f'{sim_id}: {numbers}')\n",
    "\n",
    "        if len(numbers) == 0:\n",
    "            numbers = np.nan\n",
    "        elif len(numbers) == 1:\n",
    "            numbers = float(numbers[0])\n",
    "        else: \n",
    "            numbers_ls = []\n",
    "            for i in numbers:\n",
    "                numbers_ls.append(float(i))\n",
    "            numbers = np.mean(np.array(numbers_ls))\n",
    "        \n",
    "        \n",
    "        answers.append(numbers)\n",
    "    print(mae(anw_gt,answers))\n",
    "    eva_ls.append(mae(anw_gt,answers))\n",
    "# eva_ls\n",
    "print(f'{np.mean(eva_ls):.3f} \\pm {np.std(eva_ls):.3f}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation of counterfactual inference resutls\n",
    "* 10 causal graph 51 nodes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\"question\":\"0.2434937746037162\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.78476.\"}\n",
      "1: ['0.78476']\n",
      "{\"question\":\"-0.7991788375513162\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.2957.\"}\n",
      "1: ['0.2957']\n",
      "{\"question\":\"-0.5660213006565025\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-1.4867\"}\n",
      "1: ['-1.4867']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.28486.\"}\n",
      "1: ['-1.28486']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.5887.\"}\n",
      "1: ['0.5887']\n",
      "{\"question\":\"0.8274120601682686\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 54.78598\"}\n",
      "1: ['54.78598']\n",
      "{\"question\":\"0.8744077999384204\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-59.0\"}\n",
      "1: ['-59.0']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.7858.\"}\n",
      "1: ['0.7858']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:3.5427\"}\n",
      "1: ['3.5427']\n",
      "{\"question\":\"0.3124048954591789\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.7959So, the final answer is 0.7959.\"}\n",
      "1: ['0.7959', '0.7959']\n",
      "{\"question\":\"1.6814124953844922\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 7.53.\"}\n",
      "1: ['7.53']\n",
      "{\"question\":\"-1.7169546738843338\", \"answer\": \"The final answer is -1.5867.\"}\n",
      "1: ['-1.5867']\n",
      "{\"question\":\"0.7229008186417164\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-0.4So, the final answer is -0.4.\"}\n",
      "1: ['-0.4', '-0.4']\n",
      "{\"question\":\"1.3211764710699363\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.7858\"}\n",
      "1: ['0.7858']\n",
      "{\"question\":\"-0.8478432996929206\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 7.59.Let me know if you'd like me to clarify anything!\"}\n",
      "1: ['7.59']\n",
      "{\"question\":\"1.0981623464466304\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 8.\"}\n",
      "1: ['8']\n",
      "{\"question\":\"-0.0001390716147761\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.78894, where 0.78894 is a float number.\"}\n",
      "1: ['0.78894', '0.78894']\n",
      "{\"question\":\"-0.7317845268858741\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.78593\"}\n",
      "1: ['0.78593']\n",
      "{\"question\":\"0.2232266044707819\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.53123\"}\n",
      "1: ['0.53123']\n",
      "{\"question\":\"-0.0001390716147761\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.84.\"}\n",
      "1: ['0.84']\n",
      "{\"question\":\"-0.0418209882634785\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.84.\"}\n",
      "1: ['-1.84']\n",
      "{\"question\":\"-0.6602149211611081\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.13872\"}\n",
      "1: ['0.13872']\n",
      "{\"question\":\"0.2232266044707819\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.94\"}\n",
      "1: ['0.94']\n",
      "{\"question\":\"-1.1118095861705362\", \"answer\": \"The final answer is -38.\"}\n",
      "1: ['-38']\n",
      "{\"question\":\"-10.688965496647398\", \"answer\": \"The final answer is 3.53.\"}\n",
      "1: ['3.53']\n",
      "{\"question\":\"0.7229008186417164\", \"answer\": \"The final answer is 0.95.\"}\n",
      "1: ['0.95']\n",
      "{\"question\":\"1.468695506789686\", \"answer\": \"The final answer is 2.68.\"}\n",
      "1: ['2.68']\n",
      "{\"question\":\"0.2232266044707819\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -0.287,\"}\n",
      "1: ['-0.287']\n",
      "{\"question\":\"-0.5660213006565025\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.2864\"}\n",
      "1: ['0.2864']\n",
      "{\"question\":\"1.4595121387005476\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 1.58\"}\n",
      "1: ['1.58']\n",
      "{\"question\":\"1.0722895554686405\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.785, where 1.785 is the result as a float number.\"}\n",
      "1: ['1.785', '1.785']\n",
      "{\"question\":\"0.7229008186417164\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:0.29673So, the final answer is 0.29673.\"}\n",
      "1: ['0.29673', '0.29673']\n",
      "{\"question\":\"0.3378468826296261\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.59.\"}\n",
      "1: ['0.59']\n",
      "{\"question\":\"-1.1118095861705362\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.56\"}\n",
      "1: ['-1.56']\n",
      "{\"question\":\"-1.7169546738843338\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 7.68.\"}\n",
      "1: ['7.68']\n",
      "{\"question\":\"-1.1118095861705362\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.45.Please note that the response contains a lot of irrelevant information and the actual answer is buried within it.\"}\n",
      "1: ['0.45']\n",
      "{\"question\":\"0.3378468826296261\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.78471\"}\n",
      "1: ['0.78471']\n",
      "{\"question\":\"-0.7317845268858741\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.2877\"}\n",
      "1: ['0.2877']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I got:The final answer is 0.55.\"}\n",
      "1: ['0.55']\n",
      "{\"question\":\"-1.3113582856223\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.53\"}\n",
      "1: ['0.53']\n",
      "{\"question\":\"0.8283409596307294\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:**0.95**Let me know if you need further assistance!\"}\n",
      "1: ['0.95']\n",
      "{\"question\":\"0.1302855390642746\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.52.\"}\n",
      "1: ['2.52']\n",
      "{\"question\":\"-0.8478432996929206\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -1.56\"}\n",
      "1: ['-1.56']\n",
      "{\"question\":\"-0.5056394894167549\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.7857\"}\n",
      "1: ['0.7857']\n",
      "{\"question\":\"1.0629419929070845\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.785, where 0.785 is the result as a float number.\"}\n",
      "1: ['0.785', '0.785']\n",
      "{\"question\":\"-1.3113582856223\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.78656.\"}\n",
      "1: ['1.78656']\n",
      "{\"question\":\"-0.2992603342754523\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.78684.\"}\n",
      "1: ['-1.78684']\n",
      "{\"question\":\"0.752419299328727\", \"answer\": \"The final answer is 0.56.\"}\n",
      "1: ['0.56']\n",
      "{\"question\":\"-1.3113582856223\", \"answer\": \"The final answer is 1.62.\"}\n",
      "1: ['1.62']\n",
      "{\"question\":\"0.2434937746037162\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-1.78658\"}\n",
      "1: ['-1.78658']\n",
      "{\"question\":\"0.3580638631514523\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.786,\"}\n",
      "1: ['0.786']\n",
      "4.693396997890633\n",
      "{\"question\":\"-1.4090580272767146\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -1.78658\"}\n",
      "2: ['-1.78658']\n",
      "{\"question\":\"3.3348561158814434\", \"answer\": \"The final answer is 53.56.\"}\n",
      "2: ['53.56']\n",
      "{\"question\":\"1.611741700885883\", \"answer\": \"The final answer is 0.54.\"}\n",
      "2: ['0.54']\n",
      "{\"question\":\"0.5870677545058572\", \"answer\": \"The final answer is 56.1.\"}\n",
      "2: ['56.1']\n",
      "{\"question\":\"0.0191920986907582\", \"answer\": \"The final answer is 59.62.\"}\n",
      "2: ['59.62']\n",
      "{\"question\":\"-1.0410421463934143\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 1.53391\"}\n",
      "2: ['1.53391']\n",
      "{\"question\":\"0.0295888794239441\", \"answer\": \"After extracting the final answer from the response, I found the result to be:The final answer is -1.08876.\"}\n",
      "2: ['-1.08876']\n",
      "{\"question\":\"0.8430234908659295\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -0.062,\"}\n",
      "2: ['-0.062']\n",
      "{\"question\":\"-0.8094796621780206\", \"answer\": \"The final answer is 0.2.\"}\n",
      "2: ['0.2']\n",
      "{\"question\":\"1.6684360632573565\", \"answer\": \"The final answer is 52.2.\"}\n",
      "2: ['52.2']\n",
      "{\"question\":\"-1.4277820689967111\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-1.139\"}\n",
      "2: ['-1.139']\n",
      "{\"question\":\"1.1272656539686308\", \"answer\": \"After extracting the final answer from the response, I found the result to be:The final answer is 0.587\"}\n",
      "2: ['0.587']\n",
      "{\"question\":\"-1.935078461542441\", \"answer\": \"After extracting the relevant information from the response, I found that the final answer is:The final answer is 1.1868\"}\n",
      "2: ['1.1868']\n",
      "{\"question\":\"-1.341591394272736\", \"answer\": \"The final answer is 8.0.\"}\n",
      "2: ['8.0']\n",
      "{\"question\":\"-1.6158676661549225\", \"answer\": \"The final answer is 0.54.\"}\n",
      "2: ['0.54']\n",
      "{\"question\":\"-1.1511908896340424\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -4.394,\"}\n",
      "2: ['-4.394']\n",
      "{\"question\":\"-0.0248727303489236\", \"answer\": \"The final answer is 7.58.\"}\n",
      "2: ['7.58']\n",
      "{\"question\":\"0.5870677545058572\", \"answer\": \"The final answer is 6.58.\"}\n",
      "2: ['6.58']\n",
      "{\"question\":\"-1.583266197560484\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 7.58\"}\n",
      "2: ['7.58']\n",
      "{\"question\":\"-2.0047745994310335\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.7865,\"}\n",
      "2: ['-1.7865']\n",
      "{\"question\":\"0.5584946977080701\", \"answer\": \"The final answer is 52.8.\"}\n",
      "2: ['52.8']\n",
      "{\"question\":\"-1.5392699000466867\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.0\"}\n",
      "2: ['-1.0']\n",
      "{\"question\":\"-0.9752481146405552\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 58.6\"}\n",
      "2: ['58.6']\n",
      "{\"question\":\"1.6684360632573565\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 58.7\"}\n",
      "2: ['58.7']\n",
      "{\"question\":\"0.5415831360150873\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -0.29698,\"}\n",
      "2: ['-0.29698']\n",
      "{\"question\":\"-1.6455019405044529\", \"answer\": \"The final answer is 56.\"}\n",
      "2: ['56']\n",
      "{\"question\":\"0.5870677545058572\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.63.\"}\n",
      "2: ['0.63']\n",
      "{\"question\":\"-1.6392255827928324\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 8.4.\"}\n",
      "2: ['8.4']\n",
      "{\"question\":\"-1.6158676661549225\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.5887, where 0.5887 is the result as a float number.\"}\n",
      "2: ['0.5887', '0.5887']\n",
      "{\"question\":\"-0.0248727303489236\", \"answer\": \"The final answer is 62.5.\"}\n",
      "2: ['62.5']\n",
      "{\"question\":\"0.7276223818351931\", \"answer\": \"After extracting the final answer from the response, I found the result to be:The final answer is 0.5887\"}\n",
      "2: ['0.5887']\n",
      "{\"question\":\"0.7276223818351931\", \"answer\": \"The final answer is 0.5429.\"}\n",
      "2: ['0.5429']\n",
      "{\"question\":\"-1.549939056830217\", \"answer\": \"After extracting the final answer from the response, I found the result to be:The final answer is 58.0\"}\n",
      "2: ['58.0']\n",
      "{\"question\":\"-1.341591394272736\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 62.5\"}\n",
      "2: ['62.5']\n",
      "{\"question\":\"0.3011120103226821\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 53.1\"}\n",
      "2: ['53.1']\n",
      "{\"question\":\"-1.4090580272767146\", \"answer\": \"The final answer is 5.5.\"}\n",
      "2: ['5.5']\n",
      "{\"question\":\"-1.6392255827928324\", \"answer\": \"The final answer is 58.0.\"}\n",
      "2: ['58.0']\n",
      "{\"question\":\"1.611741700885883\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.\"}\n",
      "2: ['0']\n",
      "{\"question\":\"-1.583266197560484\", \"answer\": \"The final answer is 0.5427.\"}\n",
      "2: ['0.5427']\n",
      "{\"question\":\"-1.549939056830217\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:1.54256\"}\n",
      "2: ['1.54256']\n",
      "{\"question\":\"-1.4429531192714533\", \"answer\": \"The final answer is 53.2.\"}\n",
      "2: ['53.2']\n",
      "{\"question\":\"-1.6392255827928324\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.6239.Note: The response contains a lot of numbers, but the final answer is the one that is explicitly stated as the result.\"}\n",
      "2: ['0.6239']\n",
      "{\"question\":\"-1.5392699000466867\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 62.8\"}\n",
      "2: ['62.8']\n",
      "{\"question\":\"-1.341591394272736\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1386.\"}\n",
      "2: ['0.1386']\n",
      "{\"question\":\"0.5584946977080701\", \"answer\": \"The final answer is 62.4.\"}\n",
      "2: ['62.4']\n",
      "{\"question\":\"0.8430234908659295\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.7858.\"}\n",
      "2: ['0.7858']\n",
      "{\"question\":\"1.1272656539686308\", \"answer\": \"The final answer is 0.5426.\"}\n",
      "2: ['0.5426']\n",
      "{\"question\":\"1.611741700885883\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.5428\"}\n",
      "2: ['0.5428']\n",
      "{\"question\":\"1.611741700885883\", \"answer\": \"The final answer is 4.50.\"}\n",
      "2: ['4.50']\n",
      "{\"question\":\"1.6399139890929428\", \"answer\": \"After processing the response, the final answer is:The final answer is 0.55.\"}\n",
      "2: ['0.55']\n",
      "{\"question\":\"1.1272656539686308\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.7907\"}\n",
      "2: ['0.7907']\n",
      "19.760126948228855\n",
      "{\"question\":\"0.6322036559874488\", \"answer\": \"The final answer is 36.3.\"}\n",
      "3: ['36.3']\n",
      "{\"question\":\"0.5046284127556312\", \"answer\": \"The final answer is 0.53691.\"}\n",
      "3: ['0.53691']\n",
      "{\"question\":\"0.6807106036909798\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.542.\"}\n",
      "3: ['2.542']\n",
      "{\"question\":\"0.7480834839937683\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 53.0\"}\n",
      "3: ['53.0']\n",
      "{\"question\":\"1.2535034348076066\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 56.7\"}\n",
      "3: ['56.7']\n",
      "{\"question\":\"0.7737624523474982\", \"answer\": \"The final answer is 38.0.\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"-1.5581788705801054\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.532\"}\n",
      "3: ['0.532']\n",
      "{\"question\":\"-1.5895289226300966\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.5429\"}\n",
      "3: ['-1.5429']\n",
      "{\"question\":\"-1.2940909365442002\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -1.7869\"}\n",
      "3: ['-1.7869']\n",
      "{\"question\":\"-0.279405567240842\", \"answer\": \"The final answer is 0.53392.\"}\n",
      "3: ['0.53392']\n",
      "{\"question\":\"1.567438052075711\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is 7.0.\"}\n",
      "3: ['7.0']\n",
      "{\"question\":\"0.0923079146962463\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.54291.\"}\n",
      "3: ['0.54291']\n",
      "{\"question\":\"1.567438052075711\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.36, where -1.36 is the result as a float number.\"}\n",
      "3: ['-1.36', '-1.36']\n",
      "{\"question\":\"0.2455255413746068\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 36.8.\"}\n",
      "3: ['36.8']\n",
      "{\"question\":\"-2.3469308378735567\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 28.7\"}\n",
      "3: ['28.7']\n",
      "{\"question\":\"1.2800620909100455\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 38.0.\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"1.1618539871148506\", \"answer\": \"The final answer is 2.56.\"}\n",
      "3: ['2.56']\n",
      "{\"question\":\"0.7480834839937683\", \"answer\": \"The final answer is 29.2.\"}\n",
      "3: ['29.2']\n",
      "{\"question\":\"0.5476500370609919\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 52.4\"}\n",
      "3: ['52.4']\n",
      "{\"question\":\"0.9417638141030544\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 32.4\"}\n",
      "3: ['32.4']\n",
      "{\"question\":\"-0.4756509551321173\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.78656\"}\n",
      "3: ['0.78656']\n",
      "{\"question\":\"0.5046284127556312\", \"answer\": \"The final answer is 10.956.\"}\n",
      "3: ['10.956']\n",
      "{\"question\":\"0.2224510404644881\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.58893.\"}\n",
      "3: ['1.58893']\n",
      "{\"question\":\"-0.279405567240842\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 36.0\"}\n",
      "3: ['36.0']\n",
      "{\"question\":\"-0.4870060996165827\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 56.0\"}\n",
      "3: ['56.0']\n",
      "{\"question\":\"-0.0726508096235373\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 38.0\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"0.7480834839937683\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -58.0\"}\n",
      "3: ['-58.0']\n",
      "{\"question\":\"-0.7178278552149805\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -0.38.\"}\n",
      "3: ['-0.38']\n",
      "{\"question\":\"0.3630453823425421\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 59.7\"}\n",
      "3: ['59.7']\n",
      "{\"question\":\"1.1618539871148506\", \"answer\": \"The final answer is 38.6.\"}\n",
      "3: ['38.6']\n",
      "{\"question\":\"0.2345872751745381\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.01.\"}\n",
      "3: ['2.01']\n",
      "{\"question\":\"0.2345872751745381\", \"answer\": \"The final answer is 56.\"}\n",
      "3: ['56']\n",
      "{\"question\":\"-0.493171587202898\", \"answer\": \"The final answer is 7.0.\"}\n",
      "3: ['7.0']\n",
      "{\"question\":\"0.2455255413746068\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.786\"}\n",
      "3: ['0.786']\n",
      "{\"question\":\"-0.8600711660848107\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 38.0\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"0.3262859405664873\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 38.0\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"-0.7178278552149805\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 29.1.53662 Converted to a float number:The final answer is 29.153662\"}\n",
      "3: ['29.1', '.53662', '29.153662']\n",
      "{\"question\":\"0.6807106036909798\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 38.0\"}\n",
      "3: ['38.0']\n",
      "{\"question\":\"0.5476500370609919\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.65.\"}\n",
      "3: ['0.65']\n",
      "{\"question\":\"-0.493171587202898\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.7Please let me know if you'd like me to clarify anything!\"}\n",
      "3: ['0.7']\n",
      "{\"question\":\"-1.0027325406669827\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.56.\"}\n",
      "3: ['0.56']\n",
      "{\"question\":\"-0.7178278552149805\", \"answer\": \"After extracting the final answer from the response, I found the following:0.2.56 -> 0.2560.1.36 -> 0.1360.4 -> 0.4The final answer is \"}\n",
      "3: ['0.2', '.56', '0.2560', '.1', '.36', '0.1360', '.4', '0.4']\n",
      "{\"question\":\"0.5046284127556312\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.0.Please let me know if this is correct or if I made a mistake!\"}\n",
      "3: ['-1.0']\n",
      "{\"question\":\"0.2455255413746068\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 58.8\"}\n",
      "3: ['58.8']\n",
      "{\"question\":\"-0.4756509551321173\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.34276\"}\n",
      "3: ['0.34276']\n",
      "{\"question\":\"-1.5895289226300966\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 38.3\"}\n",
      "3: ['38.3']\n",
      "{\"question\":\"0.0923079146962463\", \"answer\": \"The final answer is 7.588.\"}\n",
      "3: ['7.588']\n",
      "{\"question\":\"0.6807106036909798\", \"answer\": \"The final answer is 7.1398.\"}\n",
      "3: ['7.1398']\n",
      "{\"question\":\"0.6807106036909798\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -1.54293.\"}\n",
      "3: ['-1.54293']\n",
      "{\"question\":\"-0.4357684988495803\", \"answer\": \"The final answer is 0.53658.\"}\n",
      "3: ['0.53658']\n",
      "{\"question\":\"0.0923079146962463\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 7.38.\"}\n",
      "3: ['7.38']\n",
      "20.408370829429423\n",
      "{\"question\":\"1.6677719411487362\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.62.\"}\n",
      "4: ['0.62']\n",
      "{\"question\":\"1.074735300907197\", \"answer\": \"The final answer is 0.1428.\"}\n",
      "4: ['0.1428']\n",
      "{\"question\":\"-1.865614032346318\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1244.\"}\n",
      "4: ['0.1244']\n",
      "{\"question\":\"-0.0414525276268811\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.59.\"}\n",
      "4: ['0.59']\n",
      "{\"question\":\"-0.0359266784368379\", \"answer\": \"The final answer is 0.31.\"}\n",
      "4: ['0.31']\n",
      "{\"question\":\"1.3304117242444835\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.78.\"}\n",
      "4: ['0.78']\n",
      "{\"question\":\"-2.3362964337010426\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.7\"}\n",
      "4: ['0.7']\n",
      "{\"question\":\"-2.2995728476378243\", \"answer\": \"The final answer is 0.435.\"}\n",
      "4: ['0.435']\n",
      "{\"question\":\"4.2547308903085135\", \"answer\": \"The final answer is 0.62.\"}\n",
      "4: ['0.62']\n",
      "{\"question\":\"-2.005820402698036\", \"answer\": \"The final answer is 0.\"}\n",
      "4: ['0']\n",
      "{\"question\":\"0.5592634323362096\", \"answer\": \"The final answer is 0.62.\"}\n",
      "4: ['0.62']\n",
      "{\"question\":\"4.270596649442901\", \"answer\": \"The final answer is 0.\"}\n",
      "4: ['0']\n",
      "{\"question\":\"0.6416304835127381\", \"answer\": \"The final answer is 0.13.\"}\n",
      "4: ['0.13']\n",
      "{\"question\":\"0.5720983151876146\", \"answer\": \"The final answer is 1.34.\"}\n",
      "4: ['1.34']\n",
      "{\"question\":\"-1.3754832885509436\", \"answer\": \"The final answer is 1.35.\"}\n",
      "4: ['1.35']\n",
      "{\"question\":\"1.2887039295459342\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:2.333\"}\n",
      "4: ['2.333']\n",
      "{\"question\":\"-1.4558416220375303\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.42.\"}\n",
      "4: ['0.42']\n",
      "{\"question\":\"0.0553255616924953\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.523\"}\n",
      "4: ['0.523']\n",
      "{\"question\":\"0.19650459819778787\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.36.\"}\n",
      "4: ['0.36']\n",
      "{\"question\":\"-1.3118423829963064\", \"answer\": \"The final answer is 0.42.\"}\n",
      "4: ['0.42']\n",
      "{\"question\":\"-0.4835044354180833\", \"answer\": \"The final answer is 1.36.\"}\n",
      "4: ['1.36']\n",
      "{\"question\":\"-1.5376241774066883\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.98\"}\n",
      "4: ['0.98']\n",
      "{\"question\":\"1.292765778195607\", \"answer\": \"The final answer is 1.54.\"}\n",
      "4: ['1.54']\n",
      "{\"question\":\"-1.805626847153201\", \"answer\": \"The final answer is 0.1.\"}\n",
      "4: ['0.1']\n",
      "{\"question\":\"0.5720983151876146\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.2849.\"}\n",
      "4: ['0.2849']\n",
      "{\"question\":\"-0.386293168970109\", \"answer\": \"The final answer is 0.1389.\"}\n",
      "4: ['0.1389']\n",
      "{\"question\":\"-2.2995728476378243\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.2848\"}\n",
      "4: ['0.2848']\n",
      "{\"question\":\"1.5139615250079326\", \"answer\": \"The final answer is 0.92.\"}\n",
      "4: ['0.92']\n",
      "{\"question\":\"-2.2995728476378243\", \"answer\": \"The final answer is 0.53.\"}\n",
      "4: ['0.53']\n",
      "{\"question\":\"0.19650459819778787\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.8.\"}\n",
      "4: ['0.8']\n",
      "{\"question\":\"1.6677719411487362\", \"answer\": \"After extracting the final answer from the response, I found the following result:The final answer is 0.296\"}\n",
      "4: ['0.296']\n",
      "{\"question\":\"-1.865614032346318\", \"answer\": \"The final answer is 0.111428.\"}\n",
      "4: ['0.111428']\n",
      "{\"question\":\"1.3304117242444835\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.53\"}\n",
      "4: ['1.53']\n",
      "{\"question\":\"-1.3118423829963064\", \"answer\": \"The final answer is 2.36.\"}\n",
      "4: ['2.36']\n",
      "{\"question\":\"1.4435563303211574\", \"answer\": \"The final answer is 1.58.\"}\n",
      "4: ['1.58']\n",
      "{\"question\":\"-1.5376241774066883\", \"answer\": \"The final answer is 1.71.\"}\n",
      "4: ['1.71']\n",
      "{\"question\":\"-2.3362964337010426\", \"answer\": \"The final answer is 1.1.7.1427.2.\"}\n",
      "4: ['1.1', '.7', '.1427', '.2']\n",
      "{\"question\":\"-0.1895611974104199\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 1.53\"}\n",
      "4: ['1.53']\n",
      "{\"question\":\"0.5592634323362096\", \"answer\": \"The final answer is 1.134862,\"}\n",
      "4: ['1.134862']\n",
      "{\"question\":\"-0.386293168970109\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 7.28.\"}\n",
      "4: ['7.28']\n",
      "{\"question\":\"1.1744078572669132\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1397.\"}\n",
      "4: ['0.1397']\n",
      "{\"question\":\"0.22469586159626487\", \"answer\": \"The final answer is 0.38.\"}\n",
      "4: ['0.38']\n",
      "{\"question\":\"-0.400329955266626\", \"answer\": \"The final answer is 0.6238.\"}\n",
      "4: ['0.6238']\n",
      "{\"question\":\"1.0435960744028383\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 1.54\"}\n",
      "4: ['1.54']\n",
      "{\"question\":\"-2.3362964337010426\", \"answer\": \"The final answer is 1.53.\"}\n",
      "4: ['1.53']\n",
      "{\"question\":\"-1.4548989886452062\", \"answer\": \"The final answer is 1.67.\"}\n",
      "4: ['1.67']\n",
      "{\"question\":\"-0.8016588778427575\", \"answer\": \"The final answer is 0.53.\"}\n",
      "4: ['0.53']\n",
      "{\"question\":\"-1.4548989886452062\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is -98.0\"}\n",
      "4: ['-98.0']\n",
      "{\"question\":\"1.3304117242444835\", \"answer\": \"The final answer is 0.54.\"}\n",
      "4: ['0.54']\n",
      "{\"question\":\"0.2875537017263836\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.38\"}\n",
      "4: ['0.38']\n",
      "{\"question\":\"-1.3118423829963064\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.2899.\"}\n",
      "4: ['0.2899']\n",
      "3.4895500705359326\n",
      "{\"question\":\"1.9160105302900543\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.1398So, the final answer is 0.1398.\"}\n",
      "5: ['0.1398', '0.1398']\n",
      "{\"question\":\"-0.6866567655145945\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.38The final answer is a float number, so I will format it accordingly. The final answer is 0.38.\"}\n",
      "5: ['0.38', '0.38']\n",
      "{\"question\":\"1.43451169952446\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.1233.\"}\n",
      "5: ['1.1233']\n",
      "{\"question\":\"1.4848322137966912\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.1398\"}\n",
      "5: ['0.1398']\n",
      "{\"question\":\"1.5829481236707421\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.85.\"}\n",
      "5: ['0.85']\n",
      "{\"question\":\"1.3517541629002292\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.7\"}\n",
      "5: ['0.7']\n",
      "{\"question\":\"1.4848322137966912\", \"answer\": \"The final answer is 1.0.\"}\n",
      "5: ['1.0']\n",
      "{\"question\":\"-0.1675387539236454\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.54294\"}\n",
      "5: ['0.54294']\n",
      "{\"question\":\"0.6289625403397487\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.1387.Note that the response contains a mix of numbers and symbols, but the final answer is a single numerical value, which is\"}\n",
      "5: ['1.1387']\n",
      "{\"question\":\"1.223422641728278\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 1.0\"}\n",
      "5: ['1.0']\n",
      "{\"question\":\"0.0471469353916556\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 0.94.\"}\n",
      "5: ['0.94']\n",
      "{\"question\":\"1.3204046557682323\", \"answer\": \"After extracting the final answer from the response, I found the following results:1.0.0.1.1.0.6.1.0.38 = 0.381.98 = 1.980\"}\n",
      "5: ['1.0', '.0', '.1', '.1', '.0', '.6', '.1', '.0', '.38', '0.381', '.98', '1.980']\n",
      "{\"question\":\"-0.9642887965261264\", \"answer\": \"After extracting the final answer from the response, I found the answer to be:The final answer is 1.1157\"}\n",
      "5: ['1.1157']\n",
      "{\"question\":\"0.2062646467168234\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.523.\"}\n",
      "5: ['0.523']\n",
      "{\"question\":\"1.3270360161627923\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.59\"}\n",
      "5: ['0.59']\n",
      "{\"question\":\"2.1306130230659583\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.59\"}\n",
      "5: ['0.59']\n",
      "{\"question\":\"1.34810070977767\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1234.39.Note that the response contains multiple numbers and values, but the final answer is a single float value, which is\"}\n",
      "5: ['0.1234', '.39']\n",
      "{\"question\":\"1.3517541629002292\", \"answer\": \"The final answer is 1.1399.\"}\n",
      "5: ['1.1399']\n",
      "{\"question\":\"1.0571120837437076\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.91\"}\n",
      "5: ['0.91']\n",
      "{\"question\":\"0.1025053060141916\", \"answer\": \"The final answer is 1.1239.\"}\n",
      "5: ['1.1239']\n",
      "{\"question\":\"-0.6394927844988614\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.29658\"}\n",
      "5: ['0.29658']\n",
      "{\"question\":\"-0.5667635539514848\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.65\"}\n",
      "5: ['0.65']\n",
      "{\"question\":\"0.4357856353877761\", \"answer\": \"The final answer is 0.2.\"}\n",
      "5: ['0.2']\n",
      "{\"question\":\"1.4848322137966912\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.38\"}\n",
      "5: ['0.38']\n",
      "{\"question\":\"-0.1675387539236454\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.16399.\"}\n",
      "5: ['0.16399']\n",
      "{\"question\":\"1.1236126537690967\", \"answer\": \"After extracting the final answer from the response, I got:The final answer is 1.13976\"}\n",
      "5: ['1.13976']\n",
      "{\"question\":\"1.787411605979226\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 2.1247\"}\n",
      "5: ['2.1247']\n",
      "{\"question\":\"1.897412320785543\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.186.\"}\n",
      "5: ['0.186']\n",
      "{\"question\":\"1.4848322137966912\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.98This is the result as a float number.\"}\n",
      "5: ['0.98']\n",
      "{\"question\":\"0.4023524316118089\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1429.Note that the answer is a float number, and I've formatted it accordingly.\"}\n",
      "5: ['0.1429']\n",
      "{\"question\":\"0.1461825543271399\", \"answer\": \"The final answer is 0.1049.\"}\n",
      "5: ['0.1049']\n",
      "{\"question\":\"-0.3665503206988387\", \"answer\": \"After extracting the final answer from the response, I found the following results:The final answer is 1.5599.Note that some of the intermediate results may be in a different format (e.g., integers, decimal numbers), but the final\"}\n",
      "5: ['1.5599']\n",
      "{\"question\":\"0.1432824310219665\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.28792\"}\n",
      "5: ['0.28792']\n",
      "{\"question\":\"-1.19816082698158\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.42.\"}\n",
      "5: ['1.42']\n",
      "{\"question\":\"1.1236126537690967\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.59.\"}\n",
      "5: ['1.59']\n",
      "{\"question\":\"-0.7046200222329654\", \"answer\": \"After extracting the final answer from the response, I found the following:1.1.1.4.622.0.1.981.1151.116...0.1.1.0.56\"}\n",
      "5: ['1.1', '.1', '.4', '.622', '.0', '.1', '.981', '.1151', '.116', '...0', '.1', '.1', '.0', '.56']\n",
      "{\"question\":\"-0.5667635539514848\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 1.58.\"}\n",
      "5: ['1.58']\n",
      "{\"question\":\"-1.4957344814153704\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.45\"}\n",
      "5: ['0.45']\n",
      "{\"question\":\"1.371363922297066\", \"answer\": \"After extracting the final answer from the response, I found the following:The final answer is 0.289\"}\n",
      "5: ['0.289']\n",
      "{\"question\":\"1.102777869031954\", \"answer\": \"After extracting the final answer from the response, I found the following values:1.50.00.80.961.10.11.11580.2961.\"}\n",
      "5: ['1.50', '.00', '.80', '.961', '.10', '.11', '.11580', '.2961']\n",
      "{\"question\":\"-0.238948339783978\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 1.0\"}\n",
      "5: ['1.0']\n",
      "{\"question\":\"1.357280814388872\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.296This is the result in the format of a float number as requested.\"}\n",
      "5: ['0.296']\n",
      "{\"question\":\"0.2062646467168234\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:1.0The final answer is 1.0, which is a float number.\"}\n",
      "5: ['1.0', '1.0']\n",
      "{\"question\":\"-0.1675387539236454\", \"answer\": \"After extracting the final answer from the response, I found the answer to be:The final answer is 1.5337.Note that the answer is a float number.\"}\n",
      "5: ['1.5337']\n",
      "{\"question\":\"1.43451169952446\", \"answer\": \"The final answer is 2.1188.\"}\n",
      "5: ['2.1188']\n",
      "{\"question\":\"-0.7600105069506031\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.1637.\"}\n",
      "5: ['2.1637']\n",
      "{\"question\":\"0.1025053060141916\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.94.\"}\n",
      "5: ['0.94']\n",
      "{\"question\":\"2.1306130230659583\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.38.Note that the answer is a float number, as requested.\"}\n",
      "5: ['0.38']\n",
      "{\"question\":\"-0.1675387539236454\", \"answer\": \"After extracting the final answer from the response, I found that the result is:0.95The final answer is 0.95.\"}\n",
      "5: ['0.95', '0.95']\n",
      "{\"question\":\"0.9889366306476444\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.29571.\"}\n",
      "5: ['0.29571']\n",
      "{\"question\":\"0.4023524316118089\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.1399\"}\n",
      "5: ['0.1399']\n",
      "0.9482219930383649\n",
      "{\"question\":\"1.0119696503036768\", \"answer\": \"The final answer is 0.5888.\"}\n",
      "6: ['0.5888']\n",
      "{\"question\":\"1.7013700152684006\", \"answer\": \"The final answer is 8.0.\"}\n",
      "6: ['8.0']\n",
      "{\"question\":\"0.7519767637481867\", \"answer\": \"The final answer is 1.2897.\"}\n",
      "6: ['1.2897']\n",
      "{\"question\":\"0.9890797426525052\", \"answer\": \"The final answer is 0.\"}\n",
      "6: ['0']\n",
      "{\"question\":\"1.324125521967597\", \"answer\": \"The final answer is 1.012083.\"}\n",
      "6: ['1.012083']\n",
      "{\"question\":\"0.3434036597729131\", \"answer\": \"The final answer is 0.7885,\"}\n",
      "6: ['0.7885']\n",
      "{\"question\":\"1.3984023023217764\", \"answer\": \"The final answer is 8.0.\"}\n",
      "6: ['8.0']\n",
      "{\"question\":\"1.883810374394483\", \"answer\": \"The final answer is 1.7.\"}\n",
      "6: ['1.7']\n",
      "{\"question\":\"1.3129089899408255\", \"answer\": \"The final answer is 0.8.\"}\n",
      "6: ['0.8']\n",
      "{\"question\":\"1.3186250305271796\", \"answer\": \"The final answer is 1.785.\"}\n",
      "6: ['1.785']\n",
      "{\"question\":\"1.3129089899408255\", \"answer\": \"The final answer is 58.0.\"}\n",
      "6: ['58.0']\n",
      "{\"question\":\"1.3984023023217764\", \"answer\": \"The final answer is 1.284.\"}\n",
      "6: ['1.284']\n",
      "{\"question\":\"1.408913776641734\", \"answer\": \"The final answer is 0.35.\"}\n",
      "6: ['0.35']\n",
      "{\"question\":\"1.883810374394483\", \"answer\": \"The final answer is 0.95.\"}\n",
      "6: ['0.95']\n",
      "{\"question\":\"-0.3764251850250675\", \"answer\": \"The final answer is 0.8.\"}\n",
      "6: ['0.8']\n",
      "{\"question\":\"0.6150459008569201\", \"answer\": \"The final answer is 67.0.\"}\n",
      "6: ['67.0']\n",
      "{\"question\":\"-1.1786113605918287\", \"answer\": \"The final answer is 0.138, where 0.138 is the result as a float number.\"}\n",
      "6: ['0.138', '0.138']\n",
      "{\"question\":\"1.8442691480839737\", \"answer\": \"The final answer is 40.0.\"}\n",
      "6: ['40.0']\n",
      "{\"question\":\"-0.9602851705809984\", \"answer\": \"The final answer is 0.086.\"}\n",
      "6: ['0.086']\n",
      "{\"question\":\"1.5057060964426503\", \"answer\": \"The final answer is 78.0.\"}\n",
      "6: ['78.0']\n",
      "{\"question\":\"1.2919711989709468\", \"answer\": \"The final answer is 1.8.\"}\n",
      "6: ['1.8']\n",
      "{\"question\":\"1.3984023023217764\", \"answer\": \"The final answer is 38.0.\"}\n",
      "6: ['38.0']\n",
      "{\"question\":\"1.2919711989709468\", \"answer\": \"After extracting the final answer from the response, I found the result to be:0.1867The final answer is 0.1867.\"}\n",
      "6: ['0.1867', '0.1867']\n",
      "{\"question\":\"1.812644800490653\", \"answer\": \"The final answer is 0.7858.\"}\n",
      "6: ['0.7858']\n",
      "{\"question\":\"1.565682409874534\", \"answer\": \"The final answer is 0.8.\"}\n",
      "6: ['0.8']\n",
      "{\"question\":\"1.7913952519026577\", \"answer\": \"The final answer is 0.186.\"}\n",
      "6: ['0.186']\n",
      "{\"question\":\"0.7519767637481867\", \"answer\": \"The final answer is 58.0.\"}\n",
      "6: ['58.0']\n",
      "{\"question\":\"1.7913952519026577\", \"answer\": \"The final answer is 0.78576.\"}\n",
      "6: ['0.78576']\n",
      "{\"question\":\"1.6563854448242428\", \"answer\": \"The final answer is 8.58.\"}\n",
      "6: ['8.58']\n",
      "{\"question\":\"0.9084346091485244\", \"answer\": \"The final answer is 0.\"}\n",
      "6: ['0']\n",
      "{\"question\":\"-1.305640523629371\", \"answer\": \"The final answer is 0.58858.\"}\n",
      "6: ['0.58858']\n",
      "{\"question\":\"1.4625846575923227\", \"answer\": \"The final answer is 2.1394.\"}\n",
      "6: ['2.1394']\n",
      "{\"question\":\"1.7491931141743484\", \"answer\": \"The final answer is 0.78517.\"}\n",
      "6: ['0.78517']\n",
      "{\"question\":\"0.6985974952352435\", \"answer\": \"The final answer is 38.0.\"}\n",
      "6: ['38.0']\n",
      "{\"question\":\"1.3129089899408255\", \"answer\": \"The final answer is 0.995.\"}\n",
      "6: ['0.995']\n",
      "{\"question\":\"-0.9602851705809984\", \"answer\": \"The final answer is 0.0038.\"}\n",
      "6: ['0.0038']\n",
      "{\"question\":\"1.8442691480839737\", \"answer\": \"The final answer is 40.0.\"}\n",
      "6: ['40.0']\n",
      "{\"question\":\"0.6985974952352435\", \"answer\": \"The final answer is 0.4.\"}\n",
      "6: ['0.4']\n",
      "{\"question\":\"0.8454518887211088\", \"answer\": \"The final answer is 0.54258.\"}\n",
      "6: ['0.54258']\n",
      "{\"question\":\"1.4625846575923227\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.78476.\"}\n",
      "6: ['0.78476']\n",
      "{\"question\":\"0.6985974952352435\", \"answer\": \"The final answer is 2.1845.\"}\n",
      "6: ['2.1845']\n",
      "{\"question\":\"-5.160321757380978\", \"answer\": \"The final answer is 0.0125.\"}\n",
      "6: ['0.0125']\n",
      "{\"question\":\"-0.4270568365924936\", \"answer\": \"The final answer is 36.0.\"}\n",
      "6: ['36.0']\n",
      "{\"question\":\"0.9084346091485244\", \"answer\": \"The final answer is 2.3.\"}\n",
      "6: ['2.3']\n",
      "{\"question\":\"0.9409778516905928\", \"answer\": \"The final answer is 8.1.\"}\n",
      "6: ['8.1']\n",
      "{\"question\":\"-0.3322545457134922\", \"answer\": \"The final answer is 1.8.\"}\n",
      "6: ['1.8']\n",
      "{\"question\":\"0.430954079657584\", \"answer\": \"The final answer is 0.94.\"}\n",
      "6: ['0.94']\n",
      "{\"question\":\"1.8442691480839737\", \"answer\": \"The final answer is 0.83.\"}\n",
      "6: ['0.83']\n",
      "{\"question\":\"-1.1786113605918287\", \"answer\": \"The final answer is 38.0.\"}\n",
      "6: ['38.0']\n",
      "{\"question\":\"1.4432753361915962\", \"answer\": \"The final answer is 0.7954.\"}\n",
      "6: ['0.7954']\n",
      "{\"question\":\"0.8454518887211088\", \"answer\": \"The final answer is 80.0.\"}\n",
      "6: ['80.0']\n",
      "12.228704567712569\n",
      "{\"question\":\"0.7334657247075913\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.1861\"}\n",
      "7: ['0.1861']\n",
      "{\"question\":\"0.3025180713336735\", \"answer\": \"The final answer is 2.38.\"}\n",
      "7: ['2.38']\n",
      "{\"question\":\"0.6404141746445333\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 1.5887.\"}\n",
      "7: ['1.5887']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"The final answer is 0.8.\"}\n",
      "7: ['0.8']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"The final answer is 98.58.\"}\n",
      "7: ['98.58']\n",
      "{\"question\":\"0.8061076130445813\", \"answer\": \"The final answer is 0.56.\"}\n",
      "7: ['0.56']\n",
      "{\"question\":\"-0.3310245967740401\", \"answer\": \"The final answer is 7.94.\"}\n",
      "7: ['7.94']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.58\"}\n",
      "7: ['1.58']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.78459\"}\n",
      "7: ['0.78459']\n",
      "{\"question\":\"0.0084588473686212\", \"answer\": \"The final answer is 2.7662.\"}\n",
      "7: ['2.7662']\n",
      "{\"question\":\"0.5501334367563445\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:9.58\"}\n",
      "7: ['9.58']\n",
      "{\"question\":\"1.1561425206440343\", \"answer\": \"The final answer is 1.38.\"}\n",
      "7: ['1.38']\n",
      "{\"question\":\"0.3769255177761904\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.94.\"}\n",
      "7: ['0.94']\n",
      "{\"question\":\"0.7965031968830701\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.98.\"}\n",
      "7: ['0.98']\n",
      "{\"question\":\"-1.0076733314436972\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -0.18692.\"}\n",
      "7: ['-0.18692']\n",
      "{\"question\":\"1.3593736205946554\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.5881.Let me know if you need any further assistance!\"}\n",
      "7: ['0.5881']\n",
      "{\"question\":\"0.1330874841695626\", \"answer\": \"The final answer is 7.62.\"}\n",
      "7: ['7.62']\n",
      "{\"question\":\"0.3141659562321851\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.18467.\"}\n",
      "7: ['0.18467']\n",
      "{\"question\":\"1.1294322477065644\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:8.67\"}\n",
      "7: ['8.67']\n",
      "{\"question\":\"0.1330874841695626\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.78693\"}\n",
      "7: ['0.78693']\n",
      "{\"question\":\"0.5185725162328935\", \"answer\": \"After extracting the final answer from the response, I found the following:The final answer is 0.45.Note that the response contains a large amount of text, and I had to carefully extract the final answer from it. If you'd like\"}\n",
      "7: ['0.45']\n",
      "{\"question\":\"0.7503242755267766\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.7843,\"}\n",
      "7: ['0.7843']\n",
      "{\"question\":\"1.1294322477065644\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.52\"}\n",
      "7: ['0.52']\n",
      "{\"question\":\"-0.1424075618730651\", \"answer\": \"The final answer is 0.78591.\"}\n",
      "7: ['0.78591']\n",
      "{\"question\":\"-10.688965496647398\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.78468\"}\n",
      "7: ['0.78468']\n",
      "{\"question\":\"0.3769255177761904\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 1.38.\"}\n",
      "7: ['1.38']\n",
      "{\"question\":\"1.3078116277327778\", \"answer\": \"The final answer is 2.\"}\n",
      "7: ['2']\n",
      "{\"question\":\"1.1294322477065644\", \"answer\": \"The final answer is 7.59.\"}\n",
      "7: ['7.59']\n",
      "{\"question\":\"0.6404141746445333\", \"answer\": \"After extracting the final answer from the response, I found the following value:The final answer is 0.58839\"}\n",
      "7: ['0.58839']\n",
      "{\"question\":\"1.4595121387005476\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.78562\"}\n",
      "7: ['0.78562']\n",
      "{\"question\":\"0.0745891781517665\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.2842.\"}\n",
      "7: ['0.2842']\n",
      "{\"question\":\"0.3769255177761904\", \"answer\": \"The final answer is 2.49.\"}\n",
      "7: ['2.49']\n",
      "{\"question\":\"0.0058408151271023\", \"answer\": \"The final answer is 2.58.\"}\n",
      "7: ['2.58']\n",
      "{\"question\":\"-0.1424075618730651\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 2.62\"}\n",
      "7: ['2.62']\n",
      "{\"question\":\"1.1561425206440343\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.2847\"}\n",
      "7: ['0.2847']\n",
      "{\"question\":\"-0.1424075618730651\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.94\"}\n",
      "7: ['0.94']\n",
      "{\"question\":\"0.0058408151271023\", \"answer\": \"The final answer is 0.59.\"}\n",
      "7: ['0.59']\n",
      "{\"question\":\"0.3141659562321851\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.7857.\"}\n",
      "7: ['0.7857']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.98.\"}\n",
      "7: ['0.98']\n",
      "{\"question\":\"1.2044782097549858\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 6.62.\"}\n",
      "7: ['6.62']\n",
      "{\"question\":\"0.9901726555529808\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.7848\"}\n",
      "7: ['0.7848']\n",
      "{\"question\":\"0.3926855188963158\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.1395.Note that the answer is a float number, as requested.\"}\n",
      "7: ['0.1395']\n",
      "{\"question\":\"-1.0076733314436972\", \"answer\": \"The final answer is 0.96.\"}\n",
      "7: ['0.96']\n",
      "{\"question\":\"0.8861695320142922\", \"answer\": \"The final answer is 9.7.\"}\n",
      "7: ['9.7']\n",
      "{\"question\":\"0.7541752484526155\", \"answer\": \"The final answer is 0.\"}\n",
      "7: ['0']\n",
      "{\"question\":\"1.2044782097549858\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 60.52\"}\n",
      "7: ['60.52']\n",
      "{\"question\":\"0.9637626331667524\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.2969So, the final answer is 0.2969.\"}\n",
      "7: ['0.2969', '0.2969']\n",
      "{\"question\":\"1.246626610325625\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is 0.1.\"}\n",
      "7: ['0.1']\n",
      "{\"question\":\"1.2044782097549858\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 1.58\"}\n",
      "7: ['1.58']\n",
      "{\"question\":\"1.1158345470261009\", \"answer\": \"The final answer is 0.98.\"}\n",
      "7: ['0.98']\n",
      "{\"question\":\"-0.1059193112983897\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:**50.23**Let me know if you need any further assistance!\"}\n",
      "7: ['50.23']\n",
      "5.939084838276462\n",
      "{\"question\":\"0.4514647386096604\", \"answer\": \"The final answer is 0.392.\"}\n",
      "8: ['0.392']\n",
      "{\"question\":\"-0.014887418989803225\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.68.\"}\n",
      "8: ['2.68']\n",
      "{\"question\":\"0.4430805733853383\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.7868\"}\n",
      "8: ['0.7868']\n",
      "{\"question\":\"0.2744978529713043\", \"answer\": \"The final answer is 0.0.\"}\n",
      "8: ['0.0']\n",
      "{\"question\":\"0.3828741450746197\", \"answer\": \"The final answer is 0.3858.\"}\n",
      "8: ['0.3858']\n",
      "{\"question\":\"0.0926941875085743\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.4218.\"}\n",
      "8: ['0.4218']\n",
      "{\"question\":\"0.0926941875085743\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is -1.78652\"}\n",
      "8: ['-1.78652']\n",
      "{\"question\":\"-0.014887418989803225\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.7867.\"}\n",
      "8: ['0.7867']\n",
      "{\"question\":\"6.795481036841758\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.4087.\"}\n",
      "8: ['0.4087']\n",
      "{\"question\":\"0.3256181282496966\", \"answer\": \"The final answer is 0.7.\"}\n",
      "8: ['0.7']\n",
      "{\"question\":\"1.5284691642312058\", \"answer\": \"The final answer is 0.3928.\"}\n",
      "8: ['0.3928']\n",
      "{\"question\":\"1.2876560302588542\", \"answer\": \"After extracting the final answer from the response, I found the following result:The final answer is 0.31686\"}\n",
      "8: ['0.31686']\n",
      "{\"question\":\"0.3145479526548075\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.\"}\n",
      "8: ['0']\n",
      "{\"question\":\"0.5742471763651691\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 3827.38\"}\n",
      "8: ['3827.38']\n",
      "{\"question\":\"0.9584129743271476\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.\"}\n",
      "8: ['0']\n",
      "{\"question\":\"0.3828741450746197\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.3928\"}\n",
      "8: ['0.3928']\n",
      "{\"question\":\"-0.3400808389286541\", \"answer\": \"The final answer is 3907.3.\"}\n",
      "8: ['3907.3']\n",
      "{\"question\":\"0.9816362979852032\", \"answer\": \"The final answer is 0.38.\"}\n",
      "8: ['0.38']\n",
      "{\"question\":\"-0.3695633377914742\", \"answer\": \"After extracting the final answer from the response, I got:The final answer is 1.3718\"}\n",
      "8: ['1.3718']\n",
      "{\"question\":\"1.475647960332376\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 3827.38\"}\n",
      "8: ['3827.38']\n",
      "{\"question\":\"0.3955835890548084\", \"answer\": \"The final answer is 0.3767.\"}\n",
      "8: ['0.3767']\n",
      "{\"question\":\"0.5904416760131495\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.385, where 0.385 is the result as a float number.\"}\n",
      "8: ['0.385', '0.385']\n",
      "{\"question\":\"-1.5550359231255022\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.316\"}\n",
      "8: ['0.316']\n",
      "{\"question\":\"0.3605340705106951\", \"answer\": \"The final answer is 0.3907.\"}\n",
      "8: ['0.3907']\n",
      "{\"question\":\"-0.3400808389286541\", \"answer\": \"The final answer is 1.36.\"}\n",
      "8: ['1.36']\n",
      "{\"question\":\"0.3145479526548075\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.7858\"}\n",
      "8: ['0.7858']\n",
      "{\"question\":\"0.5122985193083808\", \"answer\": \"The final answer is 0.38.\"}\n",
      "8: ['0.38']\n",
      "{\"question\":\"0.9816362979852032\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.8.\"}\n",
      "8: ['-1.8']\n",
      "{\"question\":\"0.3256181282496966\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is -1.394,\"}\n",
      "8: ['-1.394']\n",
      "{\"question\":\"0.4752564499024801\", \"answer\": \"The final answer is 0.38091.\"}\n",
      "8: ['0.38091']\n",
      "{\"question\":\"0.0926941875085743\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.\"}\n",
      "8: ['0']\n",
      "{\"question\":\"0.4733695764127811\", \"answer\": \"The final answer is 0.\"}\n",
      "8: ['0']\n",
      "{\"question\":\"0.3145479526548075\", \"answer\": \"The final answer is 0.38.\"}\n",
      "8: ['0.38']\n",
      "{\"question\":\"-0.019617653279340286\", \"answer\": \"The final answer is 0.3907.\"}\n",
      "8: ['0.3907']\n",
      "{\"question\":\"-1.1345804793871377\", \"answer\": \"The final answer is 0.3927.\"}\n",
      "8: ['0.3927']\n",
      "{\"question\":\"-0.019617653279340286\", \"answer\": \"The final answer is 0.3928.\"}\n",
      "8: ['0.3928']\n",
      "{\"question\":\"0.986906050731049\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 94.2951.\"}\n",
      "8: ['94.2951']\n",
      "{\"question\":\"0.3303577088518443\", \"answer\": \"The final answer is 0.78531.\"}\n",
      "8: ['0.78531']\n",
      "{\"question\":\"0.3256181282496966\", \"answer\": \"The final answer is 0.94.\"}\n",
      "8: ['0.94']\n",
      "{\"question\":\"0.3145479526548075\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.588\"}\n",
      "8: ['0.588']\n",
      "{\"question\":\"0.3955835890548084\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.512.\"}\n",
      "8: ['0.512']\n",
      "{\"question\":\"0.3441531822364371\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 3848.7\"}\n",
      "8: ['3848.7']\n",
      "{\"question\":\"0.3117455567001034\", \"answer\": \"The final answer is 0.38.\"}\n",
      "8: ['0.38']\n",
      "{\"question\":\"0.5132639831906624\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.37538\"}\n",
      "8: ['0.37538']\n",
      "{\"question\":\"-0.014887418989803225\", \"answer\": \"The final answer is 0.3859.\"}\n",
      "8: ['0.3859']\n",
      "{\"question\":\"1.2876560302588542\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.3768.\"}\n",
      "8: ['0.3768']\n",
      "{\"question\":\"1.0973265525317148\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.36\"}\n",
      "8: ['0.36']\n",
      "{\"question\":\"0.429110209389588\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.78676\"}\n",
      "8: ['0.78676']\n",
      "{\"question\":\"0.4351247478160049\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.38476\"}\n",
      "8: ['0.38476']\n",
      "{\"question\":\"-0.3400808389286541\", \"answer\": \"The final answer is 1.0.\"}\n",
      "8: ['1.0']\n",
      "{\"question\":\"0.0926941875085743\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.\"}\n",
      "8: ['0']\n",
      "2.7606064423845504\n",
      "{\"question\":\"-1.364515652793873\", \"answer\": \"The final answer is 1.5.\"}\n",
      "9: ['1.5']\n",
      "{\"question\":\"1.8315405526647113\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 7.53\"}\n",
      "9: ['7.53']\n",
      "{\"question\":\"-0.3073699173026865\", \"answer\": \"The final answer is 0.7.\"}\n",
      "9: ['0.7']\n",
      "{\"question\":\"0.8971180402592536\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.621.\"}\n",
      "9: ['0.621']\n",
      "{\"question\":\"1.0806024664184724\", \"answer\": \"The final answer is 0.62362.\"}\n",
      "9: ['0.62362']\n",
      "{\"question\":\"0.9421573488447404\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.6238\"}\n",
      "9: ['0.6238']\n",
      "{\"question\":\"0.101103811253465\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.3088.\"}\n",
      "9: ['1.3088']\n",
      "{\"question\":\"1.2684691884242738\", \"answer\": \"The final answer is 6.462.\"}\n",
      "9: ['6.462']\n",
      "{\"question\":\"0.8083181676162694\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.618\"}\n",
      "9: ['0.618']\n",
      "{\"question\":\"-0.5262965771195218\", \"answer\": \"The final answer is 1.0.7.\"}\n",
      "9: ['1.0', '.7']\n",
      "{\"question\":\"0.3798529016685695\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.62338.\"}\n",
      "9: ['1.62338']\n",
      "{\"question\":\"-0.4675249252218768\", \"answer\": \"The final answer is 7.0.\"}\n",
      "9: ['7.0']\n",
      "{\"question\":\"0.3798529016685695\", \"answer\": \"The final answer is 0.62.\"}\n",
      "9: ['0.62']\n",
      "{\"question\":\"-0.5645200452969583\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 1.62378.\"}\n",
      "9: ['1.62378']\n",
      "{\"question\":\"0.2744664922032449\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:The final answer is 1.1867.\"}\n",
      "9: ['1.1867']\n",
      "{\"question\":\"-1.2087556894104172\", \"answer\": \"The final answer is 7.0.\"}\n",
      "9: ['7.0']\n",
      "{\"question\":\"-0.5518723067417611\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.29638.\"}\n",
      "9: ['0.29638']\n",
      "{\"question\":\"0.8971180402592536\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.6237.\"}\n",
      "9: ['0.6237']\n",
      "{\"question\":\"-0.7702651983862073\", \"answer\": \"The final answer is 29.5.\"}\n",
      "9: ['29.5']\n",
      "{\"question\":\"0.3475842441693588\", \"answer\": \"The final answer is 0.54.6207.\"}\n",
      "9: ['0.54', '.6207']\n",
      "{\"question\":\"-0.3474761852089708\", \"answer\": \"The final answer is 1.1846.\"}\n",
      "9: ['1.1846']\n",
      "{\"question\":\"0.0871267862241506\", \"answer\": \"The final answer is 1.1187.\"}\n",
      "9: ['1.1187']\n",
      "{\"question\":\"-0.362845827993948\", \"answer\": \"The final answer is 0.68.\"}\n",
      "9: ['0.68']\n",
      "{\"question\":\"-2.1255018819299267\", \"answer\": \"The final answer is 62362.\"}\n",
      "9: ['62362']\n",
      "{\"question\":\"-0.5442794601237178\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 2.29552\"}\n",
      "9: ['2.29552']\n",
      "{\"question\":\"1.4692643043597795\", \"answer\": \"The final answer is 64.\"}\n",
      "9: ['64']\n",
      "{\"question\":\"0.8971180402592536\", \"answer\": \"The final answer is 0.67.\"}\n",
      "9: ['0.67']\n",
      "{\"question\":\"-1.413204356719961\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.62371\"}\n",
      "9: ['0.62371']\n",
      "{\"question\":\"0.2744664922032449\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.6237\"}\n",
      "9: ['0.6237']\n",
      "{\"question\":\"-0.5518723067417611\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.296\"}\n",
      "9: ['0.296']\n",
      "{\"question\":\"-0.508312648885544\", \"answer\": \"The final answer is 58.0.\"}\n",
      "9: ['58.0']\n",
      "{\"question\":\"-0.508312648885544\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.62398.\"}\n",
      "9: ['0.62398']\n",
      "{\"question\":\"1.2605324707407906\", \"answer\": \"The final answer is 62.38.\"}\n",
      "9: ['62.38']\n",
      "{\"question\":\"-0.5645200452969583\", \"answer\": \"The final answer is 67.0.\"}\n",
      "9: ['67.0']\n",
      "{\"question\":\"-0.4459816301250033\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 7.6187\"}\n",
      "9: ['7.6187']\n",
      "{\"question\":\"-1.364515652793873\", \"answer\": \"The final answer is 58.0.\"}\n",
      "9: ['58.0']\n",
      "{\"question\":\"-1.413204356719961\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.41.\"}\n",
      "9: ['0.41']\n",
      "{\"question\":\"-0.3073699173026865\", \"answer\": \"The final answer is 62.0.\"}\n",
      "9: ['62.0']\n",
      "{\"question\":\"-0.7702651983862073\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.78560.\"}\n",
      "9: ['0.78560']\n",
      "{\"question\":\"1.2605324707407906\", \"answer\": \"The final answer is 62.0.\"}\n",
      "9: ['62.0']\n",
      "{\"question\":\"-0.1948290189988791\", \"answer\": \"The final answer is 7.78.\"}\n",
      "9: ['7.78']\n",
      "{\"question\":\"-1.413204356719961\", \"answer\": \"The final answer is 0.6207.\"}\n",
      "9: ['0.6207']\n",
      "{\"question\":\"0.0871267862241506\", \"answer\": \"The final answer is 62.6.\"}\n",
      "9: ['62.6']\n",
      "{\"question\":\"-0.5645200452969583\", \"answer\": \"The final answer is 0.52.623.\"}\n",
      "9: ['0.52', '.623']\n",
      "{\"question\":\"-0.3474761852089708\", \"answer\": \"The final answer is 0.78538.\"}\n",
      "9: ['0.78538']\n",
      "{\"question\":\"1.2684691884242738\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.18467\"}\n",
      "9: ['0.18467']\n",
      "{\"question\":\"-0.4675249252218768\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:-1.623\"}\n",
      "9: ['-1.623']\n",
      "{\"question\":\"-0.3073699173026865\", \"answer\": \"The final answer is 0.0.\"}\n",
      "9: ['0.0']\n",
      "{\"question\":\"-0.3073699173026865\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.6238.\"}\n",
      "9: ['1.6238']\n",
      "{\"question\":\"-1.411558815556028\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.2963.\"}\n",
      "9: ['0.2963']\n",
      "{\"question\":\"-0.4675249252218768\", \"answer\": \"The final answer is 0.6238.\"}\n",
      "9: ['0.6238']\n",
      "12.143203613867602\n",
      "{\"question\":\"-1.1870505892448908\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:1.58\"}\n",
      "10: ['1.58']\n",
      "{\"question\":\"0.0955270080763441\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.96\"}\n",
      "10: ['2.96']\n",
      "{\"question\":\"1.185552203219535\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.38592\"}\n",
      "10: ['0.38592']\n",
      "{\"question\":\"-1.2482244131730764\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 1.98\"}\n",
      "10: ['1.98']\n",
      "{\"question\":\"-1.231623696331313\", \"answer\": \"The final answer is 0.82.\"}\n",
      "10: ['0.82']\n",
      "{\"question\":\"0.2105275668188163\", \"answer\": \"After extracting the final answer from the response, I found the result to be:The final answer is 2.184\"}\n",
      "10: ['2.184']\n",
      "{\"question\":\"-1.068997754836574\", \"answer\": \"The final answer is 2.0.\"}\n",
      "10: ['2.0']\n",
      "{\"question\":\"-0.6332243537675198\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:2.59\"}\n",
      "10: ['2.59']\n",
      "{\"question\":\"-1.5243866940187518\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 2.56\"}\n",
      "10: ['2.56']\n",
      "{\"question\":\"0.2503367506503461\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 9.54.\"}\n",
      "10: ['9.54']\n",
      "{\"question\":\"-0.803239525846312\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.287\"}\n",
      "10: ['0.287']\n",
      "{\"question\":\"0.2082890320894082\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 1.76\"}\n",
      "10: ['1.76']\n",
      "{\"question\":\"-0.803239525846312\", \"answer\": \"The final answer is 2.0.\"}\n",
      "10: ['2.0']\n",
      "{\"question\":\"-0.8487066790721608\", \"answer\": \"The final answer is 1.2968.\"}\n",
      "10: ['1.2968']\n",
      "{\"question\":\"-0.09858301349211543\", \"answer\": \"The final answer is 2.67.\"}\n",
      "10: ['2.67']\n",
      "{\"question\":\"-1.152680530093557\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.98.\"}\n",
      "10: ['0.98']\n",
      "{\"question\":\"-1.5499541613101018\", \"answer\": \"The final answer is 2.0.\"}\n",
      "10: ['2.0']\n",
      "{\"question\":\"-1.2482244131730764\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.96.\"}\n",
      "10: ['0.96']\n",
      "{\"question\":\"-1.179917903502527\", \"answer\": \"The final answer is 1.28795.\"}\n",
      "10: ['1.28795']\n",
      "{\"question\":\"-0.10696477856759501\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.1.\"}\n",
      "10: ['2.1']\n",
      "{\"question\":\"-0.7756098097692551\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 4.56\"}\n",
      "10: ['4.56']\n",
      "{\"question\":\"0.0955270080763441\", \"answer\": \"The final answer is 2.56.\"}\n",
      "10: ['2.56']\n",
      "{\"question\":\"-1.07317773356553\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.39091\"}\n",
      "10: ['0.39091']\n",
      "{\"question\":\"0.2503367506503461\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 0.28.\"}\n",
      "10: ['0.28']\n",
      "{\"question\":\"0.9582560106606636\", \"answer\": \"The final answer is 8.0.\"}\n",
      "10: ['8.0']\n",
      "{\"question\":\"1.0998357620586718\", \"answer\": \"The final answer is 9.2.\"}\n",
      "10: ['9.2']\n",
      "{\"question\":\"-1.2482244131730764\", \"answer\": \"After extracting the final answer from the response, I found the answer to be:The final answer is 1.29698.\"}\n",
      "10: ['1.29698']\n",
      "{\"question\":\"-1.6543629142801166\", \"answer\": \"The final answer is 9.0.\"}\n",
      "10: ['9.0']\n",
      "{\"question\":\"-0.09858301349211543\", \"answer\": \"The final answer is 3.962.\"}\n",
      "10: ['3.962']\n",
      "{\"question\":\"-1.5499541613101018\", \"answer\": \"The final answer is 2.68.\"}\n",
      "10: ['2.68']\n",
      "{\"question\":\"-0.7826808837446069\", \"answer\": \"The final answer is 8.7.\"}\n",
      "10: ['8.7']\n",
      "{\"question\":\"-0.7826808837446069\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 0.2879\"}\n",
      "10: ['0.2879']\n",
      "{\"question\":\"-1.2004283072649566\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.67\"}\n",
      "10: ['2.67']\n",
      "{\"question\":\"-0.8487066790721608\", \"answer\": \"After extracting the final answer from the response, I found that the result is:0.988\"}\n",
      "10: ['0.988']\n",
      "{\"question\":\"-1.1256844235607733\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.62\"}\n",
      "10: ['0.62']\n",
      "{\"question\":\"-1.1870505892448908\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.2898\"}\n",
      "10: ['0.2898']\n",
      "{\"question\":\"-1.6543629142801166\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 2.98\"}\n",
      "10: ['2.98']\n",
      "{\"question\":\"1.185552203219535\", \"answer\": \"The final answer is 2.7.\"}\n",
      "10: ['2.7']\n",
      "{\"question\":\"-1.179917903502527\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 0.1177\"}\n",
      "10: ['0.1177']\n",
      "{\"question\":\"-1.2004283072649566\", \"answer\": \"The final answer is 0.62.\"}\n",
      "10: ['0.62']\n",
      "{\"question\":\"-0.6326050062033488\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:1.38\"}\n",
      "10: ['1.38']\n",
      "{\"question\":\"-1.6543629142801166\", \"answer\": \"The final answer is 0.8.\"}\n",
      "10: ['0.8']\n",
      "{\"question\":\"0.0955270080763441\", \"answer\": \"After extracting the final answer from the response, I found that the result is:The final answer is 9.38\"}\n",
      "10: ['9.38']\n",
      "{\"question\":\"-0.8487066790721608\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 0.78692\"}\n",
      "10: ['0.78692']\n",
      "{\"question\":\"-1.0777423840714595\", \"answer\": \"After extracting the final answer from the response, I found that the final answer is:0.6238\"}\n",
      "10: ['0.6238']\n",
      "{\"question\":\"-0.6332243537675198\", \"answer\": \"The final answer is 8.96.\"}\n",
      "10: ['8.96']\n",
      "{\"question\":\"0.2082890320894082\", \"answer\": \"The final answer is 0.2841.\"}\n",
      "10: ['0.2841']\n",
      "{\"question\":\"1.185552203219535\", \"answer\": \"The final answer is 4.8.\"}\n",
      "10: ['4.8']\n",
      "{\"question\":\"1.185552203219535\", \"answer\": \"After extracting the final answer from the response, I found:The final answer is 2.29656\"}\n",
      "10: ['2.29656']\n",
      "{\"question\":\"-0.6860814405977821\", \"answer\": \"After extracting the final answer from the response, I found that it is:The final answer is 3.45\"}\n",
      "10: ['3.45']\n",
      "{\"question\":\"0.2082890320894082\", \"answer\": \"After extracting the final answer from the response, I found that the answer is:The final answer is 4.46.\"}\n",
      "10: ['4.46']\n",
      "3.3494558505835856\n",
      "8.572 \\pm 6.770\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import json\n",
    "import re\n",
    "\n",
    "llm = 'llama'\n",
    "\n",
    "# Remove all matches from the text\n",
    "\n",
    "pattern = r'V\\d+'\n",
    "pattern2 = r'\\d+%'\n",
    "\n",
    "def mae(gt,pred):\n",
    "    gt = np.array(gt) \n",
    "    pred = np.array(pred)\n",
    "    gt = gt[~np.isnan(pred)]\n",
    "    pred = pred[~np.isnan(pred)]\n",
    "    gt = gt[np.abs(pred)<100]\n",
    "    pred  = pred[np.abs(pred)<100]\n",
    "\n",
    "    return np.mean(np.abs(gt - pred))\n",
    "eva_ls = []\n",
    "\n",
    "for sim_id in range(1,11):\n",
    "\n",
    "    with open(cwd+f'/data/table/counterfactual_answers_{sim_id}.txt', 'r') as file:    \n",
    "        anw_gt = file.readlines()\n",
    "    anw_gt = [float(a.replace('\\n', '')) for a in anw_gt]\n",
    "\n",
    "\n",
    "    answers = []\n",
    "    with open(cwd+f'/result/{llm}/table_cf_response_lu{sim_id}.txt', 'r') as file:    \n",
    "        json_data_ls = file.readlines()\n",
    "\n",
    "    # Parse the JSON data from the string\n",
    "    for js_data in json_data_ls:\n",
    "        \n",
    "        js_data = remove_quotes(js_data)\n",
    "        # js_data = js_data.replace(\"\\n\", \"\")\n",
    "\n",
    "        js_data = js_data.replace(\"\\\\\", \"\")\n",
    "        print(js_data)\n",
    "        data = json.loads(js_data)\n",
    "        # Remove all matches from the text\n",
    "\n",
    "        modified_text = re.sub(pattern, '', data['answer'])\n",
    "        modified_text = re.sub(pattern2, '', modified_text)\n",
    "        numbers  = re.findall(r\"[-+]?(?:\\d*\\.*\\d+)\",modified_text)\n",
    "        print(f'{sim_id}: {numbers}')\n",
    "        if len(numbers) == 0:\n",
    "            numbers = np.nan\n",
    "        elif len(numbers) == 1:\n",
    "            numbers = float(numbers[0])\n",
    "        else: \n",
    "            numbers_ls = []\n",
    "            try:\n",
    "                for i in numbers:\n",
    "                    numbers_ls.append(float(i))\n",
    "                numbers = np.mean(np.array(numbers_ls))\n",
    "            except ValueError:\n",
    "                numbers = np.nan\n",
    "        answers.append(numbers)\n",
    "    # print(answers)\n",
    "    print(mae(anw_gt,answers))\n",
    "    eva_ls.append(mae(anw_gt,answers))\n",
    "# eva_ls\n",
    "print(f'{np.mean(eva_ls):.3f} \\pm {np.std(eva_ls):.3f}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Causal graph reasoning: Generating D-separation questions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def text_cz(cz):\n",
    "    cz_text = ''\n",
    "    for element in cz:\n",
    "        cz_text += 'V' + str(element) \n",
    "    return cz_text\n",
    "\n",
    "\n",
    "def text_ci(ciset):\n",
    "    question_ls = []\n",
    "    for cis in ciset:\n",
    "        if len(cis[2]) == 0:\n",
    "            ci_text = f'Are V{cis[0]} and V{cis[1]} independent from each other?'\n",
    "        else:\n",
    "            cz_text =text_cz(cis[2])\n",
    "            ci_text = f'Are V{cis[0]} and V{cis[1]} conditionally independent given {cz_text}?'    \n",
    "        question_ls.append(ci_text)\n",
    "    return question_ls\n",
    "\n",
    "\n",
    "def text_dsep(ciset):\n",
    "    question_ls = []\n",
    "    for cis in ciset:\n",
    "        if len(cis[2]) == 0:\n",
    "            ci_text = f'Are V{cis[0]} and V{cis[1]} d-seperated?'\n",
    "        else:\n",
    "            cz_text =text_cz(cis[2])\n",
    "            ci_text = f'Are V{cis[0]} and V{cis[1]} d-seperated given {cz_text}?'    \n",
    "        question_ls.append(ci_text)\n",
    "    return question_ls\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.causal_eval.helper import get_sets\n",
    "dataname = 'lu'\n",
    "for sim_seed in range(1,11):\n",
    "    adj_path = parent_dir+f'/data/sim_{dataname}/{sim_seed}/generated_graph_target.csv'\n",
    "    adj_df = pd.read_csv(adj_path)\n",
    "    _,_,conditional_independent_set,_,conditional_dependent_set = get_sets(adj_df.to_numpy())\n",
    "\n",
    "    ci_sets = text_dsep(conditional_independent_set)\n",
    "    nci_set = text_dsep(conditional_dependent_set)\n",
    "    with open(cwd+f'/data/graph/{sim_seed}_questions.txt', 'w') as file:\n",
    "        for q in ci_sets:\n",
    "            file.write(q)\n",
    "            file.write('\\n')\n",
    "        for q in nci_set:\n",
    "            file.write(q)\n",
    "            file.write('\\n')\n",
    "\n",
    "    with open(cwd+f'/data/graph/{sim_seed}_answers.txt', 'w') as file:\n",
    "        for q in ci_sets:\n",
    "            file.write('yes')\n",
    "            file.write('\\n')\n",
    "        for q in nci_set:\n",
    "            file.write('no')\n",
    "            file.write('\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Knowledge discovery: Generating conditional independence questions and answers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataname = 'lu'\n",
    "for sim_seed in range(1,11):\n",
    "    adj_path = parent_dir +f'/data/sim_{dataname}/{sim_seed}/generated_graph_target.csv'\n",
    "    adj_df = pd.read_csv(adj_path)\n",
    "    _,_,conditional_independent_set,_,conditional_dependent_set = get_sets(adj_df.to_numpy())\n",
    "\n",
    "    ci_sets = text_ci(conditional_independent_set)\n",
    "    nci_set = text_ci(conditional_dependent_set)\n",
    "    with open(cwd+f'/data/table/{sim_seed}_questions.txt', 'w') as file:\n",
    "        for q in ci_sets:\n",
    "            file.write(q)\n",
    "            file.write('\\n')\n",
    "        for q in nci_set:\n",
    "            file.write(q)\n",
    "            file.write('\\n')\n",
    "\n",
    "    with open(cwd+f'/data/table/{sim_seed}_answers.txt', 'w') as file:\n",
    "        for q in ci_sets:\n",
    "            file.write('yes')\n",
    "            file.write('\\n')\n",
    "        for q in nci_set:\n",
    "            file.write('no')\n",
    "            file.write('\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Knowledge discovery: Generating causal direction questions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os,sys\n",
    "import copy\n",
    "cwd = os.path.abspath(os.path.curdir)\n",
    "sys.path.append(cwd)  # workplace\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from causallearn.graph.GraphNode import GraphNode\n",
    "from causallearn.graph.Dag import Dag\n",
    "import networkx as nx\n",
    "\n",
    "\n",
    "def ini_nodes(adj_df):\n",
    "    nodes = []\n",
    "    for i in range(len(adj_df[0,:])):\n",
    "        nodes.append(GraphNode(str(i)))\n",
    "    return nodes\n",
    "\n",
    "\n",
    "def adj2dag(adj_df):\n",
    "    G = nx.from_numpy_array(adj_df, create_using=nx.DiGraph)\n",
    "    nodes = ini_nodes(adj_df)\n",
    "    dag = Dag(nodes)\n",
    "    for i,j in list(G.edges()):\n",
    "        dag.add_directed_edge(nodes[i], nodes[j])\n",
    "    return dag,nodes\n",
    "\n",
    "def remove_edge(index_x, index_y,nodes, dag):\n",
    "    dag_rm = copy.deepcopy(dag)\n",
    "    dag_rm.remove_connecting_edge(nodes[index_x], nodes[index_y])\n",
    "    return dag_rm\n",
    "\n",
    "def get_all_xy_edges(dag,nodes):\n",
    "    x_ls = []\n",
    "    y_ls = []\n",
    "    for e in list(dag.get_graph_edges()):        \n",
    "        index_x = int(e.get_node1().get_name())\n",
    "        index_y = int(e.get_node2().get_name())\n",
    "        x_ls.append(index_x)\n",
    "        y_ls.append(index_y)\n",
    "    dir = np.array([x_ls,y_ls])\n",
    "    return dir.T\n",
    "\n",
    "def get_eva_xy_dirs(dag,nodes):\n",
    "    x_ls = []\n",
    "    y_ls = []\n",
    "    for e in list(dag.get_graph_edges()):        \n",
    "        index_x = int(e.get_node1().get_name())\n",
    "        index_y = int(e.get_node2().get_name())\n",
    "        dag_rm = remove_edge(index_x, index_y,nodes, dag)\n",
    "        # print(e.get_node1(),e.get_node2(),dag_rm.is_dseparated_from(nodes[index_x],nodes[index_y],set()))\n",
    "        if dag_rm.is_dseparated_from(nodes[index_x],nodes[index_y],set()):\n",
    "            x_ls.append(index_x)\n",
    "            y_ls.append(index_y)\n",
    "    dir = np.array([x_ls,y_ls])\n",
    "    return dir.T\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataname = 'lu'\n",
    "for sim_seed in range(1,11):\n",
    "    with open(cwd+f'/data/table/cdir_{sim_seed}_questions.txt', 'w') as file:\n",
    "        adj_path = parent_dir+f'/data/sim_{dataname}/{sim_seed}/generated_graph_target.csv'\n",
    "        adj_df = pd.read_csv(adj_path)\n",
    "        dag,nodes = adj2dag(adj_df.to_numpy())\n",
    "        xy_edges = get_all_xy_edges(dag,nodes)\n",
    "        eva_xy_dirs =  get_eva_xy_dirs(dag,nodes)\n",
    "        for pair in eva_xy_dirs:    \n",
    "            file.write(f'Between V{pair[0]} and V{pair[1]}, is V{pair[0]} the cause?\\n')\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
