{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO:\n",
    "# Interesting examples to pull out (preds are different btwn CFQI and FQI)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import sys\n",
    "sys.path.append('../simulated_fqi')\n",
    "from train_cnfqi import run\n",
    "import seaborn as sns\n",
    "import tqdm\n",
    "import matplotlib.pyplot as plt \n",
    "import numpy as np\n",
    "import configargparse\n",
    "import torch\n",
    "import torch.optim as optim\n",
    "from models.agents import NFQAgent\n",
    "from models.networks import NFQNetwork, ContrastiveNFQNetwork\n",
    "from util import get_logger, load_models, make_reproducible, save_models\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import itertools\n",
    "import pandas as pd\n",
    "import pickle\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "renal_test_tuples = pickle.load(open('mimic-iv_tuples/renal/renal_trainKtuples.pkl', 'rb'))\n",
    "renal_train_tuples = pickle.load(open('mimic-iv_tuples/renal/renal_testKtuples.pkl', 'rb'))\n",
    "regular_test_tuples = pickle.load(open('mimic-iv_tuples/renal/regular_trainKtuples.pkl', 'rb'))\n",
    "regular_train_tuples = pickle.load(open('mimic-iv_tuples/renal/regular_testKtuples.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "123"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(list(set(renal_train_tuples['vnum']))) + len(list(set(renal_test_tuples['vnum'])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3185"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(list(set(regular_train_tuples['vnum']))) + len(list(set(regular_test_tuples['vnum'])))"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "#Actions: 'none': 0, 'low2-iv': 0, 'low4-iv': 0, 'low6-iv': 0,'high1-iv': 0, 'high2-iv': 0, 'high3-iv': 0, 'low-po': 0, 'med-po': 0, 'high-po': 0\n",
    "sample_id = 20054471\n",
    "for action in female_test_tuples['a']:\n",
    "    if sum(action) != 1:\n",
    "        print(str(action))\n",
    "    else:\n",
    "        print(np.where(action==1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_rollout(vnum, tuples, group=0):\n",
    "    trajectory = []\n",
    "    for i in range(len(tuples['vnum'])):\n",
    "        vn = tuples['vnum'][i]\n",
    "        if str(vn) == str(vnum):\n",
    "            s = tuples['s'][i]\n",
    "            a = tuples['a'][i]\n",
    "            if sum(a) > 1:\n",
    "                pass\n",
    "            a = np.where(a==1)[0][0]\n",
    "            if a == 0:\n",
    "                a = [0, 0]\n",
    "            elif a in [1, 2, 3, 7, 8]:\n",
    "                a = [0, 10]\n",
    "            else:\n",
    "                a = [10, 0]\n",
    "            ns = tuples['ns'][i]\n",
    "            r = tuples['r'][i]\n",
    "            \n",
    "            trajectory.append((s, a, r, ns, False, group))\n",
    "    \n",
    "    last_tuple = trajectory[-1]\n",
    "    new_last_tuple = (last_tuple[0], last_tuple[1], last_tuple[2], last_tuple[3], True, group)\n",
    "    trajectory = trajectory[:-1]\n",
    "    trajectory.append(new_last_tuple)\n",
    "    return trajectory\n",
    "\n",
    "def rollout_dataset(ds='train', env='bg', init_experience=1000):\n",
    "    if env == 'bg':\n",
    "        rollout = []\n",
    "        if ds == 'train':\n",
    "            for vnum in regular_train_tuples['vnum'][:init_experience]:\n",
    "                traj = generate_rollout(vnum, regular_train_tuples, group=0)\n",
    "                rollout.extend(traj)\n",
    "        elif ds == 'test':\n",
    "            for vnum in regular_test_tuples['vnum'][:init_experience]:\n",
    "                traj = generate_rollout(vnum, regular_test_tuples, group=0)\n",
    "                rollout.extend(traj)\n",
    "        return rollout\n",
    "    \n",
    "    elif env == 'fg':\n",
    "        rollout = []\n",
    "        if ds == 'train':\n",
    "            for vnum in renal_train_tuples['vnum'][:init_experience]:\n",
    "                traj = generate_rollout(vnum, renal_train_tuples, group=1)\n",
    "                rollout.extend(traj)\n",
    "        elif ds == 'test':\n",
    "            for vnum in renal_test_tuples['vnum'][:init_experience]:\n",
    "                traj = generate_rollout(vnum, renal_test_tuples, group=1)\n",
    "                rollout.extend(traj)\n",
    "        return rollout\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "is_contrastive=True\n",
    "verbose = True\n",
    "init_experience = 750\n",
    "# A set of transition tuples. Male is background, female is foreground. \n",
    "bg_rollouts = rollout_dataset(ds='train', env='bg', init_experience=init_experience)\n",
    "fg_rollouts = rollout_dataset(ds='train', env='fg', init_experience=init_experience)\n",
    "\n",
    "bg_success_queue = [0] * 3\n",
    "fg_success_queue = [0] * 3\n",
    "bg_rollouts.extend(fg_rollouts)\n",
    "all_rollouts = bg_rollouts.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def normalize_rollouts(rollouts):\n",
    "    min_r = min([r[2] for r in rollouts])\n",
    "    max_r = max([r[2] for r in rollouts])\n",
    "    new_rollout = []\n",
    "    for r in rollouts:\n",
    "        new_reward = (r[2] - min_r)/(max_r - min_r)\n",
    "        new_rollout.append((r[0], r[1], new_reward, r[3], r[4], r[5]))\n",
    "    \n",
    "    sns.distplot([r[2] for r in new_rollout])\n",
    "    return new_rollout"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/amandyam/.conda/envs/research/lib/python3.6/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "all_rollouts = normalize_rollouts(all_rollouts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/amandyam/.conda/envs/research/lib/python3.6/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:ylabel='Density'>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# See what the target q_values look like\n",
    "# Network has an impact on the q-values\n",
    "nfq_net = ContrastiveNFQNetwork(state_dim=63, is_contrastive=True)\n",
    "if is_contrastive:\n",
    "    optimizer = optim.SGD(itertools.chain(nfq_net.layers_shared.parameters(), nfq_net.layers_last_shared.parameters()), lr=1e-3)\n",
    "else:\n",
    "    optimizer = optim.SGD(nfq_net.parameters(), lr=5e-3)\n",
    "nfq_agent = NFQAgent(nfq_net, optimizer)\n",
    "state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(all_rollouts)\n",
    "sns.distplot(target_q_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▋      | 728/2001 [39:00<27:33,  1.30s/it]  "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 36%|███▋      | 729/2001 [39:01<27:29,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 36%|███▋      | 730/2001 [39:03<27:41,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 731/2001 [39:04<27:29,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 732/2001 [39:05<27:38,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 733/2001 [39:06<27:16,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 734/2001 [39:08<27:27,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 735/2001 [39:09<27:36,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 736/2001 [39:10<27:08,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 737/2001 [39:12<27:29,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 738/2001 [39:13<27:34,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 739/2001 [39:14<26:59,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 740/2001 [39:16<27:10,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 741/2001 [39:17<26:45,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 742/2001 [39:18<26:55,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 743/2001 [39:19<26:32,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 744/2001 [39:21<26:41,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 745/2001 [39:22<26:55,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 746/2001 [39:23<26:33,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 747/2001 [39:24<26:45,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 748/2001 [39:26<27:04,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 749/2001 [39:27<26:40,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|███▋      | 750/2001 [39:28<26:55,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 751/2001 [39:30<26:27,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 752/2001 [39:31<26:38,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 753/2001 [39:32<26:29,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 754/2001 [39:33<26:40,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 755/2001 [39:35<26:44,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 756/2001 [39:36<26:25,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 757/2001 [39:37<26:35,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FREEZING SHARED\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 758/2001 [39:39<26:39,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 759/2001 [39:40<26:15,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 760/2001 [39:41<26:30,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 761/2001 [39:42<26:11,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 762/2001 [39:44<26:33,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 763/2001 [39:45<26:16,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 764/2001 [39:46<26:28,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 765/2001 [39:48<26:46,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 766/2001 [39:49<26:23,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 767/2001 [39:50<26:36,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 768/2001 [39:51<26:46,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 769/2001 [39:53<26:19,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███▊      | 770/2001 [39:54<26:35,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▊      | 771/2001 [39:55<26:12,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▊      | 772/2001 [39:57<26:23,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▊      | 773/2001 [39:58<26:05,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▊      | 774/2001 [39:59<26:21,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▊      | 775/2001 [40:00<26:33,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 776/2001 [40:02<26:23,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 777/2001 [40:03<26:37,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 778/2001 [40:04<26:43,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 779/2001 [40:06<26:12,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 780/2001 [40:07<26:14,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 781/2001 [40:08<25:51,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 782/2001 [40:09<26:05,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 783/2001 [40:11<25:39,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 784/2001 [40:12<25:55,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 785/2001 [40:13<26:13,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 786/2001 [40:15<25:43,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 787/2001 [40:16<25:52,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 788/2001 [40:17<26:05,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 789/2001 [40:18<25:41,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 790/2001 [40:20<25:52,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 791/2001 [40:21<25:18,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 792/2001 [40:22<25:22,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 793/2001 [40:23<25:02,  1.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 794/2001 [40:25<25:21,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 795/2001 [40:26<25:35,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 796/2001 [40:27<25:17,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 797/2001 [40:28<25:36,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 798/2001 [40:30<25:47,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 799/2001 [40:31<25:42,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|███▉      | 800/2001 [40:32<25:53,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 801/2001 [40:34<25:27,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 802/2001 [40:35<25:45,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 803/2001 [40:36<25:21,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 804/2001 [40:37<25:25,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 805/2001 [40:39<25:38,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 806/2001 [40:40<25:18,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 807/2001 [40:41<25:33,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 808/2001 [40:43<25:46,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 809/2001 [40:44<25:24,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|████      | 810/2001 [40:45<25:31,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 811/2001 [40:46<25:13,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 812/2001 [40:48<25:28,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 813/2001 [40:49<25:03,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 814/2001 [40:50<25:13,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 815/2001 [40:52<25:24,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 816/2001 [40:53<25:00,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 817/2001 [40:54<25:26,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 818/2001 [40:55<25:47,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 819/2001 [40:57<25:29,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 820/2001 [40:58<25:36,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 821/2001 [40:59<25:17,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|████      | 822/2001 [41:01<25:40,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 904/2001 [42:47<23:34,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 905/2001 [42:49<23:43,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 906/2001 [42:50<23:16,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 907/2001 [42:51<23:28,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 908/2001 [42:52<23:39,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 909/2001 [42:54<23:29,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|████▌     | 910/2001 [42:55<23:52,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 911/2001 [42:56<23:36,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 912/2001 [42:58<23:47,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 913/2001 [42:59<23:21,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 914/2001 [43:00<23:33,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 915/2001 [43:02<23:48,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 916/2001 [43:03<23:22,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 917/2001 [43:04<23:23,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 918/2001 [43:05<23:26,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 919/2001 [43:07<22:57,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 920/2001 [43:08<23:10,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 921/2001 [43:09<22:49,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 922/2001 [43:10<23:03,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 923/2001 [43:12<22:45,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 924/2001 [43:13<22:58,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▌     | 925/2001 [43:14<23:11,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▋     | 926/2001 [43:16<22:45,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▋     | 927/2001 [43:17<22:53,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▋     | 928/2001 [43:18<23:04,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▋     | 929/2001 [43:19<22:40,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|████▋     | 930/2001 [43:21<22:50,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 931/2001 [43:22<22:30,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 932/2001 [43:23<22:43,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 933/2001 [43:24<22:30,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 934/2001 [43:26<22:50,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 935/2001 [43:27<23:00,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 936/2001 [43:28<22:34,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 937/2001 [43:30<22:51,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 938/2001 [43:31<23:14,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 939/2001 [43:32<22:46,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 940/2001 [43:34<22:53,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 941/2001 [43:35<22:33,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 942/2001 [43:36<22:37,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 943/2001 [43:37<22:18,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 944/2001 [43:39<22:32,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 945/2001 [43:40<22:41,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 946/2001 [43:41<22:15,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 947/2001 [43:42<22:23,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 948/2001 [43:44<22:32,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 949/2001 [43:45<22:12,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████▋     | 950/2001 [43:46<22:27,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 951/2001 [43:48<22:07,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 952/2001 [43:49<22:21,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 953/2001 [43:50<22:02,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 954/2001 [43:51<22:13,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 955/2001 [43:53<22:20,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 956/2001 [43:54<22:15,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 957/2001 [43:55<22:39,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 958/2001 [43:57<22:59,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 959/2001 [43:58<22:44,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 960/2001 [43:59<22:46,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 961/2001 [44:00<22:24,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 962/2001 [44:02<22:47,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 963/2001 [44:03<22:21,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 964/2001 [44:04<22:26,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 965/2001 [44:06<22:34,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 966/2001 [44:07<22:13,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 967/2001 [44:08<22:25,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 968/2001 [44:10<22:31,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 969/2001 [44:11<22:07,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|████▊     | 970/2001 [44:12<22:20,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▊     | 971/2001 [44:13<22:00,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▊     | 972/2001 [44:15<22:19,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▊     | 973/2001 [44:16<22:02,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▊     | 974/2001 [44:17<22:16,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▊     | 975/2001 [44:19<22:25,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 976/2001 [44:20<22:01,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 977/2001 [44:21<22:09,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 978/2001 [44:23<22:16,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 979/2001 [44:24<22:00,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 980/2001 [44:25<22:08,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 981/2001 [44:26<22:02,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 982/2001 [44:28<22:17,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 983/2001 [44:29<21:58,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 984/2001 [44:30<22:07,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 985/2001 [44:32<22:29,  1.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 986/2001 [44:33<22:03,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 987/2001 [44:34<22:04,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 988/2001 [44:36<22:04,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 989/2001 [44:37<21:41,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|████▉     | 990/2001 [44:38<21:53,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 991/2001 [44:39<21:29,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 992/2001 [44:41<21:37,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 993/2001 [44:42<21:19,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 994/2001 [44:43<21:33,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 995/2001 [44:45<21:41,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 996/2001 [44:46<21:18,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 997/2001 [44:47<21:23,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 998/2001 [44:48<21:26,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 999/2001 [44:50<21:03,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|████▉     | 1000/2001 [44:51<21:14,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1001/2001 [44:52<20:57,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1002/2001 [44:53<21:14,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1003/2001 [44:55<20:57,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1004/2001 [44:56<21:13,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1005/2001 [44:57<21:26,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1006/2001 [44:59<21:10,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1007/2001 [45:00<21:20,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1008/2001 [45:01<21:40,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1009/2001 [45:03<21:18,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 1010/2001 [45:04<21:27,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1011/2001 [45:05<21:08,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1012/2001 [45:06<21:16,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1013/2001 [45:08<21:01,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1014/2001 [45:09<21:13,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1015/2001 [45:10<21:19,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1016/2001 [45:11<20:59,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1017/2001 [45:13<21:09,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1018/2001 [45:14<21:11,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1019/2001 [45:15<20:47,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1020/2001 [45:17<20:58,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1021/2001 [45:18<20:41,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1022/2001 [45:19<20:45,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1023/2001 [45:20<20:26,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|█████     | 1023/2001 [45:22<43:22,  2.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BG Converged\n",
      "FG Converged\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2b7413bdfcc0>]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Setup agent\n",
    "nfq_net = ContrastiveNFQNetwork(state_dim=63, is_contrastive=True)\n",
    "optimizer = optim.SGD(itertools.chain(nfq_net.layers_shared.parameters(), nfq_net.layers_last_shared.parameters()), lr=5e-4)\n",
    "\n",
    "nfq_agent = NFQAgent(nfq_net, optimizer)\n",
    "previous_loss = None\n",
    "delta = 5e-5\n",
    "count_fg = 0\n",
    "count_bg = 0\n",
    "bg_converged = False\n",
    "fg_converged = False\n",
    "\n",
    "losses = []\n",
    "epoch = 2000\n",
    "for k, epoch in enumerate(tqdm.tqdm(range(epoch + 1))):\n",
    "\n",
    "    state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(all_rollouts)\n",
    "\n",
    "    loss = nfq_agent.train((state_action_b, target_q_values, groups))\n",
    "    \n",
    "    if previous_loss is not None:\n",
    "        if abs(previous_loss - loss) < delta:\n",
    "            if not nfq_net.freeze_shared:\n",
    "                bg_converged = True\n",
    "            else:\n",
    "                fg_converged = True\n",
    "    previous_loss = loss\n",
    "    losses.append(loss)\n",
    "    \n",
    "    if is_contrastive:\n",
    "        if nfq_net.freeze_shared:\n",
    "            for param in nfq_net.layers_fg.parameters():\n",
    "                assert param.requires_grad == True\n",
    "            for param in nfq_net.layers_last_fg.parameters():\n",
    "                assert param.requires_grad == True\n",
    "            for param in nfq_net.layers_shared.parameters():\n",
    "                assert param.requires_grad == False\n",
    "            for param in nfq_net.layers_last_shared.parameters():\n",
    "                assert param.requires_grad == False\n",
    "        else:\n",
    "\n",
    "            for param in nfq_net.layers_fg.parameters():\n",
    "                assert param.requires_grad == False\n",
    "            for param in nfq_net.layers_last_fg.parameters():\n",
    "                assert param.requires_grad == False\n",
    "            for param in nfq_net.layers_shared.parameters():\n",
    "                assert param.requires_grad == True\n",
    "            for param in nfq_net.layers_last_shared.parameters():\n",
    "                assert param.requires_grad == True\n",
    "    \n",
    "    if bg_converged:\n",
    "        count_bg += 1\n",
    "        print(\"BG Converged\")\n",
    "    if bg_converged and count_bg == 30:\n",
    "        nfq_net.freeze_shared = True\n",
    "        if verbose:\n",
    "            print(\"FREEZING SHARED\")\n",
    "        if is_contrastive:\n",
    "            for param in nfq_net.layers_shared.parameters():\n",
    "                param.requires_grad = False\n",
    "            for param in nfq_net.layers_last_shared.parameters():\n",
    "                param.requires_grad = False\n",
    "            for param in nfq_net.layers_fg.parameters():\n",
    "                param.requires_grad = True\n",
    "            for param in nfq_net.layers_last_fg.parameters():\n",
    "                param.requires_grad = True\n",
    "\n",
    "            optimizer = optim.SGD(itertools.chain(nfq_net.layers_fg.parameters(), nfq_net.layers_last_fg.parameters()), lr=5e-4)\n",
    "            nfq_agent._optimizer = optimizer\n",
    "\n",
    "    if fg_converged:\n",
    "        if verbose:\n",
    "            print(\"FG Converged\")\n",
    "        count_fg += 1\n",
    "    \n",
    "    if count_fg == 50:\n",
    "        break\n",
    "\n",
    "    \n",
    "    \n",
    "plt.plot(losses)    \n",
    "    \n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation\n",
    "* The optimal levels for K are between 3.5 and 4.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def state_invtransformer(tstates, transformer='transformer.pkl'):\n",
    "    \n",
    "    scaler = pickle.load(open(transformer, 'rb'))\n",
    "    states = scaler.inverse_transform(tstates)\n",
    "    \n",
    "    return states"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "state_feats = ['anchor_age', 'patientweight', 'los', 'gender',\n",
    "       'cad', 'afib', 'chf', 'ckd', 'renal', 'paralysis', 'parathyroid',\n",
    "       'rhabdo', 'sarcoid', 'sepsis', 'expired', 'urine', 'bpdia', 'bpsys',\n",
    "       'hr', 'rr', 'spo2', 'temp', 'alt', 'aniongap', 'bun', 'cpk', 'ca',\n",
    "       'chloride', 'creatinine', 'glucose', 'hgb', 'k', 'ldh', 'mg', 'na', 'p',\n",
    "       'wbc', 'betablockers', 'ca-iv', 'ca-noniv', 'cablockers', 'dextrose',\n",
    "       'fluids', 'insulin', 'k-iv', 'hours-k-iv', 'k-noniv', 'hours-k-noniv',\n",
    "       'loopdiuretics', 'mg-iv', 'hours-mg-iv', 'mg-noniv', 'hours-mg-noniv',\n",
    "       'p-iv', 'hours-p-iv', 'p-noniv', 'hours-p-noniv', 'pnutrition',\n",
    "       'ponutrition', 'tpnutrition', 'vasopressors', 'adm-dialysis',\n",
    "       'adm-rbc']"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "rollout = generate_rollout(20054471, female_test_tuples, group=1)\n",
    "states = [r[0] for r in rollout]\n",
    "k_measurement_ind = state_feats.index('k')\n",
    "transformed_states = state_invtransformer(states)\n",
    "k_levels = [s[k_measurement_ind] for s in transformed_states]\n",
    "x = [i*6 for i in range(len(k_levels))]\n",
    "sns.lineplot(x, k_levels, label=\"K Measured\")\n",
    "plt.legend()\n",
    "plt.xlabel(\"Hours after admission\")\n",
    "plt.ylabel(\"Potassium Levels (mmol/L)\")\n"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "def un_one_hot(actions):\n",
    "    numerical_actions = []\n",
    "    for a in actions:\n",
    "        if a == [0, 0]:\n",
    "            numerical_actions.append(0)\n",
    "        elif a == [0, 10]:\n",
    "            numerical_actions.append(1)\n",
    "        elif a == [10, 0]:\n",
    "            numerical_actions.append(2)\n",
    "    return numerical_actions"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "actions = [r[1] for r in rollout]\n",
    "doctors_actions = actions\n",
    "plt.ylabel(\"Level of repletion\")\n",
    "plt.xlabel(\"Hours after admission\")\n",
    "sns.scatterplot(x, un_one_hot(actions), label='K Repletion Actions')"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "actions = np.asarray([[0, 0], [0, 10], [10, 0]])\n",
    "optimal_actions = []\n",
    "for s in states:\n",
    "    a = nfq_agent.get_best_action(s, actions, group=1)\n",
    "    optimal_actions.append(list(a))\n",
    "policy_actions = optimal_actions\n",
    "plt.ylabel(\"Level of repletion\")\n",
    "plt.xlabel(\"Hours after admission\")\n",
    "sns.scatterplot(x, un_one_hot(optimal_actions), label='K Repletion Actions')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def forward(obs, action, is_contrastive, group, nfq_agent):\n",
    "    if is_contrastive:\n",
    "        if group == 0:\n",
    "            x = nfq_agent._nfq_net.layers_shared(torch.cat([torch.FloatTensor(obs), torch.FloatTensor(a)], dim=0))\n",
    "            reward = nfq_agent._nfq_net.layers_last_shared(x)\n",
    "        else:\n",
    "            x_shared = nfq_agent._nfq_net.layers_shared(torch.cat([torch.FloatTensor(obs), torch.FloatTensor(a)], dim=0))\n",
    "            x_fg = nfq_agent._nfq_net.layers_fg(torch.cat([torch.FloatTensor(obs), torch.FloatTensor(a)], dim=0))\n",
    "            x_shared = nfq_agent._nfq_net.layers_last_shared(x_shared)\n",
    "            x_fg = nfq_agent._nfq_net.layers_last_fg(x_fg)\n",
    "            reward = x_shared + x_fg\n",
    "    else:\n",
    "        reward = nfq_agent._nfq_net(\n",
    "            torch.cat([torch.FloatTensor(obs), torch.FloatTensor(a)], dim=0), group * torch.ones(1))\n",
    "    \n",
    "    return reward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Evaluate the difference in rewards at each time step\n",
    "def evaluate(doctors_actions, policy_actions, states, group, nfq_agent):\n",
    "    doctor_reward = 0\n",
    "    policy_reward = 0\n",
    "    for (doctors_action, policy_action, state) in zip(doctors_actions, policy_actions, states):\n",
    "        reward_doctor = forward(state, doctors_action, True, group, nfq_agent).detach().cpu().numpy()[0]\n",
    "        reward_policy = forward(state, policy_action, True, group, nfq_agent).detach().cpu().numpy()[0]\n",
    "        doctor_reward += reward_doctor\n",
    "        policy_reward += reward_policy\n",
    "    \n",
    "    return policy_reward, doctor_reward - policy_reward\n",
    "\n",
    "#evaluate(doctors_actions, policy_actions, states, 1, nfq_agent)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_d_actions = []\n",
    "all_p_actions = []\n",
    "network_output = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "reward_deltas = []\n",
    "for vn in renal_test_tuples['vnum']:\n",
    "    rollout = generate_rollout(vn, renal_test_tuples, group=1)\n",
    "    states = [r[0] for r in rollout]\n",
    "    doctors_actions = [r[1] for r in rollout]\n",
    "    all_d_actions.extend(doctors_actions)\n",
    "    actions = np.asarray([[0, 0], [0, 10], [10, 0]])\n",
    "    policy_actions = []\n",
    "    for s in states:\n",
    "        a = nfq_agent.get_best_action(s, actions, group=1)\n",
    "        policy_actions.append(list(a))\n",
    "    \n",
    "    all_p_actions.extend(policy_actions)\n",
    "    \n",
    "    output, delta = evaluate(doctors_actions, policy_actions, states, 1, nfq_agent)\n",
    "    reward_deltas.append(delta)\n",
    "    network_output.append(output)\n",
    "sns.distplot(reward_deltas)\n",
    "plt.title(\"Difference in Foreground Group\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.distplot(network_output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for vn in renal_train_tuples['vnum']:\n",
    "    rollout = generate_rollout(vn, renal_train_tuples, group=1)\n",
    "    states = [r[0] for r in rollout]\n",
    "    doctors_actions = [r[1] for r in rollout]\n",
    "    all_d_actions.extend(doctors_actions)\n",
    "    actions = np.asarray([[0, 0], [0, 10], [10, 0]])\n",
    "    policy_actions = []\n",
    "    for s in states:\n",
    "        a = nfq_agent.get_best_action(s, actions, group=1)\n",
    "        policy_actions.append(list(a))\n",
    "    \n",
    "    output, delta = evaluate(doctors_actions, policy_actions, states, 1, nfq_agent)\n",
    "    print(\"Network output: \", output)\n",
    "    print(\"Reward delta; \", delta)\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "network_output = []\n",
    "reward_deltas = []\n",
    "for vn in male_test_tuples['vnum']:\n",
    "    rollout = generate_rollout(vn, male_test_tuples, group=0)\n",
    "    states = [r[0] for r in rollout]\n",
    "    doctors_actions = [r[1] for r in rollout]\n",
    "    all_d_actions.extend(doctors_actions)\n",
    "    actions = np.asarray([[0, 0], [0, 10], [10, 0]])\n",
    "    policy_actions = []\n",
    "    for s in states:\n",
    "        a = nfq_agent.get_best_action(s, actions, group=0)\n",
    "        policy_actions.append(list(a))\n",
    "    all_p_actions.extend(policy_actions)\n",
    "    \n",
    "    output, delta = evaluate(doctors_actions, policy_actions, states, 0, nfq_agent)\n",
    "    network_output.append(output)\n",
    "    reward_deltas.append(delta)\n",
    "sns.distplot(reward_deltas)\n",
    "plt.title(\"Difference in Background Group\")"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "sns.distplot(network_output)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Actions"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "sns.distplot(un_one_hot(all_d_actions), label='Doctors Actions')\n",
    "sns.distplot(un_one_hot(all_p_actions), label='Optimal Policy Actions')\n",
    "plt.legend()\n",
    "plt.xlabel(\"Action\")"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "all_doctors_train_actions = []\n",
    "for vn in male_train_tuples['vnum']:\n",
    "    rollout = generate_rollout(vn, male_train_tuples, group=0)\n",
    "    states = [r[0] for r in rollout]\n",
    "    doctors_actions = [r[1] for r in rollout]\n",
    "    all_doctors_train_actions.extend(doctors_actions)\n",
    "for vn in female_train_tuples['vnum']:\n",
    "    rollout = generate_rollout(vn, female_train_tuples, group=1)\n",
    "    states = [r[0] for r in rollout]\n",
    "    doctors_actions = [r[1] for r in rollout]\n",
    "    all_doctors_train_actions.extend(doctors_actions)\n",
    "sns.distplot(un_one_hot(all_doctors_train_actions), label='Doctors Actions')\n",
    "plt.legend()\n",
    "plt.xlabel(\"Action\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Heatmap of Actions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gather_repletion_levels(doctor=False, renal=False, num_samples=1000):\n",
    "    no_repletion = []\n",
    "    lo_repletion = []\n",
    "    hi_repletion = []\n",
    "    c_levels = []\n",
    "    if renal:\n",
    "        tuples = renal_test_tuples\n",
    "        group = 1\n",
    "    else:\n",
    "        tuples=regular_test_tuples\n",
    "        group = 0\n",
    "    for j, vn in enumerate(tqdm.tqdm(tuples['vnum'][:num_samples])):\n",
    "        rollout = generate_rollout(vn, tuples, group=group)\n",
    "        states = [r[0] for r in rollout]\n",
    "        k_measurement_ind = state_feats.index('k')\n",
    "        c_ind = state_feats.index('creatinine')\n",
    "        doctors_actions = [r[1] for r in rollout]\n",
    "        actions = np.asarray([[0, 0], [0, 10], [10, 0]])\n",
    "        for s in states:\n",
    "            transformed_state = state_invtransformer(s)\n",
    "            k = transformed_state[k_measurement_ind]\n",
    "            creatinine = transformed_state[c_ind]\n",
    "            c_levels.append(creatinine)\n",
    "            a = nfq_agent.get_best_action(s, actions, group=group)\n",
    "            a = list(a)\n",
    "            if a == [0, 0]:\n",
    "                no_repletion.append((creatinine, k))\n",
    "            elif a == [0, 10]:\n",
    "                lo_repletion.append((creatinine, k))\n",
    "            elif a == [10, 0]:\n",
    "                hi_repletion.append((creatinine, k))\n",
    "    c_levels = [i for i in range(0, 11)]\n",
    "    measurements = [i/10 for i in range(26, 75)]\n",
    "    viz = np.zeros((len(c_levels), len(measurements)))\n",
    "    counts = np.zeros((len(c_levels), len(measurements)))\n",
    "    for (c, measurement) in no_repletion:\n",
    "        measurement = round(measurement, 1)\n",
    "        c = round(c, 0)\n",
    "        c = c_levels.index(c)\n",
    "        new_meas = measurements.index(measurement)\n",
    "        viz[c, new_meas] += 0\n",
    "        counts[c, new_meas] += 1\n",
    "    for (c, measurement) in lo_repletion:\n",
    "        measurement = round(measurement, 1)\n",
    "        c = round(c, 0)\n",
    "        c = c_levels.index(c)\n",
    "        new_meas = measurements.index(measurement)\n",
    "        viz[c, new_meas] += 1\n",
    "        counts[c, new_meas] += 1\n",
    "    for (c, measurement) in hi_repletion:\n",
    "        measurement = round(measurement, 1)\n",
    "        c = round(c, 0)\n",
    "        c = c_levels.index(c)\n",
    "        new_meas = measurements.index(measurement)\n",
    "        viz[c, new_meas] += 2\n",
    "        counts[c, new_meas] += 1\n",
    "\n",
    "    viz = np.divide(viz, counts, out=np.full_like(viz, np.nan), where=counts!=0)\n",
    "    return viz, measurements, c_levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "viz, measurements, ages = gather_repletion_levels(renal=False)\n",
    "plt.figure(figsize=(14, 5))\n",
    "sns.heatmap(viz, xticklabels=measurements, yticklabels=ages)\n",
    "plt.ylabel(\"Creatinine\")\n",
    "plt.xlabel(\"Potassium Level in Blood (mmol/L)\")\n",
    "plt.title(\"Evaluating Regular Patients\")\n",
    "viz, measurements, ages = gather_repletion_levels(renal=True)\n",
    "plt.figure(figsize=(14, 5))\n",
    "sns.heatmap(viz, xticklabels=measurements, yticklabels=ages)\n",
    "plt.ylabel(\"Creatinine\")\n",
    "plt.xlabel(\"Potassium Level in Blood (mmol/L)\")\n",
    "plt.title(\"Evaluating Renal Patients\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# SHAP plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import shap\n",
    "state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(all_rollouts)\n",
    "X = (state_action_b, target_q_values)\n",
    "\n",
    "bg_rollouts = rollout_dataset(ds='test', env='bg', init_experience=init_experience)\n",
    "fg_rollouts = rollout_dataset(ds='test', env='fg', init_experience=init_experience)\n",
    "bg_rollouts.extend(fg_rollouts)\n",
    "all_rollouts = bg_rollouts.copy()\n",
    "all_rollouts = normalize_rollouts(all_rollouts)\n",
    "state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(all_rollouts)\n",
    "X_test = (state_action_b, target_q_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Shap Values: Foreground')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x468 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "group_0 = []\n",
    "group_1 = []\n",
    "for x, g in zip(X_test[0], X_test[1]):\n",
    "    if g == 0:\n",
    "        group_0.append(x.cpu().detach().numpy())\n",
    "    else:\n",
    "        group_1.append(x.cpu().detach().numpy())\n",
    "group_0 = torch.Tensor(np.asarray(group_0))\n",
    "group_1 = torch.Tensor(np.asarray(group_1))\n",
    "e = shap.DeepExplainer(nfq_agent._nfq_net, X[0])\n",
    "shap_values = e.shap_values(group_1[:10])\n",
    "explanation = shap.Explanation(shap_values)\n",
    "shap.plots.bar(shap.Explanation(shap_values), show=False)\n",
    "plt.title(\"Shap Values: Foreground\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "research [~/.conda/envs/research/]",
   "language": "python",
   "name": "conda_research"
  },
  "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.6.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
