{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import configargparse\n",
    "import torch\n",
    "import torch.optim as optim\n",
    "\n",
    "from environments import CartPoleRegulatorEnv\n",
    "from environments import CartEnv\n",
    "from environments import AcrobotEnv\n",
    "from models.agents import NFQAgent\n",
    "from models.networks import NFQNetwork, ContrastiveNFQNetwork\n",
    "from util import get_logger, close_logger, load_models, make_reproducible, save_models\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import itertools\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/amandyam/.conda/envs/research/lib/python3.6/site-packages/gym/logger.py:30: UserWarning: \u001b[33mWARN: Box bound precision lowered by casting to float32\u001b[0m\n",
      "  warnings.warn(colorize('%s: %s'%('WARN', msg % args), 'yellow'))\n"
     ]
    }
   ],
   "source": [
    "# Setup environment\n",
    "bg_cart_mass = 1.0\n",
    "fg_cart_mass = 1.0\n",
    "init_experience = 400\n",
    "force_left = 5\n",
    "is_contrastive = False\n",
    "\n",
    "train_env_bg = CartPoleRegulatorEnv(group=0, masscart=bg_cart_mass, mode=\"train\", force_left=force_left, is_contrastive=is_contrastive)\n",
    "train_env_fg = CartPoleRegulatorEnv(group=1, masscart=fg_cart_mass, mode=\"train\", force_left=force_left, is_contrastive=is_contrastive)\n",
    "eval_env_bg = CartPoleRegulatorEnv(group=0, masscart=bg_cart_mass, mode=\"eval\", force_left=force_left, is_contrastive=is_contrastive)\n",
    "eval_env_fg = CartPoleRegulatorEnv(group=1, masscart=fg_cart_mass, mode=\"eval\", force_left=force_left, is_contrastive=is_contrastive)\n",
    "\n",
    "# NFQ Main loop\n",
    "bg_rollouts = []\n",
    "fg_rollouts = []\n",
    "total_cost = 0\n",
    "if init_experience > 0:\n",
    "    for _ in range(init_experience):\n",
    "        rollout_bg, episode_cost = train_env_bg.generate_rollout(\n",
    "            None, render=False, group=0\n",
    "        )\n",
    "        rollout_fg, episode_cost = train_env_fg.generate_rollout(\n",
    "            None, render=False, group=1\n",
    "        )\n",
    "        bg_rollouts.extend(rollout_bg)\n",
    "        fg_rollouts.extend(rollout_fg)\n",
    "        total_cost += episode_cost\n",
    "\n",
    "bg_rollouts.extend(fg_rollouts)\n",
    "all_rollouts = bg_rollouts.copy()\n",
    "\n",
    "bg_rollouts_test = []\n",
    "fg_rollouts_test = []\n",
    "if init_experience > 0:\n",
    "    for _ in range(init_experience):\n",
    "        rollout_bg, episode_cost = eval_env_bg.generate_rollout(\n",
    "            None, render=False, group=0\n",
    "        )\n",
    "        rollout_fg, episode_cost = eval_env_fg.generate_rollout(\n",
    "            None, render=False, group=1\n",
    "        )\n",
    "        bg_rollouts_test.extend(rollout_bg)\n",
    "        fg_rollouts_test.extend(rollout_fg)\n",
    "bg_rollouts_test.extend(fg_rollouts)\n",
    "all_rollouts_test = bg_rollouts_test.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 0 BG Converged: False Eval BG: 20 Eval FG: 0\n",
      "Epoch: 1 BG Converged: False Eval BG: 20 Eval FG: 0\n",
      "Epoch: 2 BG Converged: False Eval BG: 31 Eval FG: 0\n",
      "Epoch: 3 BG Converged: False Eval BG: 48 Eval FG: 0\n",
      "Epoch: 4 BG Converged: False Eval BG: 68 Eval FG: 0\n",
      "Epoch: 5 BG Converged: False Eval BG: 57 Eval FG: 0\n",
      "Epoch: 6 BG Converged: False Eval BG: 33 Eval FG: 0\n",
      "Epoch: 7 BG Converged: False Eval BG: 26 Eval FG: 0\n",
      "Epoch: 8 BG Converged: False Eval BG: 25 Eval FG: 0\n",
      "Epoch: 9 BG Converged: False Eval BG: 22 Eval FG: 0\n",
      "Epoch: 10 BG Converged: False Eval BG: 22 Eval FG: 0\n",
      "Epoch: 11 BG Converged: False Eval BG: 20 Eval FG: 0\n",
      "Epoch: 12 BG Converged: False Eval BG: 29 Eval FG: 0\n",
      "Epoch: 13 BG Converged: False Eval BG: 34 Eval FG: 0\n",
      "Epoch: 14 BG Converged: False Eval BG: 86 Eval FG: 0\n",
      "Epoch: 15 BG Converged: False Eval BG: 54 Eval FG: 0\n",
      "Epoch: 16 BG Converged: False Eval BG: 60 Eval FG: 0\n",
      "Epoch: 17 BG Converged: False Eval BG: 51 Eval FG: 0\n",
      "Epoch: 18 BG Converged: False Eval BG: 50 Eval FG: 0\n",
      "Epoch: 19 BG Converged: False Eval BG: 44 Eval FG: 0\n",
      "Epoch: 20 BG Converged: False Eval BG: 104 Eval FG: 0\n",
      "Epoch: 21 BG Converged: False Eval BG: 42 Eval FG: 0\n",
      "Epoch: 22 BG Converged: False Eval BG: 35 Eval FG: 0\n",
      "Epoch: 23 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 24 BG Converged: False Eval BG: 40 Eval FG: 0\n",
      "Epoch: 25 BG Converged: False Eval BG: 45 Eval FG: 0\n",
      "Epoch: 26 BG Converged: False Eval BG: 36 Eval FG: 0\n",
      "Epoch: 27 BG Converged: False Eval BG: 32 Eval FG: 0\n",
      "Epoch: 28 BG Converged: False Eval BG: 56 Eval FG: 0\n",
      "Epoch: 29 BG Converged: False Eval BG: 51 Eval FG: 0\n",
      "Epoch: 30 BG Converged: False Eval BG: 35 Eval FG: 0\n",
      "Epoch: 31 BG Converged: False Eval BG: 47 Eval FG: 0\n",
      "Epoch: 32 BG Converged: False Eval BG: 36 Eval FG: 0\n",
      "Epoch: 33 BG Converged: False Eval BG: 53 Eval FG: 0\n",
      "Epoch: 34 BG Converged: False Eval BG: 52 Eval FG: 0\n",
      "Epoch: 35 BG Converged: False Eval BG: 64 Eval FG: 0\n",
      "Epoch: 36 BG Converged: False Eval BG: 50 Eval FG: 0\n",
      "Epoch: 37 BG Converged: False Eval BG: 48 Eval FG: 0\n",
      "Epoch: 38 BG Converged: False Eval BG: 51 Eval FG: 0\n",
      "Epoch: 39 BG Converged: False Eval BG: 51 Eval FG: 0\n",
      "Epoch: 40 BG Converged: False Eval BG: 28 Eval FG: 0\n",
      "Epoch: 41 BG Converged: False Eval BG: 26 Eval FG: 0\n",
      "Epoch: 42 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 43 BG Converged: False Eval BG: 48 Eval FG: 0\n",
      "Epoch: 44 BG Converged: False Eval BG: 69 Eval FG: 0\n",
      "Epoch: 45 BG Converged: False Eval BG: 27 Eval FG: 0\n",
      "Epoch: 46 BG Converged: False Eval BG: 58 Eval FG: 0\n",
      "Epoch: 47 BG Converged: False Eval BG: 40 Eval FG: 0\n",
      "Epoch: 48 BG Converged: False Eval BG: 53 Eval FG: 0\n",
      "Epoch: 49 BG Converged: False Eval BG: 34 Eval FG: 0\n",
      "Epoch: 50 BG Converged: False Eval BG: 27 Eval FG: 0\n",
      "Epoch: 51 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 52 BG Converged: False Eval BG: 25 Eval FG: 0\n",
      "Epoch: 53 BG Converged: False Eval BG: 43 Eval FG: 0\n",
      "Epoch: 54 BG Converged: False Eval BG: 62 Eval FG: 0\n",
      "Epoch: 55 BG Converged: False Eval BG: 35 Eval FG: 0\n",
      "Epoch: 56 BG Converged: False Eval BG: 53 Eval FG: 0\n",
      "Epoch: 57 BG Converged: False Eval BG: 22 Eval FG: 0\n",
      "Epoch: 58 BG Converged: False Eval BG: 22 Eval FG: 0\n",
      "Epoch: 59 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 60 BG Converged: False Eval BG: 25 Eval FG: 0\n",
      "Epoch: 61 BG Converged: False Eval BG: 73 Eval FG: 0\n",
      "Epoch: 62 BG Converged: False Eval BG: 45 Eval FG: 0\n",
      "Epoch: 63 BG Converged: False Eval BG: 77 Eval FG: 0\n",
      "Epoch: 64 BG Converged: False Eval BG: 68 Eval FG: 0\n",
      "Epoch: 65 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 66 BG Converged: False Eval BG: 56 Eval FG: 0\n",
      "Epoch: 67 BG Converged: False Eval BG: 93 Eval FG: 0\n",
      "Epoch: 68 BG Converged: False Eval BG: 58 Eval FG: 0\n",
      "Epoch: 69 BG Converged: False Eval BG: 25 Eval FG: 0\n",
      "Epoch: 70 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 71 BG Converged: False Eval BG: 20 Eval FG: 0\n",
      "Epoch: 72 BG Converged: False Eval BG: 25 Eval FG: 0\n",
      "Epoch: 73 BG Converged: False Eval BG: 23 Eval FG: 0\n",
      "Epoch: 74 BG Converged: False Eval BG: 27 Eval FG: 0\n",
      "Epoch: 75 BG Converged: False Eval BG: 20 Eval FG: 0\n",
      "Epoch: 76 BG Converged: False Eval BG: 23 Eval FG: 0\n",
      "Epoch: 77 BG Converged: False Eval BG: 23 Eval FG: 0\n",
      "Epoch: 78 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 79 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 80 BG Converged: False Eval BG: 26 Eval FG: 0\n",
      "Epoch: 81 BG Converged: False Eval BG: 28 Eval FG: 0\n",
      "Epoch: 82 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 83 BG Converged: False Eval BG: 21 Eval FG: 0\n",
      "Epoch: 84 BG Converged: False Eval BG: 32 Eval FG: 0\n",
      "Epoch: 85 BG Converged: False Eval BG: 45 Eval FG: 0\n",
      "Epoch: 86 BG Converged: False Eval BG: 44 Eval FG: 0\n",
      "Epoch: 87 BG Converged: False Eval BG: 44 Eval FG: 0\n",
      "Epoch: 88 BG Converged: False Eval BG: 33 Eval FG: 0\n",
      "Epoch: 89 BG Converged: False Eval BG: 33 Eval FG: 0\n",
      "Epoch: 90 BG Converged: False Eval BG: 43 Eval FG: 0\n",
      "Epoch: 91 BG Converged: False Eval BG: 47 Eval FG: 0\n",
      "Epoch: 92 BG Converged: False Eval BG: 48 Eval FG: 0\n",
      "Epoch: 93 BG Converged: False Eval BG: 42 Eval FG: 0\n",
      "Epoch: 94 BG Converged: False Eval BG: 49 Eval FG: 0\n",
      "Epoch: 95 BG Converged: False Eval BG: 40 Eval FG: 0\n",
      "Epoch: 96 BG Converged: False Eval BG: 46 Eval FG: 0\n",
      "Epoch: 97 BG Converged: False Eval BG: 34 Eval FG: 0\n",
      "Epoch: 98 BG Converged: False Eval BG: 40 Eval FG: 0\n",
      "Epoch: 99 BG Converged: False Eval BG: 46 Eval FG: 0\n",
      "Epoch: 100 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 101 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 102 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 103 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 104 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 105 BG Converged: False Eval BG: 38 Eval FG: 0\n",
      "Epoch: 106 BG Converged: False Eval BG: 86 Eval FG: 0\n",
      "Epoch: 107 BG Converged: False Eval BG: 71 Eval FG: 0\n",
      "Epoch: 108 BG Converged: False Eval BG: 69 Eval FG: 0\n",
      "Epoch: 109 BG Converged: False Eval BG: 88 Eval FG: 0\n",
      "Epoch: 110 BG Converged: False Eval BG: 73 Eval FG: 0\n",
      "Epoch: 111 BG Converged: False Eval BG: 87 Eval FG: 0\n",
      "Epoch: 112 BG Converged: False Eval BG: 73 Eval FG: 0\n",
      "Epoch: 113 BG Converged: False Eval BG: 130 Eval FG: 0\n",
      "Epoch: 114 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 115 BG Converged: False Eval BG: 67 Eval FG: 0\n",
      "Epoch: 116 BG Converged: False Eval BG: 58 Eval FG: 0\n",
      "Epoch: 117 BG Converged: False Eval BG: 52 Eval FG: 0\n",
      "Epoch: 118 BG Converged: False Eval BG: 497 Eval FG: 0\n",
      "Epoch: 119 BG Converged: False Eval BG: 78 Eval FG: 0\n",
      "Epoch: 120 BG Converged: False Eval BG: 126 Eval FG: 0\n",
      "Epoch: 121 BG Converged: False Eval BG: 75 Eval FG: 0\n",
      "Epoch: 122 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 123 BG Converged: False Eval BG: 207 Eval FG: 0\n",
      "Epoch: 124 BG Converged: False Eval BG: 109 Eval FG: 0\n",
      "Epoch: 125 BG Converged: False Eval BG: 188 Eval FG: 0\n",
      "Epoch: 126 BG Converged: False Eval BG: 93 Eval FG: 0\n",
      "Epoch: 127 BG Converged: False Eval BG: 82 Eval FG: 0\n",
      "Epoch: 128 BG Converged: False Eval BG: 96 Eval FG: 0\n",
      "Epoch: 129 BG Converged: False Eval BG: 75 Eval FG: 0\n",
      "Epoch: 130 BG Converged: False Eval BG: 52 Eval FG: 0\n",
      "Epoch: 131 BG Converged: False Eval BG: 81 Eval FG: 0\n",
      "Epoch: 132 BG Converged: False Eval BG: 67 Eval FG: 0\n",
      "Epoch: 133 BG Converged: False Eval BG: 55 Eval FG: 0\n",
      "Epoch: 134 BG Converged: False Eval BG: 94 Eval FG: 0\n",
      "Epoch: 135 BG Converged: False Eval BG: 64 Eval FG: 0\n",
      "Epoch: 136 BG Converged: False Eval BG: 75 Eval FG: 0\n",
      "Epoch: 137 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 138 BG Converged: False Eval BG: 96 Eval FG: 0\n",
      "Epoch: 139 BG Converged: False Eval BG: 75 Eval FG: 0\n",
      "Epoch: 140 BG Converged: False Eval BG: 55 Eval FG: 0\n",
      "Epoch: 141 BG Converged: False Eval BG: 81 Eval FG: 0\n",
      "Epoch: 142 BG Converged: False Eval BG: 52 Eval FG: 0\n",
      "Epoch: 143 BG Converged: False Eval BG: 57 Eval FG: 0\n",
      "Epoch: 144 BG Converged: False Eval BG: 123 Eval FG: 0\n",
      "Epoch: 145 BG Converged: False Eval BG: 71 Eval FG: 0\n",
      "Epoch: 146 BG Converged: False Eval BG: 122 Eval FG: 0\n",
      "Epoch: 147 BG Converged: False Eval BG: 157 Eval FG: 0\n",
      "Epoch: 148 BG Converged: False Eval BG: 109 Eval FG: 0\n",
      "Epoch: 149 BG Converged: False Eval BG: 78 Eval FG: 0\n",
      "Epoch: 150 BG Converged: False Eval BG: 69 Eval FG: 0\n",
      "Epoch: 151 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 152 BG Converged: False Eval BG: 71 Eval FG: 0\n",
      "Epoch: 153 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 154 BG Converged: False Eval BG: 79 Eval FG: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 155 BG Converged: False Eval BG: 128 Eval FG: 0\n",
      "Epoch: 156 BG Converged: False Eval BG: 85 Eval FG: 0\n",
      "Epoch: 157 BG Converged: False Eval BG: 67 Eval FG: 0\n",
      "Epoch: 158 BG Converged: False Eval BG: 135 Eval FG: 0\n",
      "Epoch: 159 BG Converged: False Eval BG: 152 Eval FG: 0\n",
      "Epoch: 160 BG Converged: False Eval BG: 77 Eval FG: 0\n",
      "Epoch: 161 BG Converged: False Eval BG: 88 Eval FG: 0\n",
      "Epoch: 162 BG Converged: False Eval BG: 105 Eval FG: 0\n",
      "Epoch: 163 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 164 BG Converged: False Eval BG: 602 Eval FG: 0\n",
      "Epoch: 165 BG Converged: False Eval BG: 83 Eval FG: 0\n",
      "Epoch: 166 BG Converged: False Eval BG: 136 Eval FG: 0\n",
      "Epoch: 167 BG Converged: False Eval BG: 83 Eval FG: 0\n",
      "Epoch: 168 BG Converged: False Eval BG: 115 Eval FG: 0\n",
      "Epoch: 169 BG Converged: False Eval BG: 56 Eval FG: 0\n",
      "Epoch: 170 BG Converged: False Eval BG: 122 Eval FG: 0\n",
      "Epoch: 171 BG Converged: False Eval BG: 183 Eval FG: 0\n",
      "Epoch: 172 BG Converged: False Eval BG: 131 Eval FG: 0\n",
      "Epoch: 173 BG Converged: False Eval BG: 143 Eval FG: 0\n",
      "Epoch: 174 BG Converged: False Eval BG: 101 Eval FG: 0\n",
      "Epoch: 175 BG Converged: False Eval BG: 87 Eval FG: 0\n",
      "Epoch: 176 BG Converged: False Eval BG: 129 Eval FG: 0\n",
      "Epoch: 177 BG Converged: False Eval BG: 151 Eval FG: 0\n",
      "Epoch: 178 BG Converged: False Eval BG: 73 Eval FG: 0\n",
      "Epoch: 179 BG Converged: False Eval BG: 83 Eval FG: 0\n",
      "Epoch: 180 BG Converged: False Eval BG: 73 Eval FG: 0\n",
      "Epoch: 181 BG Converged: False Eval BG: 64 Eval FG: 0\n",
      "Epoch: 182 BG Converged: False Eval BG: 59 Eval FG: 0\n",
      "Epoch: 183 BG Converged: False Eval BG: 105 Eval FG: 0\n",
      "Epoch: 184 BG Converged: False Eval BG: 125 Eval FG: 0\n",
      "Epoch: 185 BG Converged: False Eval BG: 64 Eval FG: 0\n",
      "Epoch: 186 BG Converged: False Eval BG: 118 Eval FG: 0\n",
      "Epoch: 187 BG Converged: False Eval BG: 127 Eval FG: 0\n",
      "Epoch: 188 BG Converged: False Eval BG: 58 Eval FG: 0\n",
      "Epoch: 189 BG Converged: False Eval BG: 70 Eval FG: 0\n",
      "Epoch: 190 BG Converged: False Eval BG: 114 Eval FG: 0\n",
      "Epoch: 191 BG Converged: False Eval BG: 127 Eval FG: 0\n",
      "Epoch: 192 BG Converged: False Eval BG: 91 Eval FG: 0\n",
      "Epoch: 193 BG Converged: False Eval BG: 127 Eval FG: 0\n",
      "Epoch: 194 BG Converged: False Eval BG: 122 Eval FG: 0\n",
      "Epoch: 195 BG Converged: False Eval BG: 116 Eval FG: 0\n",
      "Epoch: 196 BG Converged: False Eval BG: 124 Eval FG: 0\n",
      "Epoch: 197 BG Converged: False Eval BG: 533 Eval FG: 0\n",
      "Epoch: 198 BG Converged: False Eval BG: 432 Eval FG: 0\n",
      "Epoch: 199 BG Converged: False Eval BG: 115 Eval FG: 0\n",
      "Epoch: 200 BG Converged: False Eval BG: 97 Eval FG: 0\n",
      "Epoch: 201 BG Converged: False Eval BG: 220 Eval FG: 0\n",
      "Epoch: 202 BG Converged: False Eval BG: 156 Eval FG: 0\n",
      "Epoch: 203 BG Converged: False Eval BG: 133 Eval FG: 0\n",
      "Epoch: 204 BG Converged: False Eval BG: 182 Eval FG: 0\n",
      "Epoch: 205 BG Converged: False Eval BG: 173 Eval FG: 0\n",
      "Epoch: 206 BG Converged: False Eval BG: 148 Eval FG: 0\n",
      "Epoch: 207 BG Converged: False Eval BG: 194 Eval FG: 0\n",
      "Epoch: 208 BG Converged: False Eval BG: 151 Eval FG: 0\n",
      "Epoch: 209 BG Converged: False Eval BG: 169 Eval FG: 0\n",
      "Epoch: 210 BG Converged: False Eval BG: 162 Eval FG: 0\n",
      "Epoch: 211 BG Converged: False Eval BG: 96 Eval FG: 0\n",
      "Epoch: 212 BG Converged: False Eval BG: 72 Eval FG: 0\n",
      "Epoch: 213 BG Converged: False Eval BG: 60 Eval FG: 0\n",
      "Epoch: 214 BG Converged: False Eval BG: 58 Eval FG: 0\n",
      "Epoch: 215 BG Converged: False Eval BG: 69 Eval FG: 0\n",
      "Epoch: 216 BG Converged: False Eval BG: 90 Eval FG: 0\n",
      "Epoch: 217 BG Converged: False Eval BG: 94 Eval FG: 0\n",
      "Epoch: 218 BG Converged: False Eval BG: 75 Eval FG: 0\n",
      "Epoch: 219 BG Converged: False Eval BG: 84 Eval FG: 0\n",
      "Epoch: 220 BG Converged: False Eval BG: 100 Eval FG: 0\n",
      "Epoch: 221 BG Converged: False Eval BG: 90 Eval FG: 0\n",
      "Epoch: 222 BG Converged: False Eval BG: 111 Eval FG: 0\n",
      "Epoch: 223 BG Converged: False Eval BG: 133 Eval FG: 0\n",
      "Epoch: 224 BG Converged: False Eval BG: 131 Eval FG: 0\n",
      "Epoch: 225 BG Converged: False Eval BG: 127 Eval FG: 0\n",
      "Epoch: 226 BG Converged: False Eval BG: 143 Eval FG: 0\n",
      "Epoch: 227 BG Converged: False Eval BG: 59 Eval FG: 0\n",
      "Epoch: 228 BG Converged: False Eval BG: 148 Eval FG: 0\n",
      "Epoch: 229 BG Converged: False Eval BG: 109 Eval FG: 0\n",
      "Epoch: 230 BG Converged: False Eval BG: 74 Eval FG: 0\n",
      "Epoch: 231 BG Converged: False Eval BG: 52 Eval FG: 0\n",
      "Epoch: 232 BG Converged: False Eval BG: 87 Eval FG: 0\n",
      "Epoch: 233 BG Converged: False Eval BG: 83 Eval FG: 0\n",
      "Epoch: 234 BG Converged: False Eval BG: 61 Eval FG: 0\n",
      "Epoch: 235 BG Converged: False Eval BG: 90 Eval FG: 0\n",
      "Epoch: 236 BG Converged: False Eval BG: 63 Eval FG: 0\n",
      "Epoch: 237 BG Converged: False Eval BG: 66 Eval FG: 0\n",
      "Epoch: 238 BG Converged: False Eval BG: 85 Eval FG: 0\n",
      "Epoch: 239 BG Converged: False Eval BG: 85 Eval FG: 0\n",
      "Epoch: 240 BG Converged: False Eval BG: 80 Eval FG: 0\n",
      "Epoch: 241 BG Converged: False Eval BG: 84 Eval FG: 0\n",
      "Epoch: 242 BG Converged: False Eval BG: 96 Eval FG: 0\n",
      "Epoch: 243 BG Converged: False Eval BG: 95 Eval FG: 0\n",
      "Epoch: 244 BG Converged: False Eval BG: 77 Eval FG: 0\n",
      "Epoch: 245 BG Converged: False Eval BG: 71 Eval FG: 0\n",
      "Epoch: 246 BG Converged: False Eval BG: 90 Eval FG: 0\n",
      "Epoch: 247 BG Converged: False Eval BG: 99 Eval FG: 0\n",
      "Epoch: 248 BG Converged: False Eval BG: 72 Eval FG: 0\n",
      "Epoch: 249 BG Converged: False Eval BG: 62 Eval FG: 0\n",
      "Epoch: 250 BG Converged: False Eval BG: 65 Eval FG: 0\n",
      "Epoch: 251 BG Converged: False Eval BG: 89 Eval FG: 0\n",
      "Epoch: 252 BG Converged: False Eval BG: 165 Eval FG: 0\n",
      "Epoch: 253 BG Converged: False Eval BG: 184 Eval FG: 0\n",
      "Epoch: 254 BG Converged: False Eval BG: 161 Eval FG: 0\n",
      "Epoch: 255 BG Converged: False Eval BG: 114 Eval FG: 0\n",
      "Epoch: 256 BG Converged: False Eval BG: 224 Eval FG: 0\n",
      "Epoch: 257 BG Converged: False Eval BG: 184 Eval FG: 0\n",
      "Epoch: 258 BG Converged: False Eval BG: 216 Eval FG: 0\n",
      "Epoch: 259 BG Converged: False Eval BG: 185 Eval FG: 0\n",
      "Epoch: 260 BG Converged: False Eval BG: 123 Eval FG: 0\n",
      "Epoch: 261 BG Converged: False Eval BG: 183 Eval FG: 0\n",
      "Epoch: 262 BG Converged: False Eval BG: 104 Eval FG: 0\n",
      "Epoch: 263 BG Converged: False Eval BG: 168 Eval FG: 0\n",
      "Epoch: 264 BG Converged: False Eval BG: 179 Eval FG: 0\n",
      "Epoch: 265 BG Converged: False Eval BG: 170 Eval FG: 0\n",
      "Epoch: 266 BG Converged: False Eval BG: 107 Eval FG: 0\n",
      "Epoch: 267 BG Converged: False Eval BG: 125 Eval FG: 0\n",
      "Epoch: 268 BG Converged: False Eval BG: 138 Eval FG: 0\n",
      "Epoch: 269 BG Converged: False Eval BG: 163 Eval FG: 0\n",
      "Epoch: 270 BG Converged: False Eval BG: 284 Eval FG: 0\n",
      "Epoch: 271 BG Converged: False Eval BG: 112 Eval FG: 0\n",
      "Epoch: 272 BG Converged: False Eval BG: 169 Eval FG: 0\n",
      "Epoch: 273 BG Converged: False Eval BG: 106 Eval FG: 0\n",
      "Epoch: 274 BG Converged: False Eval BG: 146 Eval FG: 0\n",
      "Epoch: 275 BG Converged: False Eval BG: 118 Eval FG: 0\n",
      "Epoch: 276 BG Converged: False Eval BG: 191 Eval FG: 0\n",
      "Epoch: 277 BG Converged: False Eval BG: 219 Eval FG: 0\n",
      "Epoch: 278 BG Converged: False Eval BG: 192 Eval FG: 0\n",
      "Epoch: 279 BG Converged: False Eval BG: 130 Eval FG: 0\n",
      "Epoch: 280 BG Converged: False Eval BG: 489 Eval FG: 0\n",
      "Epoch: 281 BG Converged: False Eval BG: 296 Eval FG: 0\n",
      "Epoch: 282 BG Converged: False Eval BG: 281 Eval FG: 0\n",
      "Epoch: 283 BG Converged: False Eval BG: 509 Eval FG: 0\n",
      "Epoch: 284 BG Converged: False Eval BG: 3000 Eval FG: 0\n",
      "Epoch: 285 BG Converged: False Eval BG: 3000 Eval FG: 0\n",
      "Epoch: 286 BG Converged: True Eval BG: 3000 Eval FG: 0\n",
      "Epoch: 287 BG Converged: True Eval BG: 0 Eval FG: 29\n",
      "Epoch: 288 BG Converged: True Eval BG: 0 Eval FG: 24\n",
      "Epoch: 289 BG Converged: True Eval BG: 0 Eval FG: 24\n",
      "Epoch: 290 BG Converged: True Eval BG: 0 Eval FG: 28\n",
      "Epoch: 291 BG Converged: True Eval BG: 0 Eval FG: 28\n",
      "Epoch: 292 BG Converged: True Eval BG: 0 Eval FG: 30\n",
      "Epoch: 293 BG Converged: True Eval BG: 0 Eval FG: 36\n",
      "Epoch: 294 BG Converged: True Eval BG: 0 Eval FG: 41\n",
      "Epoch: 295 BG Converged: True Eval BG: 0 Eval FG: 40\n",
      "Epoch: 296 BG Converged: True Eval BG: 0 Eval FG: 80\n",
      "Epoch: 297 BG Converged: True Eval BG: 0 Eval FG: 366\n",
      "Epoch: 298 BG Converged: True Eval BG: 0 Eval FG: 93\n",
      "Epoch: 299 BG Converged: True Eval BG: 0 Eval FG: 96\n",
      "Epoch: 300 BG Converged: True Eval BG: 0 Eval FG: 65\n",
      "Epoch: 301 BG Converged: True Eval BG: 0 Eval FG: 74\n",
      "Epoch: 302 BG Converged: True Eval BG: 0 Eval FG: 79\n",
      "Epoch: 303 BG Converged: True Eval BG: 0 Eval FG: 105\n",
      "Epoch: 304 BG Converged: True Eval BG: 0 Eval FG: 71\n",
      "Epoch: 305 BG Converged: True Eval BG: 0 Eval FG: 83\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 306 BG Converged: True Eval BG: 0 Eval FG: 124\n",
      "Epoch: 307 BG Converged: True Eval BG: 0 Eval FG: 147\n",
      "Epoch: 308 BG Converged: True Eval BG: 0 Eval FG: 130\n",
      "Epoch: 309 BG Converged: True Eval BG: 0 Eval FG: 70\n",
      "Epoch: 310 BG Converged: True Eval BG: 0 Eval FG: 124\n",
      "Epoch: 311 BG Converged: True Eval BG: 0 Eval FG: 95\n",
      "Epoch: 312 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 313 BG Converged: True Eval BG: 0 Eval FG: 78\n",
      "Epoch: 314 BG Converged: True Eval BG: 0 Eval FG: 76\n",
      "Epoch: 315 BG Converged: True Eval BG: 0 Eval FG: 120\n",
      "Epoch: 316 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 317 BG Converged: True Eval BG: 0 Eval FG: 51\n",
      "Epoch: 318 BG Converged: True Eval BG: 0 Eval FG: 116\n",
      "Epoch: 319 BG Converged: True Eval BG: 0 Eval FG: 55\n",
      "Epoch: 320 BG Converged: True Eval BG: 0 Eval FG: 63\n",
      "Epoch: 321 BG Converged: True Eval BG: 0 Eval FG: 59\n",
      "Epoch: 322 BG Converged: True Eval BG: 0 Eval FG: 73\n",
      "Epoch: 323 BG Converged: True Eval BG: 0 Eval FG: 78\n",
      "Epoch: 324 BG Converged: True Eval BG: 0 Eval FG: 64\n",
      "Epoch: 325 BG Converged: True Eval BG: 0 Eval FG: 144\n",
      "Epoch: 326 BG Converged: True Eval BG: 0 Eval FG: 55\n",
      "Epoch: 327 BG Converged: True Eval BG: 0 Eval FG: 81\n",
      "Epoch: 328 BG Converged: True Eval BG: 0 Eval FG: 125\n",
      "Epoch: 329 BG Converged: True Eval BG: 0 Eval FG: 59\n",
      "Epoch: 330 BG Converged: True Eval BG: 0 Eval FG: 170\n",
      "Epoch: 331 BG Converged: True Eval BG: 0 Eval FG: 84\n",
      "Epoch: 332 BG Converged: True Eval BG: 0 Eval FG: 117\n",
      "Epoch: 333 BG Converged: True Eval BG: 0 Eval FG: 55\n",
      "Epoch: 334 BG Converged: True Eval BG: 0 Eval FG: 56\n",
      "Epoch: 335 BG Converged: True Eval BG: 0 Eval FG: 67\n",
      "Epoch: 336 BG Converged: True Eval BG: 0 Eval FG: 157\n",
      "Epoch: 337 BG Converged: True Eval BG: 0 Eval FG: 62\n",
      "Epoch: 338 BG Converged: True Eval BG: 0 Eval FG: 68\n",
      "Epoch: 339 BG Converged: True Eval BG: 0 Eval FG: 76\n",
      "Epoch: 340 BG Converged: True Eval BG: 0 Eval FG: 115\n",
      "Epoch: 341 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 342 BG Converged: True Eval BG: 0 Eval FG: 70\n",
      "Epoch: 343 BG Converged: True Eval BG: 0 Eval FG: 48\n",
      "Epoch: 344 BG Converged: True Eval BG: 0 Eval FG: 82\n",
      "Epoch: 345 BG Converged: True Eval BG: 0 Eval FG: 76\n",
      "Epoch: 346 BG Converged: True Eval BG: 0 Eval FG: 40\n",
      "Epoch: 347 BG Converged: True Eval BG: 0 Eval FG: 57\n",
      "Epoch: 348 BG Converged: True Eval BG: 0 Eval FG: 56\n",
      "Epoch: 349 BG Converged: True Eval BG: 0 Eval FG: 37\n",
      "Epoch: 350 BG Converged: True Eval BG: 0 Eval FG: 47\n",
      "Epoch: 351 BG Converged: True Eval BG: 0 Eval FG: 49\n",
      "Epoch: 352 BG Converged: True Eval BG: 0 Eval FG: 57\n",
      "Epoch: 353 BG Converged: True Eval BG: 0 Eval FG: 46\n",
      "Epoch: 354 BG Converged: True Eval BG: 0 Eval FG: 40\n",
      "Epoch: 355 BG Converged: True Eval BG: 0 Eval FG: 34\n",
      "Epoch: 356 BG Converged: True Eval BG: 0 Eval FG: 53\n",
      "Epoch: 357 BG Converged: True Eval BG: 0 Eval FG: 37\n",
      "Epoch: 358 BG Converged: True Eval BG: 0 Eval FG: 46\n",
      "Epoch: 359 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 360 BG Converged: True Eval BG: 0 Eval FG: 37\n",
      "Epoch: 361 BG Converged: True Eval BG: 0 Eval FG: 39\n",
      "Epoch: 362 BG Converged: True Eval BG: 0 Eval FG: 57\n",
      "Epoch: 363 BG Converged: True Eval BG: 0 Eval FG: 53\n",
      "Epoch: 364 BG Converged: True Eval BG: 0 Eval FG: 42\n",
      "Epoch: 365 BG Converged: True Eval BG: 0 Eval FG: 54\n",
      "Epoch: 366 BG Converged: True Eval BG: 0 Eval FG: 64\n",
      "Epoch: 367 BG Converged: True Eval BG: 0 Eval FG: 37\n",
      "Epoch: 368 BG Converged: True Eval BG: 0 Eval FG: 50\n",
      "Epoch: 369 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 370 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 371 BG Converged: True Eval BG: 0 Eval FG: 74\n",
      "Epoch: 372 BG Converged: True Eval BG: 0 Eval FG: 51\n",
      "Epoch: 373 BG Converged: True Eval BG: 0 Eval FG: 56\n",
      "Epoch: 374 BG Converged: True Eval BG: 0 Eval FG: 50\n",
      "Epoch: 375 BG Converged: True Eval BG: 0 Eval FG: 94\n",
      "Epoch: 376 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 377 BG Converged: True Eval BG: 0 Eval FG: 73\n",
      "Epoch: 378 BG Converged: True Eval BG: 0 Eval FG: 140\n",
      "Epoch: 379 BG Converged: True Eval BG: 0 Eval FG: 62\n",
      "Epoch: 380 BG Converged: True Eval BG: 0 Eval FG: 85\n",
      "Epoch: 381 BG Converged: True Eval BG: 0 Eval FG: 63\n",
      "Epoch: 382 BG Converged: True Eval BG: 0 Eval FG: 59\n",
      "Epoch: 383 BG Converged: True Eval BG: 0 Eval FG: 106\n",
      "Epoch: 384 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 385 BG Converged: True Eval BG: 0 Eval FG: 159\n",
      "Epoch: 386 BG Converged: True Eval BG: 0 Eval FG: 56\n",
      "Epoch: 387 BG Converged: True Eval BG: 0 Eval FG: 67\n",
      "Epoch: 388 BG Converged: True Eval BG: 0 Eval FG: 79\n",
      "Epoch: 389 BG Converged: True Eval BG: 0 Eval FG: 103\n",
      "Epoch: 390 BG Converged: True Eval BG: 0 Eval FG: 59\n",
      "Epoch: 391 BG Converged: True Eval BG: 0 Eval FG: 53\n",
      "Epoch: 392 BG Converged: True Eval BG: 0 Eval FG: 56\n",
      "Epoch: 393 BG Converged: True Eval BG: 0 Eval FG: 70\n",
      "Epoch: 394 BG Converged: True Eval BG: 0 Eval FG: 54\n",
      "Epoch: 395 BG Converged: True Eval BG: 0 Eval FG: 80\n",
      "Epoch: 396 BG Converged: True Eval BG: 0 Eval FG: 54\n",
      "Epoch: 397 BG Converged: True Eval BG: 0 Eval FG: 106\n",
      "Epoch: 398 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 399 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 400 BG Converged: True Eval BG: 0 Eval FG: 100\n",
      "Epoch: 401 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 402 BG Converged: True Eval BG: 0 Eval FG: 68\n",
      "Epoch: 403 BG Converged: True Eval BG: 0 Eval FG: 65\n",
      "Epoch: 404 BG Converged: True Eval BG: 0 Eval FG: 53\n",
      "Epoch: 405 BG Converged: True Eval BG: 0 Eval FG: 99\n",
      "Epoch: 406 BG Converged: True Eval BG: 0 Eval FG: 50\n",
      "Epoch: 407 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 408 BG Converged: True Eval BG: 0 Eval FG: 71\n",
      "Epoch: 409 BG Converged: True Eval BG: 0 Eval FG: 73\n",
      "Epoch: 410 BG Converged: True Eval BG: 0 Eval FG: 54\n",
      "Epoch: 411 BG Converged: True Eval BG: 0 Eval FG: 73\n",
      "Epoch: 412 BG Converged: True Eval BG: 0 Eval FG: 70\n",
      "Epoch: 413 BG Converged: True Eval BG: 0 Eval FG: 109\n",
      "Epoch: 414 BG Converged: True Eval BG: 0 Eval FG: 68\n",
      "Epoch: 415 BG Converged: True Eval BG: 0 Eval FG: 49\n",
      "Epoch: 416 BG Converged: True Eval BG: 0 Eval FG: 77\n",
      "Epoch: 417 BG Converged: True Eval BG: 0 Eval FG: 110\n",
      "Epoch: 418 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 419 BG Converged: True Eval BG: 0 Eval FG: 62\n",
      "Epoch: 420 BG Converged: True Eval BG: 0 Eval FG: 57\n",
      "Epoch: 421 BG Converged: True Eval BG: 0 Eval FG: 45\n",
      "Epoch: 422 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 423 BG Converged: True Eval BG: 0 Eval FG: 60\n",
      "Epoch: 424 BG Converged: True Eval BG: 0 Eval FG: 59\n",
      "Epoch: 425 BG Converged: True Eval BG: 0 Eval FG: 77\n",
      "Epoch: 426 BG Converged: True Eval BG: 0 Eval FG: 52\n",
      "Epoch: 427 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 428 BG Converged: True Eval BG: 0 Eval FG: 81\n",
      "Epoch: 429 BG Converged: True Eval BG: 0 Eval FG: 67\n",
      "Epoch: 430 BG Converged: True Eval BG: 0 Eval FG: 61\n",
      "Epoch: 431 BG Converged: True Eval BG: 0 Eval FG: 53\n",
      "Epoch: 432 BG Converged: True Eval BG: 0 Eval FG: 75\n",
      "Epoch: 433 BG Converged: True Eval BG: 0 Eval FG: 58\n",
      "Epoch: 434 BG Converged: True Eval BG: 0 Eval FG: 92\n",
      "Epoch: 435 BG Converged: True Eval BG: 0 Eval FG: 63\n",
      "Epoch: 436 BG Converged: True Eval BG: 0 Eval FG: 68\n",
      "Epoch: 437 BG Converged: True Eval BG: 0 Eval FG: 110\n",
      "Epoch: 438 BG Converged: True Eval BG: 0 Eval FG: 63\n",
      "Epoch: 439 BG Converged: True Eval BG: 0 Eval FG: 104\n",
      "Epoch: 440 BG Converged: True Eval BG: 0 Eval FG: 106\n",
      "Epoch: 441 BG Converged: True Eval BG: 0 Eval FG: 130\n",
      "Epoch: 442 BG Converged: True Eval BG: 0 Eval FG: 92\n",
      "Epoch: 443 BG Converged: True Eval BG: 0 Eval FG: 133\n",
      "Epoch: 444 BG Converged: True Eval BG: 0 Eval FG: 146\n",
      "Epoch: 445 BG Converged: True Eval BG: 0 Eval FG: 120\n",
      "Epoch: 446 BG Converged: True Eval BG: 0 Eval FG: 206\n",
      "Epoch: 447 BG Converged: True Eval BG: 0 Eval FG: 225\n",
      "Epoch: 448 BG Converged: True Eval BG: 0 Eval FG: 295\n",
      "Epoch: 449 BG Converged: True Eval BG: 0 Eval FG: 341\n",
      "Epoch: 450 BG Converged: True Eval BG: 0 Eval FG: 155\n",
      "Epoch: 451 BG Converged: True Eval BG: 0 Eval FG: 742\n",
      "Epoch: 452 BG Converged: True Eval BG: 0 Eval FG: 387\n",
      "Epoch: 453 BG Converged: True Eval BG: 0 Eval FG: 3000\n",
      "Epoch: 454 BG Converged: True Eval BG: 0 Eval FG: 3000\n",
      "FG Converged\n"
     ]
    }
   ],
   "source": [
    "epoch = 3000\n",
    "bg_success_queue = [0] * 3\n",
    "fg_success_queue = [0] * 3\n",
    "bg_converged = False\n",
    "\n",
    "# Setup agent\n",
    "nfq_net = ContrastiveNFQNetwork(state_dim=train_env_bg.state_dim, is_contrastive=is_contrastive)\n",
    "optimizer = optim.Adam(nfq_net.parameters(), lr=1e-1)\n",
    "nfq_agent = NFQAgent(nfq_net, optimizer)\n",
    "for ep in range(epoch + 1):\n",
    "    \n",
    "    if bg_converged:\n",
    "        state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(fg_rollouts)\n",
    "    else:\n",
    "        state_action_b, target_q_values, groups = nfq_agent.generate_pattern_set(bg_rollouts)\n",
    "    \n",
    "    loss = nfq_agent.train((state_action_b, target_q_values, groups))\n",
    "    \n",
    "    eval_episode_length_fg = 0\n",
    "    eval_episode_length_bg = 0\n",
    "    eval_success_fg = False\n",
    "    eval_success_bg = False\n",
    "    if bg_converged:\n",
    "        eval_episode_length_fg, eval_success_fg, eval_episode_cost_fg = nfq_agent.evaluate(\n",
    "            eval_env_fg, render=False\n",
    "        )\n",
    "    else:\n",
    "        eval_episode_length_bg, eval_success_bg, eval_episode_cost_bg = nfq_agent.evaluate(\n",
    "        eval_env_bg, render=False\n",
    "        )\n",
    "\n",
    "    bg_success_queue = bg_success_queue[1:]\n",
    "    bg_success_queue.append(1 if eval_success_bg else 0)\n",
    "\n",
    "    fg_success_queue = fg_success_queue[1:]\n",
    "    fg_success_queue.append(1 if eval_success_fg else 0)\n",
    "\n",
    "    if sum(bg_success_queue) == 3:\n",
    "        bg_converged = True\n",
    "\n",
    "    if sum(fg_success_queue) == 3:\n",
    "        print(\"FG Converged\")\n",
    "        break\n",
    "    \n",
    "    print(\"Epoch: \" + str(ep) + \" BG Converged: \" + str(bg_converged) + \" Eval BG: \" + str(eval_episode_length_bg)\n",
    "         + \" Eval FG: \" + str(eval_episode_length_fg))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'sns' 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<ipython-input-7-d9d2383430bd>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     21\u001b[0m     \u001b[0mtrain_env_fg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m     \u001b[0meval_env_fg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 23\u001b[0;31m \u001b[0msns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdistplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mperformance\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m: name 'sns' is not defined"
     ]
    }
   ],
   "source": [
    "eval_env_bg.step_number = 0\n",
    "eval_env_fg.step_number = 0\n",
    "\n",
    "eval_env_bg.max_steps = 1000\n",
    "eval_env_fg.max_steps = 1000\n",
    "\n",
    "performance = []\n",
    "evaluations = 10\n",
    "total = 0\n",
    "for it in range(evaluations):\n",
    "\n",
    "    eval_episode_length_bg, eval_success_bg, eval_episode_cost_bg = nfq_agent.evaluate(eval_env_bg, True)\n",
    "    performance.append(eval_episode_length_bg)\n",
    "    train_env_bg.close()\n",
    "    eval_env_bg.close()\n",
    "\n",
    "    eval_episode_length_fg, eval_success_fg, eval_episode_cost_fg = nfq_agent.evaluate(eval_env_fg, True)\n",
    "    performance.append(eval_episode_length_fg)\n",
    "    train_env_fg.close()\n",
    "    eval_env_fg.close()"
   ]
  },
  {
   "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": {
      "text/plain": [
       "<AxesSubplot:ylabel='Density'>"
      ]
     },
     "execution_count": 9,
     "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": [
    "sns.distplot(performance)"
   ]
  },
  {
   "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
}
