{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/statsmodels/tools/_testing.py:19: FutureWarning: pandas.util.testing is deprecated. Use the functions in the public API at pandas.testing instead.\n",
      "  import pandas.util.testing as tm\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd\n",
    "from sklearn.gaussian_process import GaussianProcessRegressor\n",
    "from sklearn.gaussian_process.kernels import RBF\n",
    "from sklearn.linear_model import Ridge\n",
    "from sklearn.preprocessing import scale\n",
    "from experiments.structural_equations import *\n",
    "from experiments.data_generation import ExperimentationModel\n",
    "from dowhy.gcm  import interventional_samples\n",
    "import matplotlib.pyplot as plt\n",
    "import argparse\n",
    "import dowhy.gcm as cy\n",
    "from tqdm import tqdm\n",
    "import yaml\n",
    "import sys \n",
    "sys.path.append(\"../\")\n",
    "sys.path.append(\"../carefl\")\n",
    "from carefl.models import CAREFL\n",
    "import pickle \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# read config file from yaml \n",
    "file_path = \"../carefl/configs/fmri.yaml\"\n",
    "config = yaml.load(open(file_path), Loader=yaml.FullLoader)\n",
    "def dict2namespace(config):\n",
    "    namespace = argparse.Namespace()\n",
    "    for key, value in config.items():\n",
    "        if isinstance(value, dict):\n",
    "            new_value = dict2namespace(value)\n",
    "        else:\n",
    "            new_value = value\n",
    "        setattr(namespace, key, new_value)\n",
    "    return namespace\n",
    "config = dict2namespace(config)\n",
    "config.device = torch.device('cuda') if torch.cuda.is_available() else torch.device('cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "################################################\n",
      "Iteration 1/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:04,  2.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:03,  2.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:03,  2.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:01<00:03,  2.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:01<00:02,  3.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  3.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:02<00:01,  3.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:02<00:01,  3.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  3.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:03<00:00,  3.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:03<00:00,  2.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  3.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:04<00:00,  3.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649769\n",
      "trial                0.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                0.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 2/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:04,  3.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:00<00:03,  3.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:03,  3.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:01<00:03,  2.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:03,  2.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:02<00:01,  3.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  3.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  2.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:03<00:01,  2.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  2.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  2.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649769\n",
      "trial                1.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                1.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 3/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:04,  2.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:04,  2.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:02<00:03,  2.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:03,  2.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:03<00:01,  3.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  3.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  3.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:03<00:00,  3.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  3.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  2.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649767\n",
      "trial                2.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                2.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 4/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:03,  3.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:03,  3.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:00<00:03,  3.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:03,  3.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:01<00:02,  3.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:01<00:02,  3.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  3.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:02<00:01,  3.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:02<00:01,  3.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  3.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:03<00:00,  3.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:03<00:00,  2.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  2.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:04<00:00,  3.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.60421\n",
      "gaussian_process     0.64977\n",
      "trial                3.00000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                3.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 5/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:04,  2.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:04,  2.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:01<00:03,  2.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:02,  2.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:02<00:02,  2.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  2.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  2.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  2.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  2.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649767\n",
      "trial                4.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                4.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 6/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:04,  3.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:03,  2.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:01<00:03,  2.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:02,  2.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:02<00:01,  3.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  2.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  2.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  2.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:04<00:00,  2.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649767\n",
      "trial                5.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                5.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 7/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:05,  2.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:05,  2.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:05,  2.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:02<00:03,  2.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:02,  2.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:03<00:02,  2.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  2.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  2.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  2.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:05<00:00,  2.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.60421\n",
      "gaussian_process     0.64977\n",
      "trial                6.00000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                6.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 8/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:05,  2.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:05,  2.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:04,  2.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:02<00:03,  2.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:03,  2.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:03<00:02,  2.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  2.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:03<00:01,  2.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:04<00:00,  2.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:05<00:00,  2.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.604210\n",
      "gaussian_process     0.649771\n",
      "trial                7.000000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                7.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 9/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:03,  3.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:00<00:04,  2.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:04,  2.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:02<00:04,  2.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:03,  2.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:03<00:03,  2.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:03<00:02,  2.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:02,  2.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:04<00:01,  2.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:05<00:00,  2.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:05<00:00,  2.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:05<00:00,  2.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.60421\n",
      "gaussian_process     0.64977\n",
      "trial                8.00000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                8.000000\n",
      "dtype: float64\n",
      "################################################\n",
      "Iteration 10/10\n",
      "################################################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/14 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "  7%|▋         | 1/14 [00:00<00:06,  2.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 14%|█▍        | 2/14 [00:01<00:06,  1.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 21%|██▏       | 3/14 [00:01<00:04,  2.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 29%|██▊       | 4/14 [00:01<00:04,  2.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 5/14 [00:02<00:03,  2.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 43%|████▎     | 6/14 [00:02<00:03,  2.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 50%|█████     | 7/14 [00:02<00:02,  2.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 57%|█████▋    | 8/14 [00:03<00:02,  2.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 64%|██████▍   | 9/14 [00:03<00:01,  2.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 71%|███████▏  | 10/14 [00:04<00:01,  2.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 79%|███████▊  | 11/14 [00:04<00:01,  2.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 86%|████████▌ | 12/14 [00:05<00:00,  2.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      " 93%|█████████▎| 13/14 [00:05<00:00,  2.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/lib/python3.7/site-packages/sklearn/gaussian_process/kernels.py:427: ConvergenceWarning: The optimal value found for dimension 0 of parameter k1__constant_value is close to the specified lower bound 1e-05. Decreasing the bound and calling fit again may find a better value.\n",
      "  ConvergenceWarning,\n",
      "100%|██████████| 14/14 [00:06<00:00,  2.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "linear_regression    0.60421\n",
      "gaussian_process     0.64977\n",
      "trial                9.00000\n",
      "dtype: float64\n",
      "linear_regression    0.604529\n",
      "gaussian_process     0.674611\n",
      "trial                9.000000\n",
      "dtype: float64\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "subject_int_ids = {\n",
    "        292: {'rest': 0, 'stim': 2},\n",
    "        294: {'rest': 0, 'stim': 1},\n",
    "        302: {'rest': 0, 'stim': 1},\n",
    "        303: {'rest': 0, 'stim': 3},\n",
    "        307: {'rest': 0, 'stim': 1},\n",
    "        316: {'rest': 0, 'stim': 1},\n",
    "        320: {'rest': 0, 'stim': 1},\n",
    "        # 330:{'rest': 0, 'stim': 5},\n",
    "        352: {'rest': 0, 'stim': 1},\n",
    "        357: {'rest': 0, 'stim': 1},\n",
    "        372: {'rest': 0, 'stim': 2},\n",
    "        376: {'rest': 0, 'stim': 1},\n",
    "        # 384:{'rest': 0, 'stim': 1},\n",
    "        # 395:{'rest': 0, 'stim': 1},\n",
    "        399: {'rest': 0, 'stim': 1},\n",
    "        400: {'rest': 0, 'stim': 1},\n",
    "        403: {'rest': 0, 'stim': 1},\n",
    "        # 413:{'rest': 0, 'stim': 1}\n",
    "    }\n",
    "\n",
    "# define ROIs\n",
    "rois = np.array([28, 44])  # just take 2 ROIs for now\n",
    "rois = rois[::-1]\n",
    "params = {'num_epochs' : 500,\n",
    "              'lr' : 1e-4,\n",
    "              'batch_size': 64,\n",
    "              'hidden_dim' : 128,\n",
    "              'use_positional_encoding': False,\n",
    "              'weight_decay': 0,\n",
    "              'lambda_loss' : 0,\n",
    "              'clip': False,\n",
    "              'verbose' : False}\n",
    "\n",
    "##3 BEGIN RUNNING EXP\n",
    "all_results = None\n",
    "all_k = list(subject_int_ids.keys())\n",
    "for i in range(10):\n",
    "    print(\"################################################\")\n",
    "    print(f\"Iteration {i+1}/10\")\n",
    "    print(\"################################################\")\n",
    "    results = []\n",
    "    config.training.seed = i+10\n",
    "    config.data.seed = i+10\n",
    "    np.random.seed(i+10)\n",
    "    torch.manual_seed(i+10)\n",
    "    for k in tqdm(all_k):\n",
    "        \n",
    "        # load in data\n",
    "        print(\"\")\n",
    "        path = os.path.join('..', 'carefl', 'data', 'fmri', 'subject_data')\n",
    "        files = [f for f in os.listdir(path) if 'sub-' + str(k) + 'run' in f]\n",
    "\n",
    "        dat = [np.array(pd.read_csv(os.path.join(path, f), header=0)) for f in files]\n",
    "        scale_dat = [scale(d, with_mean=True) for d in dat]\n",
    "\n",
    "        # ------ define train/test data\n",
    "        train_dat = scale_dat[subject_int_ids[k]['rest']][:, rois]\n",
    "        intervene_dat = scale_dat[subject_int_ids[k]['stim']][:, rois]\n",
    "\n",
    "        train_df = pd.DataFrame(train_dat, columns=['x1', 'x2'])\n",
    "        # ------ run models\n",
    "        #\n",
    "        \n",
    "        # mod = CAREFL(config)\n",
    "        # mod.fit_to_sem(train_dat)\n",
    "        # xvals = intervene_dat[:, 0]\n",
    "        # int_pred = np.array([mod.predict_intervention(x, n_samples=500)[1][0, 1] for x in xvals])\n",
    "        \n",
    "        #diff_model = create_diff_model('bivariate', params)               \n",
    "\n",
    "        #cy.fit(diff_model, train_df)\n",
    "\n",
    "        xvals = intervene_dat[:, 0]\n",
    "        #int_pred = np.array([mod.predict_intervention(x, n_samples=500)[1][0, 1] for x in xvals])\n",
    "        preds = []\n",
    "        n_samp = 1000\n",
    "        \n",
    "        # for ind, x in enumerate(xvals):\n",
    "        #     samps = interventional_samples(diff_model, {\"x1\": lambda z: x}, num_samples_to_draw=n_samp)\n",
    "        #     preds.append(np.median(samps.iloc[:,1]))\n",
    "            \n",
    "        ## compare with GPs and Linear Regression\n",
    "        lm = Ridge()  # LinearRegression()\n",
    "        lm.fit(X=train_dat[:, 0].reshape((-1, 1)), y=train_dat[:, 1])\n",
    "        # kernel = C(1.0, (1e-3, 1e3)) * RBF(10, (1e-2, 1e2))\n",
    "        kernel = 1.0 * RBF(1.0)\n",
    "        gp = GaussianProcessRegressor(kernel=kernel, alpha=25, n_restarts_optimizer=10)\n",
    "        gp.fit(X=train_dat[:, 0].reshape((-1, 1)), y=train_dat[:, 1])\n",
    "\n",
    "        results_df = pd.DataFrame({\n",
    "            #'dcm': np.abs((preds) - (intervene_dat[:, 1])),\n",
    "                                    'linear_regression':\n",
    "                                        np.abs((lm.predict(xvals.reshape((-1, 1)))) - (intervene_dat[:, 1])),\n",
    "                                    'gaussian_process': \n",
    "                                        np.abs((gp.predict(xvals.reshape((-1, 1)))) - (intervene_dat[:, 1])),\n",
    "                                # 'carefl': np.abs((int_pred) - (intervene_dat[:, 1]))\n",
    "                                })\n",
    "        results_df.median(axis=0)\n",
    "        results.append(results_df.median(axis=0))\n",
    "        #print('### Subject ' + str(k))\n",
    "        #print(results_df.median(axis=0))\n",
    "\n",
    "    print('\\n\\n\\n\\n')\n",
    "    pd_results = pd.DataFrame(results)\n",
    "    pd_results[\"trial\"] = i \n",
    "    print(pd_results.abs().mean(axis=0))\n",
    "    print(pd_results.abs().median(axis=0))\n",
    "    if all_results is None:\n",
    "        all_results = pd_results\n",
    "    else:\n",
    "        all_results = pd.concat([all_results, pd_results])\n",
    "    #save pd as csv\n",
    "    all_results.to_csv(\"fmri_results_gp_lr.csv\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>carefl</th>\n",
       "      <th>trial</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.532180</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.456371</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.554691</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.468737</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.574203</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     carefl  trial\n",
       "0  0.532180      0\n",
       "1  0.456371      0\n",
       "2  0.554691      0\n",
       "3  0.468737      0\n",
       "4  0.574203      0"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_results.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>dcm</th>\n",
       "      <th>dcm2</th>\n",
       "      <th>linear_regression</th>\n",
       "      <th>gaussian_process</th>\n",
       "      <th>carefl</th>\n",
       "      <th>trial</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.556352</td>\n",
       "      <td>0.549923</td>\n",
       "      <td>0.502165</td>\n",
       "      <td>0.587379</td>\n",
       "      <td>0.537523</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.342304</td>\n",
       "      <td>0.410053</td>\n",
       "      <td>0.408466</td>\n",
       "      <td>0.358389</td>\n",
       "      <td>0.378245</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.656436</td>\n",
       "      <td>0.694555</td>\n",
       "      <td>0.670544</td>\n",
       "      <td>0.554062</td>\n",
       "      <td>0.533804</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.454214</td>\n",
       "      <td>0.397245</td>\n",
       "      <td>0.355530</td>\n",
       "      <td>0.579702</td>\n",
       "      <td>0.396807</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.556818</td>\n",
       "      <td>0.574172</td>\n",
       "      <td>0.565094</td>\n",
       "      <td>0.601470</td>\n",
       "      <td>0.545104</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0       dcm      dcm2  linear_regression  gaussian_process  \\\n",
       "0           0  0.556352  0.549923           0.502165          0.587379   \n",
       "1           1  0.342304  0.410053           0.408466          0.358389   \n",
       "2           2  0.656436  0.694555           0.670544          0.554062   \n",
       "3           3  0.454214  0.397245           0.355530          0.579702   \n",
       "4           4  0.556818  0.574172           0.565094          0.601470   \n",
       "\n",
       "     carefl  trial  \n",
       "0  0.537523      0  \n",
       "1  0.378245      0  \n",
       "2  0.533804      0  \n",
       "3  0.396807      0  \n",
       "4  0.545104      0  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_results = pd.read_csv(\"fmri_results copy.csv\")\n",
    "gp_lr_results = pd.read_csv(\"fmri_results_gp_lr.csv\")\n",
    "carefl_results = pd.read_csv(\"fmri_results_carefl.csv\")\n",
    "dcm_results.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "full_results[\"actual_carefl\"]=  carefl_results[\"carefl\"].values\n",
    "full_results[\"actual_lr\"]=  gp_lr_results[\"linear_regression\"].values\n",
    "full_results[\"actual_gp\"]=  gp_lr_results[\"gaussian_process\"].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <td>6.500000</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dcm</th>\n",
       "      <td>0.598192</td>\n",
       "      <td>9.482290e-03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dcm2</th>\n",
       "      <td>0.622353</td>\n",
       "      <td>7.714542e-03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>linear_regression</th>\n",
       "      <td>0.604529</td>\n",
       "      <td>1.170278e-16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gaussian_process</th>\n",
       "      <td>0.674610</td>\n",
       "      <td>5.038103e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>carefl</th>\n",
       "      <td>0.553435</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>trial</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_carefl</th>\n",
       "      <td>0.598359</td>\n",
       "      <td>2.981521e-02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_lr</th>\n",
       "      <td>0.604529</td>\n",
       "      <td>1.170278e-16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_gp</th>\n",
       "      <td>0.674611</td>\n",
       "      <td>4.830263e-08</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          0             1\n",
       "Unnamed: 0         6.500000  0.000000e+00\n",
       "dcm                0.598192  9.482290e-03\n",
       "dcm2               0.622353  7.714542e-03\n",
       "linear_regression  0.604529  1.170278e-16\n",
       "gaussian_process   0.674610  5.038103e-07\n",
       "carefl             0.553435  0.000000e+00\n",
       "trial              4.500000  3.027650e+00\n",
       "actual_carefl      0.598359  2.981521e-02\n",
       "actual_lr          0.604529  1.170278e-16\n",
       "actual_gp          0.674611  4.830263e-08"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grouped = full_results.groupby(\"trial\")\n",
    "all_medians = None\n",
    "for trial, group in grouped:\n",
    "    abs_pd = group\n",
    "    cur_med =abs_pd.median(axis=0) \n",
    "    if all_medians is None:\n",
    "        all_medians = cur_med\n",
    "    else:\n",
    "        all_medians = pd.concat([all_medians, cur_med], axis=1)\n",
    "pd.concat([all_medians.mean(axis=1),all_medians.std(axis=1)],axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <td>6.500000</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dcm</th>\n",
       "      <td>0.577967</td>\n",
       "      <td>1.892387e-03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dcm2</th>\n",
       "      <td>0.596570</td>\n",
       "      <td>6.067855e-03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>linear_regression</th>\n",
       "      <td>0.604210</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gaussian_process</th>\n",
       "      <td>0.649768</td>\n",
       "      <td>1.273336e-06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>carefl</th>\n",
       "      <td>0.571354</td>\n",
       "      <td>1.170278e-16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>trial</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_carefl</th>\n",
       "      <td>0.600448</td>\n",
       "      <td>2.172801e-02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_lr</th>\n",
       "      <td>0.604210</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>actual_gp</th>\n",
       "      <td>0.649769</td>\n",
       "      <td>1.423059e-06</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          0             1\n",
       "Unnamed: 0         6.500000  0.000000e+00\n",
       "dcm                0.577967  1.892387e-03\n",
       "dcm2               0.596570  6.067855e-03\n",
       "linear_regression  0.604210  0.000000e+00\n",
       "gaussian_process   0.649768  1.273336e-06\n",
       "carefl             0.571354  1.170278e-16\n",
       "trial              4.500000  3.027650e+00\n",
       "actual_carefl      0.600448  2.172801e-02\n",
       "actual_lr          0.604210  0.000000e+00\n",
       "actual_gp          0.649769  1.423059e-06"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grouped = full_results.groupby(\"trial\")\n",
    "all_means = None\n",
    "for trial, group in grouped:\n",
    "    abs_pd = group\n",
    "    cur_med =abs_pd.mean(axis=0) \n",
    "    if all_means is None:\n",
    "        all_means = cur_med\n",
    "    else:\n",
    "        all_means = pd.concat([all_means, cur_med], axis=1)\n",
    "pd.concat([all_means.mean(axis=1),all_means.std(axis=1)],axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Unnamed: 0           0.000000e+00\n",
       "dcm                  1.892387e-03\n",
       "dcm2                 6.067855e-03\n",
       "linear_regression    0.000000e+00\n",
       "gaussian_process     1.273336e-06\n",
       "carefl               1.170278e-16\n",
       "trial                3.027650e+00\n",
       "actual_carefl        2.172801e-02\n",
       "dtype: float64"
      ]
     },
     "execution_count": 117,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "int_pred = np.array([mod.predict_intervention(x, n_samples=500)[1][0, 1] for x in xvals])\n",
    "xvals = intervene_dat[:, 0]\n",
    "# int_pred = np.array([mod.predict_intervention(x, n_samples=500)[1][0, 1] for x in xvals])\n",
    "preds, preds2 = [], []\n",
    "n_samp = 1000\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([143.,  76.,  24.,   4.,   3.,   1.,   1.,   0.,   0.,   1.]),\n",
       " array([1.27587227e-03, 6.58987282e-01, 1.31669869e+00, 1.97441010e+00,\n",
       "        2.63212151e+00, 3.28983292e+00, 3.94754433e+00, 4.60525574e+00,\n",
       "        5.26296715e+00, 5.92067856e+00, 6.57838997e+00]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.abs(int_pred- intervene_dat[:, 1]),alpha=0.5)\n",
    "plt.hist(np.abs(preds1- intervene_dat[:, 1]),alpha=0.5)\n",
    "plt.hist(np.abs(preds2- intervene_dat[:, 1]),alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "means = np.array([i.mean(axis=0) for i in all_results])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "cdim                 0.585375\n",
       "cdim2                0.591621\n",
       "linear_regression    0.604210\n",
       "gaussian_process     0.649770\n",
       "dtype: float64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_results[0].mean(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle \\left( 0.577358375775052, \\  0.00625389245943597\\right)$"
      ],
      "text/plain": [
       "(0.5773583757750519, 0.006253892459435974)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(means[:,0]),np.std(means[:,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle \\left( 0.603523782001982, \\  0.0131695653506727\\right)$"
      ],
      "text/plain": [
       "(0.603523782001982, 0.013169565350672676)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(means[:1]),np.std(means[:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'means' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/p2/qjns7zj118l97lkbqykpkg7c0000gn/T/ipykernel_90647/1733647177.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mmeans\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m: name 'means' is not defined"
     ]
    }
   ],
   "source": [
    "means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "cdim                 0.201861\n",
       "cdim2                0.200678\n",
       "linear_regression    0.198173\n",
       "gaussian_process     0.136915\n",
       "dtype: float64"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_results[0].std(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cdim                 0.449119\n",
      "cdim2                0.480017\n",
      "linear_regression    0.455315\n",
      "gaussian_process     0.472884\n",
      "dtype: float64\n",
      "cdim                 0.149102\n",
      "cdim2                0.078490\n",
      "linear_regression    0.066255\n",
      "gaussian_process     0.161921\n",
      "dtype: float64\n"
     ]
    }
   ],
   "source": [
    "print(pd.DataFrame(results).mean(axis=0))\n",
    "print(pd.DataFrame(results).std(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "cdim                 0.343688\n",
       "cdim2                0.424517\n",
       "linear_regression    0.408466\n",
       "gaussian_process     0.358389\n",
       "dtype: float64"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df.median(axis=0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.4 ('base')",
   "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.7.4"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "40d3a090f54c6569ab1632332b64b2c03c39dcf918b08424e98f38b5ae0af88f"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
