{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "24e2e518",
   "metadata": {},
   "outputs": [],
   "source": [
    "# MISC\n",
    "import os\n",
    "import sys\n",
    "\n",
    "sys.path.append(\"..\")\n",
    "os.environ['MUJOCO_GL']='egl'\n",
    "os.environ['CUDA_VISIBLE_DEVICES']='0'\n",
    "\n",
    "import shutup\n",
    "shutup.please()\n",
    "\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "# VIS\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from rich.pretty import pprint\n",
    "from tqdm.auto import tqdm\n",
    "\n",
    "from hydra import initialize, compose\n",
    "from omegaconf import OmegaConf\n",
    "\n",
    "plt.style.use(['seaborn-v0_8-colorblind', 'seaborn-v0_8-notebook'])\n",
    "colors = plt.rcParams['axes.prop_cycle'].by_key()['color'] \n",
    "\n",
    "GLOBAL_KEY = jax.random.key(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ddfdb58c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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t5iTTjppyr+75ZZbzJFHHmkktf9ceumlkwaATtx///1m4cKFEzLf9ra3vezbnUqlkjnrrLMOeX9At8yEnrC/H/zgB2ZgYMD82Z/92UFtP5Uf//jH5rWvfe2EnnDSSSeZZ555ZsrtzzzzTHP88ccf8v6AbpoJfcHHa4X9/e///q85/PDDzR//8R9P+ff0he7grVAepbf/9n9rgCStWrVKCxYsaP+58cYbJbU+OeHRRx/VZZddpt/5nd9pb/97v/d7Gh4e1r/927+1Hxt/+3Dfvn167rnndMwxx+jII4/UI4888oq1rVq1SsYYXXvttQf8OZ577jnNnTt3yr979atfrZNPPllf/vKX9S//8i/6xCc+odtuu03XXHPNAXNfzoIFC/T6179ef/EXf6F77rlH1157rX74wx9O+sdYqblz5x7UbVqg12ZCTxjv17/+td7znvdo6dKlWrt27QG3fzlz587VihUrdM011+iee+7R9ddfr6eeekoXXnih9u7dO+X29ASEYib0BR+vFcZ74YUXdOGFFyqXy+kLX/jClNvQF7oj2+sCprP004tqtdqkv1u3bp2q1ap27typ9773ve3Hn376aUnScccdN+l7jj/+eD3wwAOq1+vK5/MaGxvT5z//ea1fv16/+tWvZMZ9wNeePXuc/ixmig8P27hxo8455xz913/9l974xjdKan0ixJw5c3Tdddfp8ssv1wknnNDRfp588kmdccYZuvXWW3XBBRdIks4991y95jWv0WWXXaZvf/vbOuussybVNjAwcIg/GdA9070njFev13XOOeeoWq3qP/7jP6Z80XQw9uzZo9NPP12f+tSn9MlPfrL9+Bvf+EatWrVK69ev1xVXXDGpNnoCQjHd+4KP1wrjvfjii7r44os1Ojqqb3/72zr66KNftjb6gn8MFh4dccQRWrhwoR5//PFJf5f+x1oO5h9PvZyPfOQjWr9+vT7+8Y9raGhIRxxxhAYGBnTxxRcrSZJDzt3fvHnztHv37kmPr1u3TkcddVS7UaTe+c536tprr9V//ud/dtws/u7v/k579+7VOeecMylTajWo/QeL3bt369hjj+1oP0AvTPeekIrjWOeff75+9rOf6YEHHtDrXve6Q97XXXfdpZ07d7Z7QGrlypWaM2eONm7cOGmw2L1796R/2An0q+neF3y8Vhhv9erVuv/++3Xb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",
      "text/plain": [
       "<Figure size 800x550 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from envs.custom_mazes.darkroom import FourRoomsMazeEnv, Maze\n",
    "\n",
    "test = FourRoomsMazeEnv(Maze(seed=0, maze_type='fourrooms_random_layouts'))\n",
    "test.reset()\n",
    "img = test.render(return_img=True)\n",
    "START_POS = (1,1)\n",
    "\n",
    "fig, ax = plt.subplots(nrows=1, ncols=3)\n",
    "for i, cur_ax in enumerate(ax.flat, start=0):\n",
    "    test.setup_goals(seed=None, task_num=i, start_pos=START_POS)\n",
    "    test.render(ax=cur_ax)\n",
    "    cur_ax.set_title(f\"Goal: {test.goal}\")\n",
    "plt.tight_layout()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4abd977",
   "metadata": {},
   "source": [
    "# Collect Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f48a19e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "29eef0d121f34cba900ab5bb681b3366",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\">{</span>\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'actions'</span>: <span style=\"font-weight: bold\">(</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100000</span>,<span style=\"font-weight: bold\">)</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'layout_type'</span>: <span style=\"font-weight: bold\">(</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100000</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10</span><span style=\"font-weight: bold\">)</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'next_observations'</span>: <span style=\"font-weight: bold\">(</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100000</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span><span style=\"font-weight: bold\">)</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'observations'</span>: <span style=\"font-weight: bold\">(</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100000</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span><span style=\"font-weight: bold\">)</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'terminals'</span>: <span style=\"font-weight: bold\">(</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100000</span>,<span style=\"font-weight: bold\">)</span>\n",
       "<span style=\"font-weight: bold\">}</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1m{\u001b[0m\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'actions'\u001b[0m: \u001b[1m(\u001b[0m\u001b[1;36m100000\u001b[0m,\u001b[1m)\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'layout_type'\u001b[0m: \u001b[1m(\u001b[0m\u001b[1;36m100000\u001b[0m, \u001b[1;36m10\u001b[0m\u001b[1m)\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'next_observations'\u001b[0m: \u001b[1m(\u001b[0m\u001b[1;36m100000\u001b[0m, \u001b[1;36m2\u001b[0m\u001b[1m)\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'observations'\u001b[0m: \u001b[1m(\u001b[0m\u001b[1;36m100000\u001b[0m, \u001b[1;36m2\u001b[0m\u001b[1m)\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'terminals'\u001b[0m: \u001b[1m(\u001b[0m\u001b[1;36m100000\u001b[0m,\u001b[1m)\u001b[0m\n",
       "\u001b[1m}\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkoAAAHYCAYAAACyZcdMAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAPopJREFUeJzt3Xt4VNW9//HPJBgSCQkXD5lMuZh6PHKVICgG1GjJQxSK5tRa0VQppkBtUgnxqHgh4JWKFQGlBGwV+xxQtOdALdpoGmpSJARISAUE1F9T8ZJJ2sNlTBQTMvv3B2bLkGxJzB5mdni/fPZTZ+81a39nKsmX71p7LZdhGIYAAADQSkSoAwAAAAhXJEoAAAAWSJQAAAAskCgBAABYIFECAACwQKIEAABggUQJAADAAokSAACAhW6hDqA9/H6/Pv30U/Xs2VMulyvU4QAAIEkyDEOfffaZPB6PIiJOf+3h6NGjamxstLXPqKgoRUdH29qnkzkiUfr00081YMCAUIcBAECbPvroI/Xv3/+03vPo0aNKSnLL6z1ia79ut1vV1dUkS19xRKLUs2fPr/7N9dUBAEA4MCQZJ/yeOn0aGxvl9R7RPz5aqri4GFv69Pm+0LkDZquxsZFE6SuOSJS+Hm4jUQIAhBsjpNNCYmO7Kza2uy19+f1+W/rpShyRKAEAgLYZxjEZxjHb+kIgnnoDAACwQEUJAAAHM4xmGUazbX0hEBUlAAAAC1SUAABwML9xTH6b5hbZ1U9XQqIEAICDMZk7uBh6AwAAsEBFCQAABzs+mduuihKTuU9GogQAgIMZ/mMy/DYlSjb105Uw9AYAAGCBihIAAE5mHDt+2NUXAlBRAgAAsBC0RGn58uU699xzFR0drbFjx2rbtm3BuhUAAGesluUB7DoQKCiJ0rp165SXl6f58+ersrJSI0eOVHp6uurq6oJxOwAAzlz+Y5K/yaaDROlkQUmUFi9erBkzZmj69OkaOnSoCgoKdPbZZ+u5554Lxu0AAACCwvbJ3I2NjaqoqNC9995rnouIiFBaWprKysra1UdNTY1qamrM1/X19XaHCQBAl3B8yCzStr4QyPZE6V//+peam5uVkJAQcD4hIUH79u1rVx8rV67Ugw8+aHdoAAAAHRKWywPMmjVL1157rfm6vr5eqampIYwIAIAw5T8m+e2pKDFHqTXbE6VzzjlHkZGRqq2tDThfW1srt9vdrj4SExOVmJhovvb5fLbGCABAl0GiFFS2T+aOiorS6NGjVVxcbJ7z+/0qLi5WSkqK3bcDAAAImqAMveXl5WnatGkaM2aMLrnkEi1ZskQNDQ2aPn16MG4HAMAZrNnGFbXZFPdkQUmUbrzxRv3zn/9Ufn6+vF6vkpOTVVhY2GqCNwAAQDgL2mTunJwc5eTkBKt7AAAgyeU/Jpffnpk0LuYotRKWT70BAIB28h+TbEqUmMzdGpviAgAA25SWlmrKlCnyeDxyuVzasGGDZduf/exncrlcWrJkScD5gwcPKjMzU3FxcerVq5eysrJaLT79zjvv6PLLL1d0dLQGDBigRYsWter/lVde0eDBgxUdHa0RI0bo9ddf7/DnIVECAMDJ/MfsPTqpoaFBI0eO1PLly7+x3fr167V161Z5PJ5W1zIzM7Vnzx4VFRVp48aNKi0t1cyZM83rPp9PEydO1KBBg1RRUaEnnnhCCxYs0KpVq8w2W7Zs0U033aSsrCzt3LlTGRkZysjI0O7duzv0eVyGYRgdekcI+Hw+xcfH63he5wp1OAAAfMWQ5NeRI0cUFxd3Wu/c8rvx4/2ZiusZZU+fnzWq/wVrbPs8LpdL69evV0ZGRsD5Tz75RGPHjtUbb7yhyZMnKzc3V7m5uZKkvXv3aujQodq+fbvGjBkjSSosLNSkSZP08ccfy+PxaMWKFbr//vvl9XoVFXX8s8+dO1cbNmwwdwG58cYb1dDQoI0bN5r3vfTSS5WcnKyCgoJ2fwYqSgAAOJjLOGbrIUlVVVWqrKw0jxP3X+0sv9+vW265RXfddZeGDRvW6npZWZl69eplJkmSlJaWpoiICJWXl5ttrrjiCjNJkqT09HTt379fhw4dMtukpaUF9J2ent7ufWdbMJkbAAAn8/slv03rH/n9ktRq27D58+drwYIFttzi8ccfV7du3XTHHXe0ed3r9apfv34B57p166Y+ffrI6/WabZKSkgLatCxB5PV61bt3b3m93jb3nW3po71IlAAAQICSkhLFxsaar0/cVqwzKioqtHTpUlVWVsrlcsZUGhIlAAAc7Pg6SvYkHS3rKCUnJwdlztVf//pX1dXVaeDAgea55uZm3XnnnVqyZIn+8Y9/yO12q66uLuB9x44d08GDB809Y91ud5t7yrZc+6Y27d13tgVzlAAAwGlxyy236J133lFVVZV5eDwe3XXXXXrjjTckSSkpKTp8+LAqKirM923atEl+v19jx44125SWlqqpqclsU1RUpAsuuEC9e/c225y472xLm47uO0tFCQAAJ/M327jgZOfnOtXX1+uDDz4wX1dXV6uqqkp9+vTRwIED1bdv34D2Z511ltxuty644AJJ0pAhQ3T11VdrxowZKigoUFNTk3JycjR16lRzKYGbb75ZDz74oLKysnTPPfdo9+7dWrp0qZ566imz39mzZys1NVVPPvmkJk+erJdeekk7duwIWEKgPagoAQDgZGG2jtKOHTs0atQojRo1SpKUl5enUaNGKT8/v919rFmzRoMHD9aECRM0adIkXXbZZQEJTnx8vN58801VV1dr9OjRuvPOO5Wfnx+w1tK4ceO0du1arVq1SiNHjtTvf/97bdiwQcOHD+/Q52EdpU7yfdb+/+NPt+izB4U6BEsfTHk+1CG06fzrOvbY6On0Reb8UIfQJldE+Bamz9r1UqhDaJNrdPjug+lyRYY6hDZFRWaFOgQLoV9H6dOqSYrreZY9fX7WJE/y6yH5POEqfH/CAQCAU3L5m23cFNemZQa6EIbeAAAALFBRAgDAyQwbJ3MbVJRORqIEAICDufx+24bMXF+tzI2vMfQGAABggYoSAABO5m+WbFqZ27Y947oQKkoAAAAWqCgBAOBgx5cHsGuvNypKJyNRAgDAyRh6CyqG3gAAACxQUQIAwMEYegsuKkoAAAAWqCgBAOBkzFEKKhIlAAAczOU3bFtR2+U3bOmnK2HoDQAAwAIVJQAAnMzfLNm1RRtDb61QUQIAALBARQkAACczbKwoGVSUTkaiBACAg7kMv1yGTesoGXZlXF0HQ28AAAAWqCgBAOBkTOYOKhIlAACczO+3ccFJht5OxtAbAACABSpKAAA4GRWloKKiBAAAYIGKEgAADuby++WyqRBk155xXQmJEgAATub32/jUG4nSyRh6AwAAsEBFCQAAJ6OiFFRUlAAAACxQUQIAwMmoKAUViRIAAE5mNEt+w6a+SJROxtAbAACABSpKAAA4GOsoBRcVJQAAAAtUlAAAcDImcwcViRIAAE5GohRUDL0BAABYoKLUSZFn9Qp1CJaa/V+GOgRL3xn891CH0Cbf3waEOgRLUbeE5x/XmOjvhDoES8ciIkMdQpu+/OLjUIdgyWg+GuoQ0FF+w75KkF3LDHQhVJQAAAAshOdfUQEAQPv4DRvnKFFROhmJEgAATub3S36XTX2RKJ2MoTcAAAALVJQAAHAyKkpBRUUJAADAAokSAABO5jfsPTqptLRUU6ZMkcfjkcvl0oYNG8xrTU1NuueeezRixAj16NFDHo9Ht956qz799NOAPg4ePKjMzEzFxcWpV69eysrKUn19fUCbd955R5dffrmio6M1YMAALVq0qFUsr7zyigYPHqzo6GiNGDFCr7/+eoc/D4kSAABOZvjtPTqpoaFBI0eO1PLly1td+/zzz1VZWal58+apsrJS//u//6v9+/fr2muvDWiXmZmpPXv2qKioSBs3blRpaalmzpxpXvf5fJo4caIGDRqkiooKPfHEE1qwYIFWrVplttmyZYtuuukmZWVlaefOncrIyFBGRoZ2797doc/jMgwj7AckfT6f4uPjdTyvs2kc1iYNRxeHOgRLEZHRoQ7BUuM9j4Q6hDYdOxoV6hAsRf1q5qkbhUBYLzhZsSTUIbSpcfCUUIdgKVwXnIzv1bpaEB4MSX4dOXJEcXFxp/XOLb8bDz4bo7iz7fnd6PvcUJ8ZX9j2eVwul9avX6+MjAzLNtu3b9cll1yiDz/8UAMHDtTevXs1dOhQbd++XWPGjJEkFRYWatKkSfr444/l8Xi0YsUK3X///fJ6vYqKOv5ze+7cudqwYYP27dsnSbrxxhvV0NCgjRs3mve69NJLlZycrIKCgnZ/BipKAAA4mWHjsNtXtZOqqipVVlaaR01NTdDCP3LkiFwul3r16iVJKisrU69evcwkSZLS0tIUERGh8vJys80VV1xhJkmSlJ6erv379+vQoUNmm7S0tIB7paenq6ysrEPxkSgBAIAAqampGj16tHmsXLkyKPc5evSo7rnnHt10001mBcvr9apfv34B7bp166Y+ffrI6/WabRISEgLatLw+VZuW6+3F8gAAADhZEFbmLikpUWxsrHk6MTHRpht8rampST/60Y9kGIZWrFhhe/92IVECAMDJgpAoJScnB3XOVUuS9OGHH2rTpk0B93K73aqrqwtof+zYMR08eFBut9tsU1tbG9Cm5fWp2rRcby+G3gAAwGnTkiS9//77+vOf/6y+ffsGXE9JSdHhw4dVUVFhntu0aZP8fr/Gjh1rtiktLVVTU5PZpqioSBdccIF69+5ttikuLg7ou6ioSCkpKR2Kl0QJAAAHC7PVAVRfX6+qqipVVVVJkqqrq1VVVaUDBw6oqalJP/zhD7Vjxw6tWbNGzc3N8nq98nq9amxslCQNGTJEV199tWbMmKFt27bp7bffVk5OjqZOnSqPxyNJuvnmmxUVFaWsrCzt2bNH69at09KlS5WXl2fGMXv2bBUWFurJJ5/Uvn37tGDBAu3YsUM5OTkd+jy2J0oLFy7UxRdfrJ49e6pfv37KyMjQ/v377b4NAAAIQzt27NCoUaM0atQoSVJeXp5GjRql/Px8ffLJJ3r11Vf18ccfKzk5WYmJieaxZcsWs481a9Zo8ODBmjBhgiZNmqTLLrssYI2k+Ph4vfnmm6qurtbo0aN15513Kj8/P2CtpXHjxmnt2rVatWqVRo4cqd///vfasGGDhg8f3qHPY/scpZKSEmVnZ+viiy/WsWPHdN9992nixIl699131aNHD7tvBwDAmS0Ic5Q648orr9Q3LdHYnuUb+/Tpo7Vr135jmwsvvFB//etfv7HNDTfcoBtuuOGU9/smtidKhYWFAa9Xr16tfv36qaKiQldccYXdtwMA4Mzml42Jkk39dCFBf+rtyJEjko5nh+1VU1MTsLjVyfu7AAAAnA5BTZT8fr9yc3M1fvz4Do0Jrly5Ug8++GAQIwMAoIugohRUQU2UsrOztXv3bm3evLlD75s1a1bABnn19fVKTU21OzwAAIBvFLREKScnx9zxt3///h16b8sM+BY+n8/u8AAA6BqMrw67+kIA2xMlwzD0i1/8QuvXr9dbb72lpKQku28BAAC+YvhdMvwum/qypZsuxfZEKTs7W2vXrtUf/vAH9ezZ09x8Lj4+XjExMXbfDgAAIGhsX3ByxYoVOnLkiK688sqAhaTWrVtn960AAIDf5gMBgjL0BgAAThPDJdk09MYcpdbY6w0AAMBC0BecBAAAwcNk7uCiogQAAGCBihIAAE7mt3GOEhWlVkiUAABwMsN1/LClL3u66UoYegMAALBARQkAAAdjMndwUVECAACwQEUJAAAn80fYOJmbSUonI1ECAMDJeOotqBh6AwAAsEBFCQAABzMMlwyblgdgu9bWSJQ6qXtU31CHYKlpV0GoQ7C0uWRcqENo03fdNaEOwVLSnldCHUKbGqN7hDoES912vBPqENoU/Xl9qEOwZER1D3UIQFghUQIAwMmYzB1UJEoAADiY4ZeN6yiRKJ2MydwAAAAWqCgBAOBkho3LA9i1Z1wXQkUJAADAAhUlAAAczN7lAagonYxECQAAJ/NHHD9s6cuebroSht4AAAAsUFECAMDBDL/LxuUBGHo7GRUlAAAAC1SUAABwMCZzBxeJEgAATsZk7qBi6A0AAMACFSUAAByMydzBRUUJAADAAhUlAAAcjMncwUWiBACAkzGZO6gYegMAALBARQkAAAdjMndwUVECAACwQEUJAAAHYzJ3cJEoAQDgZIaNk7kNe7rpShh6AwAAsECiBACAg7VM5rbr6KzS0lJNmTJFHo9HLpdLGzZsCIzXMJSfn6/ExETFxMQoLS1N77//fkCbgwcPKjMzU3FxcerVq5eysrJUX18f0Oadd97R5ZdfrujoaA0YMECLFi1qFcsrr7yiwYMHKzo6WiNGjNDrr7/e4c9DogQAAGzT0NCgkSNHavny5W1eX7RokZYtW6aCggKVl5erR48eSk9P19GjR802mZmZ2rNnj4qKirRx40aVlpZq5syZ5nWfz6eJEydq0KBBqqio0BNPPKEFCxZo1apVZpstW7bopptuUlZWlnbu3KmMjAxlZGRo9+7dHfo8LsMwwn5E0ufzKT4+XsfzuvCaaHbM/0KoQ7DUtKsg1CFY2nTbd0IdQpu+664JdQiWkhZ8HuoQ2uSP7hHqECx121wW6hDaNvS7oY7AkhHVPdQhtKl7Ssd+uZ0+hiS/jhw5ori4uNN655bfjdVZ31VcVKQ9fTY2K+m3f7ft87hcLq1fv14ZGRmSjleTPB6P7rzzTv3Xf/2XJOnIkSNKSEjQ6tWrNXXqVO3du1dDhw7V9u3bNWbMGElSYWGhJk2apI8//lgej0crVqzQ/fffL6/Xq6ioKEnS3LlztWHDBu3bt0+SdOONN6qhoUEbN24047n00kuVnJysgoL2/36kogQAgJPZOez21dBbVVWVKisrzaOmxp6/RFZXV8vr9SotLc08Fx8fr7Fjx6qs7PhfbMrKytSrVy8zSZKktLQ0RUREqLy83GxzxRVXmEmSJKWnp2v//v06dOiQ2ebE+7S0ablPe5EoAQCAAKmpqRo9erR5rFy50pZ+vV6vJCkhISHgfEJCgnnN6/WqX79+Ade7deumPn36BLRpq48T72HVpuV6e7E8AAAADmYYETIMe+oeLbNxSkpKFBsba55PTEy0pX8nIlECAMDJThgys6UvScnJyUGZc+V2uyVJtbW1AclXbW2tkpOTzTZ1dXUB7zt27JgOHjxovt/tdqu2tjagTcvrU7Vpud5eDL0BAIDTIikpSW63W8XFxeY5n8+n8vJypaSkSJJSUlJ0+PBhVVRUmG02bdokv9+vsWPHmm1KS0vV1NRktikqKtIFF1yg3r17m21OvE9Lm5b7tBeJEgAADtayhYldR2fV19erqqpKVVVVko5P4K6qqtKBAwfkcrmUm5urRx55RK+++qp27dqlW2+9VR6Px3wybsiQIbr66qs1Y8YMbdu2TW+//bZycnI0depUeTweSdLNN9+sqKgoZWVlac+ePVq3bp2WLl2qvLw8M47Zs2ersLBQTz75pPbt26cFCxZox44dysnJ6dDnYegNAADYZseOHbrqqqvM1y3Jy7Rp07R69Wrdfffdamho0MyZM3X48GFddtllKiwsVHR0tPmeNWvWKCcnRxMmTFBERISuv/56LVu2zLweHx+vN998U9nZ2Ro9erTOOecc5efnB6y1NG7cOK1du1YPPPCA7rvvPp1//vnasGGDhg8f3qHPwzpKncQ6St8O6yh1HOsodRzrKHUc6yh1VOjXUfogc7B62rSO0meNzfr3NftC8nnCFRUlAAAcLBhPveFrzFECAACwQEUJAAAHs2sz25a+EIhEqZOa/V+GOgRLxpCbQh2CpUvHLg51CG2KvSX21I1CZdQdoY6gbf6jp24TKm+F5xylL0bdEOoQLEV0C9c/A/eFOgCcoUiUAABwMLse62/pC4FIlAAAcDASpeBiMjcAAIAFKkoAADiYYdg4mZuKUitUlAAAACxQUQIAwMFYcDK4SJQAAHAw1lEKLobeAAAALFBRAgDAwVgeILioKAEAAFigogQAgINRUQouEiUAABzM8Ns3Cdvw29JNl8LQGwAAgAUqSgAAOBhDb8FFRQkAAMBC0BOlX/7yl3K5XMrNzQ32rQAAOOO0rMxt14FAQR162759u1auXKkLL7wwmLcBAOCM5Tdc8ts0ZGZXP11J0FLH+vp6ZWZm6tlnn1Xv3r2DdRsAAICgCVpFKTs7W5MnT1ZaWpoeeeSRDr23pqZGNTU15uv6+nq7wwMAoGuwca83sddbK0FJlF566SVVVlZq+/bt3+r9K1eu1IMPPmhzVAAAAB1je6L00Ucfafbs2SoqKlJ0dPS36mPWrFm69tprzdf19fVKTU21K0QAALoMlgcILtsTpYqKCtXV1emiiy4yzzU3N6u0tFTPPPOMvvzyS0VGRn5jH4mJiUpMTDRf+3w+u8MEAKBLIFEKLtsTpQkTJmjXrl0B56ZPn67BgwfrnnvuOWWSBAAAEC5sT5R69uyp4cOHB5zr0aOH+vbt2+o8AADoHCpKwcXKUgAAABZOy15vb7311um4DQAAZxy/ESG/TStq29VPV8KmuAAAOJhh2LeOEkNvrZE6AgAAWKCiBACAgzGZO7ioKAEAAFigogQAgINRUQouEiUAABzMb7jktynBsaufroShNwAAAAtUlAAAcDCG3oKLihIAAIAFKkoAADgYFaXgIlECAMDBmMwdXAy9AQAAWKCi1EnGzhWhDsHSl7/7v1CHYGn1G1eHOoQ2TY94I9QhWOr2v/NCHUKbmo92D3UIlo4a/UMdQtvuWxPqCCwZ3Y6FOgR0kGHYN2RmGLZ006WQKAEA4GDMUQouht4AAAAskCgBAOBgxleTue04OltRam5u1rx585SUlKSYmBidd955evjhh2WcMKZnGIby8/OVmJiomJgYpaWl6f333w/o5+DBg8rMzFRcXJx69eqlrKws1dfXB7R55513dPnllys6OloDBgzQokWLOhW7FRIlAABgi8cff1wrVqzQM888o7179+rxxx/XokWL9PTTT5ttFi1apGXLlqmgoEDl5eXq0aOH0tPTdfToUbNNZmam9uzZo6KiIm3cuFGlpaWaOXOmed3n82nixIkaNGiQKioq9MQTT2jBggVatWqV7Z+JOUoAADhYOM1R2rJli6677jpNnjxZknTuuefqxRdf1LZt277q39CSJUv0wAMP6LrrrpMk/e53v1NCQoI2bNigqVOnau/evSosLNT27ds1ZswYSdLTTz+tSZMm6Ve/+pU8Ho/WrFmjxsZGPffcc4qKitKwYcNUVVWlxYsXByRUdqCiBACAg7UkSnYdklRVVaXKykrzqKmpaVcs48aNU3Fxsd577z1J0t/+9jdt3rxZ11xzjSSpurpaXq9XaWlp5nvi4+M1duxYlZWVSZLKysrUq1cvM0mSpLS0NEVERKi8vNxsc8UVVygqKspsk56erv379+vQoUOd+DZbo6IEAAACpKamBryeP3++FixYcMr3zZ07Vz6fT4MHD1ZkZKSam5v16KOP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CO+0YzI3AACwRVRUlEaPHq3i4mLznN/vV3FxsVJSUkIY2bfniIoSAABwhry8PE2bNk1jxozRJZdcoiVLlqihoUHTp08PdWjfyhmXKCUmJmr+/Pln9HhrR/GddRzfWcfxnXUc31nH8Z0F34033qh//vOfys/Pl9frVXJysgoLC1tN8HYKlxHaZxoBAADCFnOUAAAALJAoAQAAWCBRAgAAsECiBAAAYIFECQAAwAKJEgAAgAUSJQAAAAskSgAAABZIlAAAACyccYnS8uXLde655yo6Olpjx47Vtm3bQh1S2Fq4cKEuvvhi9ezZU/369VNGRob2798f6rAc5Ze//KVcLpdyc3NDHUpY++STT/TjH/9Yffv2VUxMjEaMGKEdO3aEOqyw1dzcrHnz5ikpKUkxMTE677zz9PDDD4uNFr5WWlqqKVOmyOPxyOVyacOGDQHXDcNQfn6+EhMTFRMTo7S0NL3//vuhCRZh7YxKlNatW6e8vDzNnz9flZWVGjlypNLT01VXVxfq0MJSSUmJsrOztXXrVhUVFampqUkTJ05UQ0NDqENzhO3bt2vlypW68MILQx1KWDt06JDGjx+vs846S3/605/07rvv6sknn1Tv3r1DHVrYevzxx7VixQo988wz2rt3rx5//HEtWrRITz/9dKhDCxsNDQ0aOXKkli9f3ub1RYsWadmyZSooKFB5ebl69Oih9PR0HT169DRHirBnnEEuueQSIzs723zd3NxseDweY+HChSGMyjnq6uoMSUZJSUmoQwl7n332mXH++ecbRUVFRmpqqjF79uxQhxS27rnnHuOyyy4LdRiOMnnyZOO2224LOPeDH/zAyMzMDFFE4U2SsX79evO13+833G638cQTT5jnDh8+bHTv3t148cUXQxAhwtkZU1FqbGxURUWF0tLSzHMRERFKS0tTWVlZCCNzjiNHjkiS+vTpE+JIwl92drYmT54c8N8b2vbqq69qzJgxuuGGG9SvXz+NGjVKzz77bKjDCmvjxo1TcXGx3nvvPUnS3/72N23evFnXXHNNiCNzhurqanm93oA/n/Hx8Ro7diy/D9BKt1AHcLr861//UnNzsxISEgLOJyQkaN++fSGKyjn8fr9yc3M1fvx4DR8+PNThhLWXXnpJlZWV2r59e6hDcYS///3vWrFihfLy8nTfffdp+/btuuOOOxQVFaVp06aFOrywNHfuXPl8Pg0ePFiRkZFqbm7Wo48+qszMzFCH5gher1eS2vx90HINaHHGJEronOzsbO3evVubN28OdShh7aOPPtLs2bNVVFSk6OjoUIfjCH6/X2PGjNFjjz0mSRo1apR2796tgoICEiULL7/8stasWaO1a9dq2LBhqqqqUm5urjweD98ZYLMzZujtnHPOUWRkpGprawPO19bWyu12hygqZ8jJydHGjRv1l7/8Rf379w91OGGtoqJCdXV1uuiii9StWzd169ZNJSUlWrZsmbp166bm5uZQhxh2EhMTNXTo0IBzQ4YM0YEDB0IUUfi76667NHfuXE2dOlUjRozQLbfcojlz5mjhwoWhDs0RWn7m8/sA7XHGJEpRUVEaPXq0iouLzXN+v1/FxcVKSUkJYWThyzAM5eTkaP369dq0aZOSkpJCHVLYmzBhgnbt2qWqqirzGDNmjDIzM1VVVaXIyMhQhxh2xo8f32rZiffee0+DBg0KUUTh7/PPP1dEROCP78jISPn9/hBF5CxJSUlyu90Bvw98Pp/Ky8v5fYBWzqiht7y8PE2bNk1jxozRJZdcoiVLlqihoUHTp08PdWhhKTs7W2vXrtUf/vAH9ezZ0xy7j4+PV0xMTIijC089e/ZsNYerR48e6tu3L3O7LMyZM0fjxo3TY489ph/96Efatm2bVq1apVWrVoU6tLA1ZcoUPfrooxo4cKCGDRumnTt3avHixbrttttCHVrYqK+v1wcffGC+rq6uVlVVlfr06aOBAwcqNzdXjzzyiM4//3wlJSVp3rx58ng8ysjICF3QCE+hfuzudHv66aeNgQMHGlFRUcYll1xibN26NdQhhS1JbR7PP/98qENzFJYHOLU//vGPxvDhw43u3bsbgwcPNlatWhXqkMKaz+czZs+ebQwcONCIjo42vvvd7xr333+/8eWXX4Y6tLDxl7/8pc2fX9OmTTMM4/gSAfPmzTMSEhKM7t27GxMmTDD2798f2qARllyGwVKuAAAAbTlj5igBAAB0FIkSAACABRIlAAAACyRKAAAAFkiUAAAALJAoAQAAWCBRAgAAsECiBAAAYIFECQAAwAKJEgAAgAUSJQAAAAskSgAAABb+P8RsPNkQX6uaAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x550 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from envs.minigrid.env_utils import random_exploration_fourrooms, q_learning_fourrooms\n",
    "\n",
    "train_layout_data = []\n",
    "NUM_TRAIN_LAYOUTS = 10\n",
    "NUM_TRAIN_STEPS = 100\n",
    "NUM_TRAIN_EPISODES = 1000\n",
    "seeds = np.arange(0, NUM_TRAIN_LAYOUTS)\n",
    "\n",
    "for i in tqdm(range(len(seeds))):\n",
    "    env = FourRoomsMazeEnv(Maze(seed=seeds[i], maze_type='fourrooms_random_layouts'), max_steps=NUM_TRAIN_STEPS)\n",
    "    dataset, env = random_exploration_fourrooms(env, num_episodes=NUM_TRAIN_EPISODES, layout_type=i, num_mdp=NUM_TRAIN_LAYOUTS, start_pos=None)\n",
    "    train_layout_data.append(dataset)\n",
    "    \n",
    "pprint(jax.tree.map(lambda x: x.shape, train_layout_data[0]))\n",
    "\n",
    "coverage_map = np.zeros(shape=env.maze.size)\n",
    "for layout in train_layout_data:\n",
    "    for obs in layout['observations']:\n",
    "        obs = obs.astype(np.int16)\n",
    "        coverage_map[obs[1], obs[0]] += 1\n",
    "        \n",
    "plt.imshow(coverage_map, cmap='inferno', vmin=0)\n",
    "plt.colorbar()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb38f3bb",
   "metadata": {},
   "source": [
    "# Initialize BFB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "982de61f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\">{</span>\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'seed'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">42</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'run_group'</span>: <span style=\"color: #008000; text-decoration-color: #008000\">'dynamics_fb'</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'save_dir'</span>: <span style=\"color: #008000; text-decoration-color: #008000\">'experiment_logs/'</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'train_steps'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">200001</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'log_interval'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10000</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_interval'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">30000</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_tasks'</span>: <span style=\"color: #800080; text-decoration-color: #800080; font-style: italic\">None</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_episodes'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">20</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_temperature'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_gaussian'</span>: <span style=\"color: #800080; text-decoration-color: #800080; font-style: italic\">None</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'video_episodes'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'video_frame_skip'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'eval_on_cpu'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'frame_stack'</span>: <span style=\"color: #800080; text-decoration-color: #800080; font-style: italic\">None</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'p_aug'</span>: <span style=\"color: #800080; text-decoration-color: #800080; font-style: italic\">None</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'agent'</span>: <span style=\"font-weight: bold\">{</span>\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'agent_name'</span>: <span style=\"color: #008000; text-decoration-color: #008000\">'dynamics_fb'</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'lr'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0003</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'batch_size'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1024</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'discrete'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'discount'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.99</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'tau'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.01</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'clip_by_global_norm'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'dataset_class'</span>: <span style=\"color: #008000; text-decoration-color: #008000\">'GCDataset'</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'value_p_curgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'value_p_trajgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'value_p_randomgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'value_geom_sample'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'actor_p_curgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'actor_p_trajgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'actor_p_randomgoal'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'actor_geom_sample'</span>: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'gc_negative'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'p_aug'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'frame_stack'</span>: <span style=\"color: #800080; text-decoration-color: #800080; font-style: italic\">None</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'z_dim'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">150</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'z_mix_ratio'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.5</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'boltzmann'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'f_hidden_dims'</span>: <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1024</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">512</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">512</span><span style=\"font-weight: bold\">]</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'f_layer_norm'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'b_hidden_dims'</span>: <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">512</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">512</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">512</span><span style=\"font-weight: bold\">]</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'b_layer_norm'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'use_context'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'number_of_meta_envs'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'dyn_encoder_warmup_steps'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">80000</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'n_blocks'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'n_heads'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'emb_dim'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">96</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'mlp_dim'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">256</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'output_dim'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">32</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'context_len'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'use_masked_attention'</span>: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'use_mean_embedding'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'cosine_schedule'</span>: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'world_pred_hidden'</span>: <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">256</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">256</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">256</span><span style=\"font-weight: bold\">]</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   │   </span><span style=\"color: #008000; text-decoration-color: #008000\">'num_eval_episodes'</span>: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">20</span>\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"font-weight: bold\">}</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'env'</span>: <span style=\"font-weight: bold\">{</span><span style=\"color: #008000; text-decoration-color: #008000\">'env_name'</span>: <span style=\"color: #008000; text-decoration-color: #008000\">'fourrooms-dynamics'</span>, <span style=\"color: #008000; text-decoration-color: #008000\">'discrete'</span>: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span><span style=\"font-weight: bold\">}</span>,\n",
       "<span style=\"color: #7fbf7f; text-decoration-color: #7fbf7f\">│   </span><span style=\"color: #008000; text-decoration-color: #008000\">'tags'</span>: <span style=\"font-weight: bold\">[</span><span style=\"color: #008000; text-decoration-color: #008000\">'dynamics-fb'</span>, <span style=\"color: #008000; text-decoration-color: #008000\">'4rooms'</span>, <span style=\"color: #008000; text-decoration-color: #008000\">'discrete'</span><span style=\"font-weight: bold\">]</span>\n",
       "<span style=\"font-weight: bold\">}</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1m{\u001b[0m\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'seed'\u001b[0m: \u001b[1;36m42\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'run_group'\u001b[0m: \u001b[32m'dynamics_fb'\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'save_dir'\u001b[0m: \u001b[32m'experiment_logs/'\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'train_steps'\u001b[0m: \u001b[1;36m200001\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'log_interval'\u001b[0m: \u001b[1;36m10000\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_interval'\u001b[0m: \u001b[1;36m30000\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_tasks'\u001b[0m: \u001b[3;35mNone\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_episodes'\u001b[0m: \u001b[1;36m20\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_temperature'\u001b[0m: \u001b[1;36m0\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_gaussian'\u001b[0m: \u001b[3;35mNone\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'video_episodes'\u001b[0m: \u001b[1;36m1\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'video_frame_skip'\u001b[0m: \u001b[1;36m3\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'eval_on_cpu'\u001b[0m: \u001b[1;36m0\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'frame_stack'\u001b[0m: \u001b[3;35mNone\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'p_aug'\u001b[0m: \u001b[3;35mNone\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'agent'\u001b[0m: \u001b[1m{\u001b[0m\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'agent_name'\u001b[0m: \u001b[32m'dynamics_fb'\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'lr'\u001b[0m: \u001b[1;36m0.0003\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'batch_size'\u001b[0m: \u001b[1;36m1024\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'discrete'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'discount'\u001b[0m: \u001b[1;36m0.99\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'tau'\u001b[0m: \u001b[1;36m0.01\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'clip_by_global_norm'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'dataset_class'\u001b[0m: \u001b[32m'GCDataset'\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'value_p_curgoal'\u001b[0m: \u001b[1;36m0.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'value_p_trajgoal'\u001b[0m: \u001b[1;36m1.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'value_p_randomgoal'\u001b[0m: \u001b[1;36m0.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'value_geom_sample'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'actor_p_curgoal'\u001b[0m: \u001b[1;36m0.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'actor_p_trajgoal'\u001b[0m: \u001b[1;36m0.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'actor_p_randomgoal'\u001b[0m: \u001b[1;36m1.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'actor_geom_sample'\u001b[0m: \u001b[3;91mFalse\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'gc_negative'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'p_aug'\u001b[0m: \u001b[1;36m0.0\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'frame_stack'\u001b[0m: \u001b[3;35mNone\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'z_dim'\u001b[0m: \u001b[1;36m150\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'z_mix_ratio'\u001b[0m: \u001b[1;36m0.5\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'boltzmann'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'f_hidden_dims'\u001b[0m: \u001b[1m[\u001b[0m\u001b[1;36m1024\u001b[0m, \u001b[1;36m512\u001b[0m, \u001b[1;36m512\u001b[0m\u001b[1m]\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'f_layer_norm'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'b_hidden_dims'\u001b[0m: \u001b[1m[\u001b[0m\u001b[1;36m512\u001b[0m, \u001b[1;36m512\u001b[0m, \u001b[1;36m512\u001b[0m\u001b[1m]\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'b_layer_norm'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'use_context'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'number_of_meta_envs'\u001b[0m: \u001b[1;36m10\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'dyn_encoder_warmup_steps'\u001b[0m: \u001b[1;36m80000\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'n_blocks'\u001b[0m: \u001b[1;36m4\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'n_heads'\u001b[0m: \u001b[1;36m4\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'emb_dim'\u001b[0m: \u001b[1;36m96\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'mlp_dim'\u001b[0m: \u001b[1;36m256\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'output_dim'\u001b[0m: \u001b[1;36m32\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'context_len'\u001b[0m: \u001b[1;36m100\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'use_masked_attention'\u001b[0m: \u001b[3;91mFalse\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'use_mean_embedding'\u001b[0m: \u001b[3;92mTrue\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'cosine_schedule'\u001b[0m: \u001b[3;91mFalse\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'world_pred_hidden'\u001b[0m: \u001b[1m[\u001b[0m\u001b[1;36m256\u001b[0m, \u001b[1;36m256\u001b[0m, \u001b[1;36m256\u001b[0m\u001b[1m]\u001b[0m,\n",
       "\u001b[2;32m│   │   \u001b[0m\u001b[32m'num_eval_episodes'\u001b[0m: \u001b[1;36m20\u001b[0m\n",
       "\u001b[2;32m│   \u001b[0m\u001b[1m}\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'env'\u001b[0m: \u001b[1m{\u001b[0m\u001b[32m'env_name'\u001b[0m: \u001b[32m'fourrooms-dynamics'\u001b[0m, \u001b[32m'discrete'\u001b[0m: \u001b[3;92mTrue\u001b[0m\u001b[1m}\u001b[0m,\n",
       "\u001b[2;32m│   \u001b[0m\u001b[32m'tags'\u001b[0m: \u001b[1m[\u001b[0m\u001b[32m'dynamics-fb'\u001b[0m, \u001b[32m'4rooms'\u001b[0m, \u001b[32m'discrete'\u001b[0m\u001b[1m]\u001b[0m\n",
       "\u001b[1m}\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'actions': (1000000,), 'layout_type': (1000000, 10), 'next_observations': (1000000, 2), 'observations': (1000000, 2), 'terminals': (1000000,)}\n"
     ]
    }
   ],
   "source": [
    "import functools\n",
    "from utils.datasets import Dataset, GCDataset\n",
    "\n",
    "with initialize(version_base=None, config_path=\"../configs/\"):\n",
    "    fb_config = compose(config_name='entry.yaml', overrides=['experiment=fb_dynamics_discrete_4rooms.yaml',\n",
    "                                                            f'agent.number_of_meta_envs={NUM_TRAIN_LAYOUTS}',\n",
    "                                                            f'agent.discount=0.99',\n",
    "                                                            f'agent.z_dim=150',\n",
    "                                                            f'agent.output_dim=32',\n",
    "                                                            f'agent.z_mix_ratio=0.5'])\n",
    "    fb_config = OmegaConf.to_container(fb_config, resolve=True)\n",
    "    pprint(fb_config)\n",
    "\n",
    "def concatenate_dicts(dict1, dict2):\n",
    "    return jax.tree.map(lambda x, y: jnp.concatenate([x, y]), dict1, dict2)\n",
    "\n",
    "whole_data = functools.reduce(concatenate_dicts, train_layout_data)\n",
    "# SAVING\n",
    "# np.save(f\"../aux_data/fourrooms_meta{NUM_TRAIN_LAYOUTS}_data\", arr=jax.device_get(whole_data))\n",
    "# whole_data = np.load(f\"../aux_data/fourrooms_meta{NUM_TRAIN_LAYOUTS}_data.npy\", allow_pickle=True).item()\n",
    "\n",
    "print(jax.tree.map(lambda x: x.shape, whole_data))\n",
    "whole_dataset = Dataset.create(**jax.device_get(whole_data))\n",
    "gc_whole_dataset = GCDataset(whole_dataset, config=fb_config['agent'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "557e636d",
   "metadata": {},
   "outputs": [],
   "source": [
    "sys.path.append(\"..\")\n",
    "from agents.dynamics_fb import ForwardBackwardAgent\n",
    "\n",
    "gc_whole_dataset = GCDataset(whole_dataset, config=fb_config['agent'])\n",
    "example_batch = gc_whole_dataset.sample(1)\n",
    "fb_agent = ForwardBackwardAgent.create(\n",
    "    0,\n",
    "    example_batch['observations'],\n",
    "    np.full_like(example_batch['actions'], env.action_space.n - 1),\n",
    "    config=fb_config['agent']\n",
    ")\n",
    "batch = gc_whole_dataset.sample(2, layout_type=0, context_length=NUM_TRAIN_STEPS)[1]\n",
    "fb_agent, info = fb_agent.update(batch, train_context_embedding=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ea6398e7",
   "metadata": {},
   "source": [
    "# Train BFB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5c1d2fc6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+eabxjfffGOMGzfO6NKli1FZWek4ZtSoUUb//v2NL774wvj000+N7t27G9dff73j8ZKSEiMhIcG44YYbjC1bthivvPKKERoaaixatMhxzP/+9z/D39/fePTRR41t27YZf/zjH43AwEBj8+bNrXMyDMN4+OGHjbi4OOOdd94xdu/ebSxbtsyIiIgwnnzySccx3nw+VqxYYTz44IPG66+/bkgy3njjDafH3emzN6SWljwfxcXFRmZmprF06VIjNzfXWLt2rTFkyBBj4MCBTq/hK+fjRK+//rrRv39/o3379sYTTzzhs+dj586dRmxsrHH33XcbGzZsMHbu3Gm89dZbTn/Ge9PfN2c6H1OmTDG6detmrFmzxti9e7exaNEiw9/f33jrrbe88nx42vevM9XSEASL0xgyZIgxbdo0x22r1Wq0b9/emDNnjolVNd2hQ4cMScbHH39sGEbdX46BgYHGsmXLHMfk5OQYkoy1a9cahlH3h4Wfn5+Rn5/vOOaZZ54xoqKijKqqKsMwDOOee+4xzjrrLKf3Gj9+vDFy5EjHbXc6p0ePHjV69OhhrF692hg+fLgjWPja+bj33nuN884775SP22w2IzEx0Xjssccc9xUXFxvBwcHGK6+8YhiGYWzbts2QZHz11VeOY1auXGlYLBbjwIEDhmEYxt///nejTZs2jvNjf+9evXo5bl977bXGJZdc4vT+GRkZxtSpU5v2IV1wySWXGL/+9a+d7rvyyiuNG264wTAM3zofP/9i4E6fvSG1NLfTfZG2W7dunSHJ2Lt3r2EYvnk+fvjhByM5OdnYsmWL0blzZ6dg4WvnY/z48caNN954yud489839Z2Ps846y3jooYec7jv77LONBx980DAM7z4fhuHe378aUktDsBXqFKqrq7V+/XplZmY67vPz81NmZqbWrl1rYmVNV1JSIkmKjY2VJK1fv141NTVOnzU1NVWdOnVyfNa1a9eqb9++SkhIcBwzcuRIlZaWauvWrY5jTnwN+zH213C3czpt2jRdcsklJ9Xsa+dj+fLlGjRokK655hq1a9dOAwYM0LPPPut4fPfu3crPz3eqMzo6WhkZGU7nIyYmRoMGDXIck5mZKT8/P3355ZeOY37xi18oKCjIcczIkSO1fft2HTlyxHHM6c5Zazj33HOVnZ2tHTt2SJK++eYbffbZZxo9erQk3zsfJ3Knz96QWsxQUlIii8WimJgYSb53Pmw2m2666SbdfffdOuuss0563JfOh81m07vvvquePXtq5MiRateunTIyMpy2B/na3zfnnnuuli9frgMHDsgwDK1Zs0Y7duzQxRdfLMn7z4c7f/9qSC0NQbA4haKiIlmtVqf/kJKUkJCg/Px8k6pqOpvNpjvuuEPDhg1Tnz59JEn5+fkKCgpy/EVod+Jnzc/Pr/dc2B873TGlpaWqrKx0q3O6ZMkSbdiwQXPmzDnpMV87H7t27dIzzzyjHj166L333tNvf/tb3XbbbfrXv/7l+Bz2uk5VZ35+vtq1a+f0eEBAgGJjY5vlnLXm+bjvvvt03XXXKTU1VYGBgRowYIDuuOMO3XDDDU61+sr5OJE7ffaG1NLajh07pnvvvVfXX3+9oqKiJPne+fjLX/6igIAA3XbbbfU+7kvn49ChQyorK9PcuXM1atQovf/++7riiit05ZVX6uOPP3bU6Ut/3zz11FPq3bu3OnTooKCgII0aNUoLFizQL37xC8fn8Nbz4e7fvxpSS0MENPhIeIVp06Zpy5Yt+uyzz8wuxTT79+/X7bffrtWrVyskJMTsckxns9k0aNAgPfLII5KkAQMGaMuWLVq4cKEmTpxocnWt79VXX9VLL72kl19+WWeddZY2bdqkO+64Q+3bt/fJ84GGqamp0bXXXivDMPTMM8+YXY4p1q9fryeffFIbNmyQxWIxuxzT2Ww2SdJll12mO++8U5KUnp6uzz//XAsXLtTw4cPNLM8UTz31lL744gstX75cnTt31ieffKJp06apffv2J/2Lu7fxle9frFicQnx8vPz9/U/qhi8oKFBiYqJJVTXN9OnT9c4772jNmjXq0KGD4/7ExERVV1eruLjY6fgTP2tiYmK958L+2OmOiYqKUmhoqNuc0/Xr1+vQoUM6++yzFRAQoICAAH388cf629/+poCAACUkJPjU+UhKSlLv3r2d7ktLS3NMLbHXcro6ExMTdejQIafHa2trdfjw4WY5Z615Pu6++27HqkXfvn1100036c4773Ssbvna+TiRO332htTSWuyhYu/evVq9erVjtcJep6+cj08//VSHDh1Sp06dHH+27t27V3fddZdSUlIcdfrK+YiPj1dAQMAZ/3z1lb9vKisr9cADD2jevHkaO3as+vXrp+nTp2v8+PF6/PHHHZ/DG8+HJ3z/akgtDUGwOIWgoCANHDhQ2dnZjvtsNpuys7M1dOhQEytznWEYmj59ut544w19+OGH6tKli9PjAwcOVGBgoNNn3b59u/bt2+f4rEOHDtXmzZud/kKw/wVq/0Nz6NChTq9hP8b+Gu5yTi+66CJt3rxZmzZtcvwMGjRIN9xwg+N3Xzofw4YNO2n83Y4dO9S5c2dJUpcuXZSYmOhUZ2lpqb788kun81FcXKz169c7jvnwww9ls9mUkZHhOOaTTz5RTU2N45jVq1erV69eatOmjeOY052z1lBRUSE/P+c/Gv39/R3/+uhr5+NE7vTZG1JLa7CHiu+++04ffPCB4uLinB73pfNx00036dtvv3X6s7V9+/a6++679d577zk+h6+cj6CgIA0ePPi0f7760t+/NTU1qqmpOe2fr952Pjzp+1dDamnoh8YpLFmyxAgODjZeeOEFY9u2bcZvfvMbIyYmxqkz3xP89re/NaKjo42PPvrIyMvLc/xUVFQ4jrn11luNTp06GR9++KHx9ddfG0OHDjWGDh3qeNw+7uziiy82Nm3aZKxatcpo27ZtvePO7r77biMnJ8dYsGBBvePO3PGcnjgVyjB863ysW7fOCAgIMB5++GHju+++M1566SUjLCzM+M9//uM4Zu7cuUZMTIzx1ltvGd9++61x2WWX1TtidMCAAcaXX35pfPbZZ0aPHj2cRkgWFxcbCQkJxk033WRs2bLFWLJkiREWFnbSCMmAgADj8ccfN3JycoyZM2e2+rjZiRMnGsnJyY5xs6+//roRHx9v3HPPPY5jvPl8HD161Ni4caOxceNGQ5Ixb948Y+PGjY4pR+702RtSS0uej+rqamPcuHFGhw4djE2bNjn9+XriRCNfOR/1+flUKF87H6+//roRGBho/OMf/zC+++47xxjQTz/91PEa3vT3zZnOx/Dhw42zzjrLWLNmjbFr1y7j+eefN0JCQoy///3vXnk+PO3715lqaQiCxRk89dRTRqdOnYygoCBjyJAhxhdffGF2SS6TVO/P888/7zimsrLS+N3vfme0adPGCAsLM6644gojLy/P6XX27NljjB492ggNDTXi4+ONu+66y6ipqXE6Zs2aNUZ6eroRFBRkdO3a1ek97NzxnP48WPja+Xj77beNPn36GMHBwUZqaqrxj3/8w+lxm81m/OlPfzISEhKM4OBg46KLLjK2b9/udMyPP/5oXH/99UZERIQRFRVlTJ482Th69KjTMd98841x3nnnGcHBwUZycrIxd+7ck2p59dVXjZ49expBQUHGWWedZbz77rvN/4FPo7S01Lj99tuNTp06GSEhIUbXrl2NBx980OmLojefjzVr1tT758XEiRMNw3Cvz96QWlryfOzevfuUf76uWbPG585HfeoLFr52Pp577jmje/fuRkhIiNG/f3/jzTffdHoNb/r75kznIy8vz5g0aZLRvn17IyQkxOjVq5fx17/+1bDZbF55Pjzt+1dDajkTy/EPDgAAAACNRo8FAAAAgCYjWAAAAABoMoIFAAAAgCYjWAAAAABoMoIFAAAAgCYjWAAAAABoMoIFAAAAgCYjWAAAAABoMoIFAHihWbNmKSIiQpJUXFysWbNmadu2babUMn/+fK1YseKk+1NSUjR9+nQTKgIAtASCBQB4ueLiYs2ePdvtgsUbb7yhP/zhDyZUBABoCQFmFwAA8CyGYai6ulrBwcFNep0BAwY0U0UAAHfAigUAeLE9e/aoS5cukqRrrrlGFotFFotFe/bskSRVVVXpgQceUOfOnRUcHKy0tDS9/PLLTq8xadIk9enTRytWrFD//v0VHByst99+W+Xl5Zo+fbp69eqlsLAwpaSk6NZbb1VJSYnjuSkpKdq7d68WLFjgeO8XXnjB8djPt0K9/vrrSk9PV0hIiNq3b6+srCwdO3bM8fhHH30ki8Wi1atX61e/+pUiIyPVuXNnPfroo06vs3XrVo0ZM0ZxcXEKCwtTr169TjoGANC8WLEAAC+WlJSk119/XVdeeaUeeeQRXXjhhY77Jenaa6/VZ599ppkzZyotLU0rVqzQjTfeqDZt2mj06NGO1zl48KBuu+02/fGPf1SnTp3UqVMnVVRUyGq16uGHH1bbtm21f/9+Pfzww7r88su1Zs0aSXXbncaMGaPzzjtPd911lySpW7du9da6fPlyXX311bruuus0d+5c5ebm6oEHHtC+ffv02muvOR1766236qabbtIbb7yhN998U/fee6/69eunUaNGSZLGjh2rhIQEPffcc4qOjtbOnTv1ww8/NO/JBQA4IVgAgBcLDg52bDnq0aOHzjnnHMdja9as0fLly/Xee+/p4osvliSNGDFCeXl5mjlzplOwOHLkiFauXKmMjAyn13/mmWccv9fW1qpLly4677zztGPHDvXs2VMDBgxQcHCwEhISnN67PrNmzdI555zjWDEZNWqUwsLCNHXqVG3evFl9+/Z1HHvVVVdp1qxZkqSLLrpI7777rl577TWNGjVKRUVF2r17t5588kmNHTtWkhyBCgDQctgKBQA+6v3331dsbKx++ctfqra21vEzYsQIbdy4UVar1XFsXFzcSaFCkl588UUNGDBAERERCgwM1HnnnSdJ2rFjh0u1lJWVadOmTbr66qud7h8/frwk6bPPPnO63x6EJMlisSgtLc2xIhEXF6fOnTvr/vvv17/+9S9WKgCglRAsAMBHFRUV6fDhwwoMDHT6ueWWW1RbW6u8vDzHsQkJCSc9/4033tCECRM0ZMgQvfrqq/riiy/0xhtvSJJTX0RDFBcXyzCMk94nOjpawcHBOnz4sNP9MTExTreDgoIc72mxWPT+++8rLS1N06ZNU8eOHTVo0CB98sknLtUEAHANW6EAwEfFxsaqbdu29Y6ClaR27do5frdYLCc9vmzZMqWnp2vRokWO+z7++ONG1RITEyOLxaJDhw453V9SUqKqqirFxsa69Ho9e/bUsmXLVFNTo88//1wPPPCAxo4dqwMHDjiu7wEAaF6sWACAlwsKCpJ08ipCZmamCgsLFRQUpEGDBp30Y3/eqVRWVp50zEsvvVTv+59pBSMiIkLp6eknNWm/+uqrkuTYYuWqwMBADR8+XPfdd59KS0t18ODBRr0OAODMWLEAAC+XmJiomJgYvfLKK+rSpYuCg4PVr18/jRgxQmPHjtWoUaN0zz33qF+/fiovL9fWrVu1c+dO/fOf/zzt644YMULTpk3Tn//8Zw0dOlQrVqxQdnb2ScelpaXpww8/1OrVq9WmTRt16dJFcXFxJx03a9YsXX755brxxht14403avv27XrggQd01VVXOTVun8m3336ru+66S+PHj1e3bt1UUlKiOXPmKCUl5ZQTqQAATceKBQB4OT8/Pz3//PPavXu3LrroIg0ePNjxL/evvfaabr31Vv3973/X6NGjdfPNN+v999/X8OHDz/i6U6dO1V133aWnnnpKV155pfbv33/SNTAk6ZFHHlGHDh101VVXafDgwXr77bfrfb1x48Zp2bJl2rx5sy677DLNnTtXv/nNb/Sf//zHpc+bmJioxMREzZkzR6NHj9bUqVPVsWNHvf/++/L393fptQAADWcxDMMwuwgAAAAAno0VCwAAAABNRrAAAAAA0GQECwAAAABNRrAAAAAA0GQECwAAAABNRrAAAAAA0GQECwAAAABNRrAAAAAA0GQECwAAAABNRrAAAAAA0GQECwAAAABNRrAAAAAA0GT/D3FA38EKvPPyAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x550 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[6], line 89\u001b[0m\n\u001b[1;32m     86\u001b[0m PRETRAIN_ENCODER_STEPS \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m80_000\u001b[39m \u001b[38;5;66;03m# number of steps to train contexual transformer\u001b[39;00m\n\u001b[1;32m     88\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m update_step \u001b[38;5;129;01min\u001b[39;00m pbar:\n\u001b[0;32m---> 89\u001b[0m     batch \u001b[38;5;241m=\u001b[39m \u001b[43mgc_whole_dataset\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msample\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfb_config\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43magent\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mbatch_size\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlayout_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcontext_length\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mNUM_TRAIN_STEPS\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mget_traj_batch\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m[\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     90\u001b[0m     fb_agent, info \u001b[38;5;241m=\u001b[39m fb_agent\u001b[38;5;241m.\u001b[39mupdate(batch, train_context_embedding\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m \u001b[38;5;28;01mif\u001b[39;00m update_step \u001b[38;5;241m<\u001b[39m PRETRAIN_ENCODER_STEPS \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[1;32m     92\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m update_step \u001b[38;5;241m>\u001b[39m PRETRAIN_ENCODER_STEPS \u001b[38;5;129;01mand\u001b[39;00m update_step \u001b[38;5;241m%\u001b[39m \u001b[38;5;241m30_000\u001b[39m \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m:\n",
      "File \u001b[0;32m~/ZeroShotRL/notebooks/../utils/datasets.py:271\u001b[0m, in \u001b[0;36mGCDataset.sample\u001b[0;34m(self, batch_size, idxs, evaluation, layout_type, context_length, layout_number, custom_layout, get_traj_batch)\u001b[0m\n\u001b[1;32m    269\u001b[0m \u001b[38;5;66;03m# for dynamics-aware\u001b[39;00m\n\u001b[1;32m    270\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m layout_type \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mor\u001b[39;00m get_traj_batch \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[0;32m--> 271\u001b[0m     context_batch \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msample_traj_random\u001b[49m\u001b[43m(\u001b[49m\u001b[43mbatch_size\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcontext_length\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    272\u001b[0m     context_batch2 \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39msample_traj_random(batch_size, context_length)\n\u001b[1;32m    273\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m batch, context_batch, context_batch2\n",
      "File \u001b[0;32m~/ZeroShotRL/notebooks/../utils/datasets.py:363\u001b[0m, in \u001b[0;36mGCDataset.sample_traj_random\u001b[0;34m(self, batch_size, context_length)\u001b[0m\n\u001b[1;32m    361\u001b[0m batch[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtraj_states\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m jax\u001b[38;5;241m.\u001b[39mtree_map(\u001b[38;5;28;01mlambda\u001b[39;00m arr: arr[traj_indx], \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mobservations\u001b[39m\u001b[38;5;124m'\u001b[39m])\n\u001b[1;32m    362\u001b[0m batch[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtraj_actions\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m jax\u001b[38;5;241m.\u001b[39mtree_map(\u001b[38;5;28;01mlambda\u001b[39;00m arr: arr[traj_indx], \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mactions\u001b[39m\u001b[38;5;124m'\u001b[39m])[\u001b[38;5;241m.\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;241m.\u001b[39m, \u001b[38;5;28;01mNone\u001b[39;00m]\n\u001b[0;32m--> 363\u001b[0m batch[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtraj_next_states\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[43mjax\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtree_map\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43;01mlambda\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43marr\u001b[49m\u001b[43m:\u001b[49m\u001b[43m \u001b[49m\u001b[43marr\u001b[49m\u001b[43m[\u001b[49m\u001b[43mtraj_indx\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdataset\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mnext_observations\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    364\u001b[0m \u001b[38;5;66;03m# batch['traj_states'] = np.concatenate([batch['observations'][:,None,:], batch['traj_states']], axis=1)\u001b[39;00m\n\u001b[1;32m    365\u001b[0m \u001b[38;5;66;03m# batch['traj_actions'] = np.concatenate([batch['actions'][:, None], batch['traj_actions']], axis=1)[..., None]\u001b[39;00m\n\u001b[1;32m    366\u001b[0m \u001b[38;5;66;03m# batch['traj_next_states'] = np.concatenate([batch['traj_states'][:, 1:, :], batch['traj_states'][:, -1, :][:, None]], axis=1)\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    373\u001b[0m \u001b[38;5;66;03m# rand_indx_decode = rand_indx_decode.reshape(batch_size, num_random_states_decode)\u001b[39;00m\n\u001b[1;32m    374\u001b[0m \u001b[38;5;66;03m# batch['random_states_decode'] = jax.tree_map(lambda arr: arr[rand_indx_decode], self.dataset['observations'])\u001b[39;00m\n\u001b[1;32m    375\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m batch\n",
      "File \u001b[0;32m~/miniconda3/envs/jax2/lib/python3.10/site-packages/jax/_src/tree_util.py:358\u001b[0m, in \u001b[0;36mtree_map\u001b[0;34m(f, tree, is_leaf, *rest)\u001b[0m\n\u001b[1;32m    356\u001b[0m leaves, treedef \u001b[38;5;241m=\u001b[39m tree_flatten(tree, is_leaf)\n\u001b[1;32m    357\u001b[0m all_leaves \u001b[38;5;241m=\u001b[39m [leaves] \u001b[38;5;241m+\u001b[39m [treedef\u001b[38;5;241m.\u001b[39mflatten_up_to(r) \u001b[38;5;28;01mfor\u001b[39;00m r \u001b[38;5;129;01min\u001b[39;00m rest]\n\u001b[0;32m--> 358\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mtreedef\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43munflatten\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mxs\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mxs\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mzip\u001b[39;49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mall_leaves\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/jax2/lib/python3.10/site-packages/jax/_src/tree_util.py:358\u001b[0m, in \u001b[0;36m<genexpr>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    356\u001b[0m leaves, treedef \u001b[38;5;241m=\u001b[39m tree_flatten(tree, is_leaf)\n\u001b[1;32m    357\u001b[0m all_leaves \u001b[38;5;241m=\u001b[39m [leaves] \u001b[38;5;241m+\u001b[39m [treedef\u001b[38;5;241m.\u001b[39mflatten_up_to(r) \u001b[38;5;28;01mfor\u001b[39;00m r \u001b[38;5;129;01min\u001b[39;00m rest]\n\u001b[0;32m--> 358\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m treedef\u001b[38;5;241m.\u001b[39munflatten(\u001b[43mf\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mxs\u001b[49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mfor\u001b[39;00m xs \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mzip\u001b[39m(\u001b[38;5;241m*\u001b[39mall_leaves))\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "from envs.custom_mazes.env_utils import policy_image_fourrooms, value_image_fourrooms, plot_policy, get_canvas_image,\\\n",
    "    plot_value_image_fourrooms\n",
    "from functools import partial\n",
    "from utils.evaluation import supply_rng\n",
    "from IPython.display import clear_output\n",
    "\n",
    "from envs.env_utils import EpisodeMonitor\n",
    "from utils.evaluation import evaluate_fourrooms_dynamics\n",
    "from collections import defaultdict\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas\n",
    "from functools import partial\n",
    "import jax\n",
    "\n",
    "def policy_image_fourrooms(env, dataset, N, M, action_fn=None, **kwargs):\n",
    "    fig = plt.figure(tight_layout=True)\n",
    "    canvas = FigureCanvas(fig)\n",
    "    plot_policy(env, dataset, N, M, fig=fig, ax=plt.gca(), action_fn=action_fn, **kwargs)\n",
    "    # plt.savefig(\"dynamics_fb.svg\", dpi=300)\n",
    "    image = get_canvas_image(canvas)\n",
    "    plt.close(fig)\n",
    "    return image\n",
    "\n",
    "def value_image_fourrooms(env, dataset, value_fn, N, M, action_fn=None, **kwargs):\n",
    "    fig = plt.figure(tight_layout=True)\n",
    "    canvas = FigureCanvas(fig)\n",
    "    plot_value_image_fourrooms(env, dataset, value_fn, N, M, fig=fig, ax=plt.gca(), action_fn=action_fn, **kwargs)\n",
    "    # plt.savefig(\"dynamics_value.svg\", dpi=300)\n",
    "    image = get_canvas_image(canvas)\n",
    "    plt.close(fig)\n",
    "    return image\n",
    "\n",
    "START_POS = (1,1)\n",
    "def visualize_value_image(env, layout_type, task_num):\n",
    "    observation, info = env.setup_goals(seed=None, task_num=task_num, start_pos=START_POS)\n",
    "    goal = info.get(\"goal_pos\", None)\n",
    "    mdp_type=None\n",
    "    if fb_config['agent']['use_context']:\n",
    "        dataset_inference, env = random_exploration_fourrooms(env, num_episodes=1, layout_type=layout_type, num_mdp=NUM_TRAIN_LAYOUTS, start_pos=START_POS)\n",
    "        print(jax.tree.map(lambda x: x.shape, dataset_inference))\n",
    "        dynamics_embedding_mean, dynamics_mean_std = fb_agent.network.select('dynamic_transformer')(dataset_inference['observations'][None], dataset_inference['actions'][None, :, None],\n",
    "                                                                                    dataset_inference['next_observations'][None], train=False, return_embedding=True)\n",
    "        dynamics_embedding = dynamics_embedding_mean + jax.random.normal(key=GLOBAL_KEY, shape=dynamics_embedding_mean.shape) * jnp.exp(dynamics_mean_std)\n",
    "        dynamics_embedding = dynamics_embedding.squeeze()\n",
    "\n",
    "    latent_z = jax.device_get(fb_agent.infer_z(goal, mdp_num=None, dynamics_embedding=dynamics_embedding)[None])\n",
    "    N, M = env.maze.size\n",
    "    pred_value_img = value_image_fourrooms(env, example_batch,N=N, M=M,\n",
    "                                value_fn=partial(fb_agent.predict_q, z=latent_z, mdp_num=mdp_type[None] if mdp_type is not None else None,\n",
    "                                                dynamics_embedding=dynamics_embedding[None]),\n",
    "                                action_fn=None, goal=goal)\n",
    "    return pred_value_img\n",
    "\n",
    "def visualize_policy(env, layout_type, task_num):\n",
    "    observation, info = env.setup_goals(seed=None, task_num=task_num, start_pos=START_POS)\n",
    "    goal = info.get(\"goal_pos\", None)\n",
    "    if fb_config['agent']['use_context']:\n",
    "        dataset_inference, env = random_exploration_fourrooms(env, num_episodes=1, layout_type=layout_type, num_mdp=NUM_TRAIN_LAYOUTS, start_pos=START_POS)\n",
    "        print(jax.tree.map(lambda x: x.shape, dataset_inference))\n",
    "        dynamics_embedding_mean, dynamics_mean_std = fb_agent.network.select('dynamic_transformer')(dataset_inference['observations'][None], dataset_inference['actions'][None,:,None],\n",
    "                                                                                    dataset_inference['next_observations'][None], train=False, return_embedding=True)\n",
    "        dynamics_embedding = dynamics_embedding_mean + jax.random.normal(key=GLOBAL_KEY, shape=dynamics_embedding_mean.shape) * jnp.exp(dynamics_mean_std)\n",
    "        dynamics_embedding=dynamics_embedding.squeeze()\n",
    "        mdp_type=None\n",
    "        \n",
    "    latent_z = fb_agent.infer_z(goal, mdp_num=mdp_type, dynamics_embedding=dynamics_embedding)\n",
    "    # start = info.get(\"start_pos\", None)\n",
    "    example_batch = whole_dataset.sample(1)\n",
    "    mdp_type=None\n",
    "    N, M = env.maze.size\n",
    "    pred_policy_img = policy_image_fourrooms(env, example_batch, N=N, M=M,\n",
    "                                                    action_fn=partial(supply_rng(fb_agent.sample_actions,\n",
    "                                                                                rng=jax.random.PRNGKey(np.random.randint(0, 2**32))), latent_z=latent_z,\n",
    "                                                                    mdp_num=None, dynamics_embedding=dynamics_embedding[None], temperature=0.0),\n",
    "                                                    goal=goal)\n",
    "    return pred_policy_img\n",
    "\n",
    "training_steps = 200_001\n",
    "pbar = tqdm(range(training_steps))\n",
    "eval_history_train = []\n",
    "eval_history_test = []\n",
    "\n",
    "PRETRAIN_ENCODER_STEPS = 80_000 # number of steps to train contexual transformer\n",
    "\n",
    "for update_step in pbar:\n",
    "    batch = gc_whole_dataset.sample(fb_config['agent']['batch_size'], layout_type=None, context_length=NUM_TRAIN_STEPS, get_traj_batch=True)[1]\n",
    "    fb_agent, info = fb_agent.update(batch, train_context_embedding=True if update_step < PRETRAIN_ENCODER_STEPS else False)\n",
    "    \n",
    "    if update_step > PRETRAIN_ENCODER_STEPS and update_step % 30_000 == 0:\n",
    "        clear_output()\n",
    "        # TRAIN eval\n",
    "        env = FourRoomsMazeEnv(Maze(seed=4, maze_type='fourrooms_random_layouts'), max_steps=NUM_TRAIN_STEPS)\n",
    "        fig, ax = plt.subplots(nrows=2, ncols=2, figsize=(20, 10))\n",
    "        pred_policy_img = visualize_policy(env, layout_type=0, task_num=3)\n",
    "        \n",
    "        ax[0, 0].imshow(pred_policy_img)\n",
    "        pred_value_img = visualize_value_image(env, layout_type=0, task_num=3)\n",
    "        ax[0, 1].imshow(pred_value_img)\n",
    "        \n",
    "        # TEST eval\n",
    "        env = FourRoomsMazeEnv(Maze(seed=1111, maze_type='fourrooms_random_layouts'), max_steps=NUM_TRAIN_STEPS)\n",
    "        pred_policy_img = visualize_policy(env, layout_type=1, task_num=3)\n",
    "        ax[1, 0].imshow(pred_policy_img)\n",
    "        pred_value_img = visualize_value_image(env, layout_type=1, task_num=3)\n",
    "        ax[1, 1].imshow(pred_value_img)\n",
    "        \n",
    "        fig.suptitle(f\"Training step: {update_step}\")   \n",
    "        plt.tight_layout()\n",
    "        display(fig)\n",
    "        plt.close(fig)\n",
    "    \n",
    "    if (update_step > PRETRAIN_ENCODER_STEPS and update_step % 20_000 == 0) or update_step == PRETRAIN_ENCODER_STEPS:\n",
    "        clear_output()\n",
    "        fig, ax = plt.subplots()\n",
    "        ax.plot(eval_history_test, label='Test')\n",
    "        ax.plot(eval_history_train, label='Train')\n",
    "        ax.set_xlabel(\"Iterations\")\n",
    "        ax.set_ylabel(\"Accuracy\")\n",
    "        ax.set_xticks(np.arange(len(np.arange(training_steps, step=20_000))), labels=np.arange(training_steps, step=20_000))\n",
    "        plt.legend()\n",
    "        plt.tight_layout()\n",
    "        display(fig)\n",
    "        plt.close(fig)\n",
    "        \n",
    "        eval_metrics = {}\n",
    "        overall_metrics = defaultdict(list)\n",
    "\n",
    "        for task_id in range(3):\n",
    "            for env_id in range(fb_config['agent']['number_of_meta_envs']):\n",
    "                env = FourRoomsMazeEnv(Maze(seed=env_id, maze_type='fourrooms_random_layouts'), max_steps=fb_config['agent']['context_len'])\n",
    "                env = EpisodeMonitor(env, filter_regexes=['.*privileged.*', '.*proprio.*'])\n",
    "                dataset_inference, env = random_exploration_fourrooms(env, num_episodes=1, layout_type=0, num_mdp=fb_config['agent']['number_of_meta_envs'], start_pos=START_POS)\n",
    "                dynamics_embedding_mean, dynamics_mean_std = fb_agent.network.select('dynamic_transformer')(dataset_inference['observations'][None], dataset_inference['actions'][None,:,None],\n",
    "                                                                                            dataset_inference['next_observations'][None], train=False, return_embedding=True)\n",
    "                dynamics_embedding = dynamics_embedding_mean + jax.random.normal(key=GLOBAL_KEY, shape=dynamics_embedding_mean.shape) * jnp.exp(dynamics_mean_std)\n",
    "                dynamics_embedding=dynamics_embedding.squeeze()\n",
    "                eval_info, _, _ = evaluate_fourrooms_dynamics(\n",
    "                        agent=fb_agent,\n",
    "                        dynamics_embedding=dynamics_embedding,\n",
    "                        env=env,\n",
    "                        task_id=task_id,\n",
    "                        config=None,\n",
    "                        num_eval_episodes=5,\n",
    "                        num_video_episodes=0,\n",
    "                        video_frame_skip=1,\n",
    "                        eval_temperature=0.0,\n",
    "                        eval_gaussian=None,\n",
    "                        start_pos=START_POS\n",
    "                    )\n",
    "                eval_metrics.update(\n",
    "                    {f'evaluation/task_{task_id}_{k}': v for k, v in eval_info.items() if k != 'total.timesteps'}\n",
    "                )\n",
    "                for k, v in eval_info.items():\n",
    "                    overall_metrics[k].append(v)\n",
    "                    \n",
    "        for k, v in overall_metrics.items():\n",
    "            eval_metrics[f'evaluation/overall_{k}_train'] = np.mean(v)\n",
    "            \n",
    "        eval_history_train.append(eval_metrics['evaluation/overall_episode.final_reward_train'])\n",
    "        \n",
    "        eval_metrics = {}\n",
    "        overall_metrics = defaultdict(list)\n",
    "                    \n",
    "        for task_id in range(3):\n",
    "            for env_id in range(NUM_TRAIN_LAYOUTS+100, NUM_TRAIN_LAYOUTS + 110):\n",
    "                env = FourRoomsMazeEnv(Maze(seed=env_id, maze_type='fourrooms_random_layouts'), max_steps=fb_config['agent']['context_len'])\n",
    "                env = EpisodeMonitor(env, filter_regexes=['.*privileged.*', '.*proprio.*'])\n",
    "                dataset_inference, env = random_exploration_fourrooms(env, num_episodes=1, layout_type=0, num_mdp=NUM_TRAIN_LAYOUTS, start_pos=START_POS)\n",
    "                dynamics_embedding_mean, dynamics_mean_std = fb_agent.network.select('dynamic_transformer')(dataset_inference['observations'][None], dataset_inference['actions'][None,:,None],\n",
    "                                                                                            dataset_inference['next_observations'][None], train=False, return_embedding=True)\n",
    "                dynamics_embedding = dynamics_embedding_mean + jax.random.normal(key=GLOBAL_KEY, shape=dynamics_embedding_mean.shape) * jnp.exp(dynamics_mean_std)\n",
    "                dynamics_embedding=dynamics_embedding.squeeze()\n",
    "                eval_info, _, _ = evaluate_fourrooms_dynamics(\n",
    "                        agent=fb_agent,\n",
    "                        dynamics_embedding=dynamics_embedding,\n",
    "                        env=env,\n",
    "                        task_id=task_id,\n",
    "                        config=None,\n",
    "                        num_eval_episodes=5, ##\n",
    "                        num_video_episodes=0,\n",
    "                        video_frame_skip=1,\n",
    "                        eval_temperature=0.0,\n",
    "                        eval_gaussian=None,\n",
    "                        start_pos=START_POS\n",
    "                    )\n",
    "                eval_metrics.update(\n",
    "                    {f'evaluation/task_{task_id}_{k}': v for k, v in eval_info.items() if k != 'total.timesteps'}\n",
    "                    )\n",
    "                for k, v in eval_info.items():\n",
    "                    overall_metrics[k].append(v)\n",
    "                    \n",
    "        for k, v in overall_metrics.items():\n",
    "            eval_metrics[f'evaluation/overall_{k}_ood'] = np.mean(v)\n",
    "        eval_history_test.append(eval_metrics['evaluation/overall_episode.final_reward_ood'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "92a9395a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Performance of FB on Train and Test layouts across tasks')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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J4yNjcWlS5fk+gg6JzMzU5w9e1acPXtWABDLly8XZ8+eFTExMUIIIWbNmiVefPFFafnIyEhhamoqZs6cKSIiIsSqVauEnp6e2LVrl1wfQSfVdrt//vnnYuvWreL69eviwoUL4q233hJKpVLs3btXro+gk15//XVhZWUlDhw4IGJjY6U/OTk50jI8vte/umx3Ht8f3qxZs8TBgwdFVFSUOH/+vJg1a5ZQKBTi77//FkJo977OQFrGypUrRatWrYShoaEIDAwUx48fl77Xu3dvMW7cOI3lf/31V9G2bVthaGgoOnbsKLZv397IFTcNtdnu06ZNk5Z1cnISgwcPFmfOnJGhat1VOp1Q+T+l23ncuHGid+/eFdbx8/MThoaGwsvLS6xbt67R69Z1td3uixcvFq1btxbGxsbC1tZW9OnTR/zzzz/yFK/DKtvmADT2YR7f619dtjuP7w/vpZdeEu7u7sLQ0FA4ODiIxx57TAqjQmj3vq4QQojGOx9LRERERKSJ15ASERERkawYSImIiIhIVgykRERERCQrBlIiIiIikhUDKRERERHJioGUiIiIiGTFQEpEREREsmIgJSIiIiJZMZASERERkawYSImIiIhIVgykRERERCQrBlIiIiIiktX/AxfNWCh8EcahAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x550 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(eval_history_test, label='Test')\n",
    "plt.plot(eval_history_train, label='Train')\n",
    "# plt.set_xlabel(\"Iterations\")\n",
    "# plt.set_ylabel(\"Accuracy\")\n",
    "plt.legend()\n",
    "plt.title(\"Performance of FB on Train and Test layouts across tasks\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "e7258eb4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'actions': (100,), 'layout_type': (100, 10), 'next_observations': (100, 2), 'observations': (100, 2), 'terminals': (100,)}\n",
      "{'actions': (100,), 'layout_type': (100, 10), 'next_observations': (100, 2), 'observations': (100, 2), 'terminals': (100,)}\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x77f796eb6c50>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABkoAAAIaCAYAAABvdBHsAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzs3XecVNX9//HXvdN3dmd7pYNUQZogCCoqSuxdE02isZtobIlpJn41xZSv0Rj1Z4x+TUw0ahI1iTX2DlIE6UU6bAO2l2n3/P5YdnRlIRgG5rK8n4/HoDt35u5n7pmZved87uccyxhjEBEREREREREREREROQDZmQ5AREREREREREREREQkU5QoERERERERERERERGRA5YSJSIiIiIiIiIiIiIicsBSokRERERERERERERERA5YSpSIiIiIiIiIiIiIiMgBS4kSERERERERERERERE5YClRIiIiIiIiIiIiIiIiBywlSkRERERERERERERE5IClRImIiIiIiIiIiIiIiBywlCgREREREREREREREZEDVkYTJffeey/9+/cnGAxy2GGH8cEHH2QyHBEREREREVdRn0lEREREZO/LWKLkiSee4IYbbuCWW25h3rx5jB49mhkzZlBTU5OpkERERERERFxDfSYRERERkX3DMsaYTPziww47jAkTJnDPPfcA4DgOffr04ZprruG73/1uJkISERERERFxDfWZRERERET2DW8mfmksFmPu3Ll873vfS91n2zbTp0/n/fff3619VFZWUllZmfrZcRxs22bQoEFYlpX2mEVERERE3MYYQ1NTExUVFdi2lh/sSdRnEhERERHZc7vbZ8pIomTLli0kk0lKS0u73F9aWsqyZct2ax+/+93vuPXWW/dGeCIiIiIi+5UNGzbQu3fvTIchaaQ+k4iIiIhI+vynPlNGEiXpcMUVV3Dqqaemfm5qamLatGls2LCBSCSSwchERERERPaNxsZG+vTpQ05OTqZDERdSn0lEREREDnS722fKSKKkqKgIj8dDdXV1l/urq6spKyvbrX2Ul5dTXl6e+rmxsRGASCSik34REREROaBoGqWeR30mEREREZH0+U99poxMZOz3+xk/fjyvvvpq6j7HcXj11VeZPHlyJkISERERERFxDfWZRERERET2nYxNvXXDDTdw4YUXcuihhzJx4kTuuusuWlpa+NrXvpapkERERERERFxDfSYRERERkX0jY4mS8847j9raWn70ox9RVVXFmDFjePHFF3dYrFBERERERORApD6TiIiIiMi+YRljTKaDSIfGxkZyc3NpaGjQfLsiIiIickDQObB8Hnq/iIiIiMiBZnfPgTOyRomIiIiIiIiIiIiIiIgbKFEiIiIiIiIiIiIiIiIHLCVKRERERERERERERETkgKVEiYiIiIiIiIiIiIiIHLCUKBERERERERERERERkQOWEiUiIvuxuXPnMnHiRBYuXPi5n+s4Dl//+te577779kJkPVd9fT033HADTz/9NPF4PNPhiIiIiIgcEJLJJP/85z8577zzWLdu3ed+/qZNm/jmN7/JSy+9tBei67k2b97M8ccfz6JFizDGZDocEZG9RokSEZE0McYQi8V4++23+dKXvsTgwYOpqKhg/PjxXH/99SxZsiTtJ5atra0sX76ctra2z/3cDz74gKeffpoZM2ak4q+rq+MXv/gFEyZMoFevXkyZMoX777+f5ubmncZujKGtrY0HHniA8ePH07t3b84888wdXq8xhtdee41jjjmGiooKjj76aP7xj3+QTCY/V9zGGDZu3MhNN93EiBEjGDRoECeffDJvvvnmLo+vMYb6+np+/OMfM3z4cIYOHcrNN99MXV1d6nnGGFpbW/nDH/7AhAkT6Nu3L2effTarV69OPSYSidCvXz8ee+wx6uvr1VkQERERkQOSMYbGxkb+/Oc/M2PGDPr27UtFRQVTpkzhJz/5CWvXrk3rubIxhoaGBtasWUMsFvtcz00kErz55pssX76c0aNHp/ZXXV3Nddddx8iRI+nXrx+nnHIKL7zwAtFodJf9n8bGRn7wgx8wePBgBg4cyLXXXsuGDRu6PCeZTPLEE08wceJE+vXrx5e+9CU++ugjHMf5XLE7jsOsWbO44IILGDhwIEOGDOGCCy5gwYIF/7H/s3z5ci677DIGDBjAIYccwm9/+9suv98Yw7Zt21KvpX///lx99dVUVlam9l1WVka/fv24/fbbP1fcIiL7GyVKRETSoDNJcv/993P66adTU1PDlVdeyc9//nNOP/103n33XU466SSqqqoyHSrQcbJ9xx13cMwxxzBw4EAA2tvb+f73v8/999/PCSecwM9+9jNGjx7N//zP/3DnnXfu9IQ+mUzy8MMP84tf/IKjjz6aW265hcrKSs477zzWrFmTetxbb73FV77yFSKRCD/5yU/o168fN998M88///xudxY6T+Q7rwT76le/yre+9S1aWlo44YQTmDlz5k6fF4vF+OUvf8lDDz3E2WefzQUXXMBf/vIXbrnlllRHKJFI8Pe//52f/OQnTJ48me9+97usW7eOE088kerqagBs2+a4445j5cqVzJ8/X4kSERERETngdCYZvve97/Gtb32LoqIifvCDH/Dzn/+cI444gscff5zrr7+e+vr6TIeauhjqz3/+M0cccQSlpaUANDU1ccopp/Dcc89x0UUX8f3vfx+Px8NVV13FW2+9tdP9xeNxrr32Wv74xz9y6aWXcs011/DGG2/wwx/+kC1btqQe9/TTT3PppZcycuRIvv3tb1NdXc0NN9zAmjVrdrsPYYxh1qxZXHPNNdTX1/Ptb3+ba665hsWLF3PuueeydOnSnT5vw4YN3HLLLSxatIhvfvObHHfccfzwhz/kV7/6Var/1drays0338yTTz7JJZdcwg033MBrr73G1VdfnWo727a56KKLePbZZ1mxYsVuxS0isl8yPURDQ4MBTENDQ6ZDEZEDkOM45vXXXzf5+fnm+uuvN01NTV22x2Ix87e//c1s2bIldV9ra6tZvXq1mT9/vlmwYIFZu3atiUajXZ6zadMms3jxYvPhhx+aRYsWmcrKSpNIJFKPeeutt0wkEjGzZs1KxRGNRk0sFjOO4+w03rVr15qCggLz1FNPpe776KOPzJQpU8ydd95p2trajDHGbN261Vx44YXm3HPPNTU1Nd3ua+XKleaUU04xN998s2loaDCO45j169ebIUOGmB/96EfGcRwTi8XMF7/4RXPkkUea5uZm4ziO2bRpk/nSl75krrrqKrN169bdPs4rV640vXr1Mg888EDq/s2bN5tIJGJ+8IMf7PR5a9asMb169TK/+tWvUvffd999prS01CxZssQ4jmPWrVtnzjjjDHPDDTeY+vr61LEqLS01t956a+p5iUTCnH322ebSSy81sVhst2IXEdkbdA4sn4feLyKSLu3t7eb+++83AwYMMA8//LBpb29PbXMcx2zZssW8/PLLprGxMXV/U1OTWb58uZk/f75ZuHChqaysNPF4vMs+161bZxYtWmTmz59vli5daurq6kwymTTGGBOPx80jjzxiJkyYYFasWGGMMSaZTJr29nYTj8d32v9xHMfMnTvX9OvXz7z99tup+1988UVTWFhonn322dRz582bZ6ZMmWLuuuuuVJ/os1599VUzePBg8/jjj5tkMmkSiYR54YUXzNixY80zzzxjHMcx7e3tZuTIkeass85K9d/ee+89M3bsWPPwww/vdh8imUya//u//zPjxo0zH3zwQer1fPTRR6aoqMg8+OCD3T4vkUiYf/7zn2b06NHmxRdfTN1/0003mV69eplNmzalXsvYsWPNE088YWKxmEkmk+aNN94ww4YNM48//njqefF43AwbNmyn/S0RETfb3XNgVZSIiKTJXXfdRUlJCTfccAPZ2dldtvl8Ps466ywKCwsBaG5u5qmnnuLyyy/n0ksv5ZJLLuHKK6/k+eefJxqNArBu3TpuvfVWvvnNb3LllVdy8cUX8/3vf5+FCxfutAKjubmZF154gTfeeGOX5eivvfYajuMwderU1H1erxePx0N1dTVbt26lpaWFqqoq2tvbKSsrIxQKdbuvDRs2UF1dzWGHHUZOTg6WZVFcXMy0adOYPXs2ra2trF+/nhUrVnDmmWcSCARSjznyyCNZtmwZmzZt2u3jbFkWPp+PrVu3snXrVhobG1m3bh1+v5/Bgwfv9Hmvv/46tm1z4oknpu476aSTCAaDvPjiiwBs27aNtWvXMn78eHJzcwHo27cvRx55JC+//HJqmjCPx8Ohhx7K22+/nWovEREREZEDRUNDA48++iiHH344p512GoFAILXNsiwKCwuZPn06OTk5QMd59v33389XvvKVVP/nu9/9Lh9++CGJRAKApUuXcuONN3L11Vdz+eWXc/HFF/PrX/+a2tranVZgbN26lT/96U/Mnj17l/E+//zzRCIRRo0albqvs1+yceNG6urqaGpqorq6Gp/PR0lJCR6Pp9t9zZ49m1AoxLRp07AsC4/Hw6BBgygtLWX58uXE43EWL17M2rVrueCCC1L7GTNmDEOGDOG1116jvb19t4+1x+PBcRwqKytpbGykoaGBtWvXkpOTQ+/evbt9TltbG7NmzaJfv35dXvNFF11EY2Mjb7/9NsYYli5dSigU4pBDDsHn82HbNkOGDKFPnz58+OGHqX6n1+vlqKOO4qWXXkq1l4hIT+PNdAAiIj1BLBbjvffe48gjj+xyshqLxbqcSPr9frxeLzNnzuTXv/41U6ZM4fTT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p7GbqnI6j1nnMXTT8ftsbG5r3+7ic1Pbwo7vP7cfPzfF1/l5cONnA3D1sQP3fz6MMa6KR0RE9jfu+Bvy2b6QW+ICsKxP4rMsm44/u+6Iz7LAtj+Jbfu9GY3ps2y74xy+g7ti63zPdXBXbG5t167vObd9Vq1Uf8dtsUHX77nt92Q0nk9Y3bSpW2L7tB2TF7bHxuv14PPteaLEcQwer7v6ouIOSpSIiIiIiIiIiIiIiDsZB2MSaakAMcZgjDuqBcVdlCgRETlAqcRURERERERERNyvY/xC4xiyNylRIiJygNIUPiIiIiIiIiLidob0VYEYY8A4admX9CxKlIiIiIiIiIiIiIiIS3Us8m7SlOAw3ayDIqJEiYiIiIiIiIiIiIi4kjEGxyTTkt5wTPoSLtKzKFEiIiIiIiIiIiIiIi5lgCTpWaLEYFCiRHakRImIiIiIiIiIiIiIuFLHGiUd02/t8b728hol7e3tvPfee/zzn/9k7dq1ZGdnc/zxx3P++efj9XYMxW/dupXHHnuM1157jVAoxLnnnsvpp5+e2seyZcv4wx/+wOLFi+nTpw9XXHEFo0eP3msxSwc70wGIiIiIiIiIiIiIiHTLOBiTxJhEem57saKkqamJxYsXU1FRwZVXXslxxx3HL3/5S373u98BEI/Heeihh3jppZc499xzmTJlCt/97nd56aWXAKiqquInP/kJdXV1XH755fh8Pq688ko2bty412KWDqooERE5QJn01KyKiIiIiIiIiOxlZr8YxygsLOSKK67Asixs28YYw8aNG3nyySf5xje+wccff8x7773HxRdfzKmnnorjOKxYsYLf//73HH/88cycOZPm5ma+853vMGLECI488khOOeUUnn76aa655ppMv7weTRUlIiIHKMuyMh2CiIiIiIiIiMguGeNgnASY5B7fjJMAJ4kxhng8nrolk8m0JGJs28bv9+Pz+fB4PFiWRV1dHcXFxUBHxYjf76d37954PB58Ph/HHnssy5cvp7m5mfXr11NaWkpRUREej4dQKMRhhx3GRx99tMexya6pokREREREREREREREXGr7+iRpqSjp2NeGDRt48skn8fl8AIwYMYJx48bt8pnJZJK1a9eydevWbrcHg0GGDRuG3+8HOqbZeuutt3juuee46667AGhra8O2bQKBAJZlYYyhsLCQRCJBQ0MDra2t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NsfcdgzFBxe77ntPRERERERE/gvpXsjd2bfhy/5BFSUiPVT/o/vTb1o/PL7MryHQnSnfmYLttV05yB/MC3LMz47pOHYuGeT/rFEXjMKyLGyf7cr2PeanHcfPTe3rDXiZ/vPpmQ5jvxSIBJh2yzRCBSH8YT+HXnmoa6a0siyLSK8IM+6cwcLHFtLn8D70mdLHdQlYERERERER+S91VpOkoxjEWKRlDi/pcZQoEemh3HCl9664eWFvy7bwBd0bH+DqNT8sy3J1+8p/JxAJMPW7U8Fin06Vtzss26LgoAKOvPlILMtybYJTRERERERE/kuaekv2MveOtImIiIiruLlKw7IsLI8SJCIiIiIiIj2OsbYvwp6efaHF3KUbSpSIiIiIiIiIiIiIiHsZSMeUWQaTlhm8pOdRokRERERERERERERE3MnQUQWSjkIQY6VnCi/pcZQoERERERERERERERF3S1eCQyUl0g0lSkRERERERERERETElcz2KhCTlsXcUUWJdEuJEhERERERERERERFxJwPGscBKwxolxqiiRLqlRImIiIiIiIiIiIiIuNT2dUWcdE29pYoS2ZESJSIiIiIiIiIiIiLiTqkF2DX1luw9dqYDEBERERERERERERHplqGjmsQhDTdrn029FY/Hufrqqzn88MNZvXp16v7a2lp+/vOfM23aNE488UQef/zxLs9btGgRX//615k6dSoXXHABc+fO3TcBH+CUKBERERERERHp0XTlrIhIphiX3LraP/8umO0Luu/JrcPef/3GGB5++GHWr1/Phx9+SFtbGwCxWIzf/e53vPXWW1x//fWcddZZfO973+PZZ58FYPPmzdx6660YY7jtttsoKyvjkksuYf369Xs95gOdpt4SERERERER6aFKS8vw+XyZDiMlLy+P3NxcPOEQ3sI8LL97YgMLT34EOyuIJxLGW5SLicUzHRQAlteDNzcHOxzEk5eDrzgP4ziZDivFzgrhyc7CzgrgLcwl6fVkOqQUT242djgItoWnKA8rFMh0SCmWbePJz8HK6mhXb3EeJpHMdFgAWH4/nkgYOytISUkJvVuaOhbBdoFIJEJeXh454TBWvAB8LhvezMuHUAji2ZBfCLH2TEfUwfZATi4Es8gtLKRXrwoSiUSmo+rCcRyqqyu72fLpJMee6UiYdPx/Mpkkmez4zFmWlbrt+e8w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KOSqgXToGCzsrDzozGa7STKZTE1rFQqFXDfYatt2KhERDAZd1b6O46SSTMFg0LWJkng8jtfrdWWixBhDa2sra9euZe3ata6aeisnJyd1BUswGHTVdx90lCnH43F8Pp/r2hY++e5raGhg9erVVFdXu6Yz2Ml9HRkREREREZF9wFiQju73HiRcLMsiHA4TDod3+pjs7GwuueSS1FjBpk2beOihh/jKV77CIYccQmtrK3369OEvf/kLRUVF1NXV8cgjj3DZZZfh8/kYP348TzzxBH/7298488wzefPNN1m8eDHf/va3/6uYZfe5b4RMJM06p0Byk86rqi3LSi0a7CafXtD40ze3+PSxc9vx66w46Dxebo7PjW3bXXxuOn6d771Pr/XipkTJp+dzddux++xn49MLz7tN5xRhbktKdL7vREREREREDjidC7qnZ0d7jcfjISsrK/VzVlYWlmURCoXw+/34fD6+/vWvc8cdd3DeeecRCAQ488wzueiiiwAYMmQIV199NXfffTe///3vKSkp4X/+538YO3bsXo1blCgREREREREREREREZcyxtp+S9++9pVevXpRWVlJKBQCOi5qHDJkCPfccw+JRALLsros3u71ejnuuOOYNm0ayWQytfC722aM6ImUKBERERERERERERERd9uHCY50sW17h6m6Ohdu39n6KB6PR4mRDFCiRERERERERERERETcyVjg2JCOqcON2S8TLrL3KVEiIiIiIiIiIiIiIq6WliWIjbW3lymR/ZQSJSIiIiIiIiIiIiLiTgaMY6WlosQYs0/XKJH9hxIlIiIiIiIiIiIiIuJSFob0LObeMe2WEiWyIyVKRERERERERERERMSVjLHASU+Cwxi270ukKyVKRERERERERERERMS9jJWmKbO0QIl0T4kSEREREREREREREXEnx9q+Rsme78qY7fsS+QwlSkRE9iPJeJJkNIk36MX22pkOR8Q1nKRDoi2Bx+/B4/dkOhwRERERERFJM1WUyN6kUTYRkf3ItlXbWPj4Qpo2N2U6FBFXaa9rZ8GfF1CzuCbToYiIiIiIiEgaGTqTJHt+M2mbwkt6GiVKRET2Iw3rG1j57EpaaloyHYqIq7Q3tLPinyvYtnJbpkMRERERERGRdDLW9htpuKVnUXjpeTT1loiIiIiIiIiIiIi4V2eyZI/3Y9KzH+lxlCgR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6d+/P4sXL2bjxo2uSoSFw2GSySRTpkwhHA677rsvHo+zbds25s2bx0cffeS6775AIMCoUaMoLi5mzpw51Na650rITm47ZiIiIiIiIvuEY6UlxWFUUSI74a4RFJE0M8ZQW1vruulnbNumpaWFxsZGamtrXTUQDB3rHDQ2NhIKhdi6dSs1NTWZDqmLWCxGc3Mz7e3tbNmyhaampkyHlGLbNuFwmJaWFhoaGqitrXXVFRqdbQvg8/lcN5AOHVf1f/rz4aaKJp/PR3FxMS0tLWzbto2amhpXJUpycnJobm7Gsix8Pp/rvvs613hpbGxky5Ytrmpb6EgkNjY2kpWV5crvPsBV3yciIiIiIiL7hNlea5KWBIcqSqR77hshExHpIdxSlvyfuG3qLTfFsz/69PvOTcfy03F1Jkzk89ExExERERGRA5HBwhi7Y47EPd2XMWDcs3aXuIcSJSIiIiIiIiIiIiLiUmlezD0Nu5GeR4kSEREREREREREREXEns33arTRMvdVRUZKGmKTHUaJERERERERERERERFzJbP8nbRUlWsxduqFEiYiIiIiIiIiIiIi4k7EwWEAaKkr2QTnJM888w7333ktraysAXq+Xa6+9ljPPPBOALVu28Mc//pGXX36ZUCjE+eefzznnnJN6/pIlS3jggQdYuHAhffv25Zvf/CZjx47d63Ef6JQoERERERERERERERH3SlNFidkHFSXV1dVEIhFuvPFGSkpKsCyL3r17AxCPx3nggQd49913ueyyy9iyZQvf/e53CYfDnHjiiVRWVnLbbbeRl5fHTTfdxIsvvshll13G008/TZ8+ffZq3Ac6JUpERERERERERERExJWMAcfprCrZ8311Jlwcx8FxHAAsy+ry3z0ViUQYPHgwFRUVeL1evN6OYfhVq1Yxa9YsLr/8ck4++WSMMSxfvpzf//73nHDCCcycOZP29nauueYahg8fzpQpUzjppJN46qmnuPbaa9MSm3RPiRIRERERERERERERcbX0VIJ0LOZeWVnJCy+8gM/nA2DQoEEMHz48DfsHv9/PnDlzOO2008jLy2PatGlcd911FBUVUVVVRSAQoKKiAo/HgzGGo48+mpdffpmmpiY2bNhAaWkpBQUF2LaN3+9n4sSJLFy4MC2xyc4pUSIiIiIiIiIiIiIi7tQ5XVYaqj06qkksli5dyk9/+lNs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PfRQQqEQoVCIBx54gKuuuopQKERzczPZbJb29vY+37d27VpaWloAaGlpYe3atTsdLx57sz796U+zYMGC0u2BBx7YnR9FRERERESk7HTOJCIiIlJ+5UpuKEkiA9mtipJjjz2WZ599ts/XzjvvPCZPnsxXv/pVxowZQzgc5t577+XMM88E4MUXX2T58uXMmTMHgDlz5vC9732PdevW0dTUBMDdd99NdXU1U6dOfdOxtLa20traWvq7jX3ERURERETk7UXnTCIiIiLlVdzMvRxpDoMpW2XKQDo6Orjpppv429/+RkdHB5MmTeLzn/88Bx98MFD4TPbrX/+av/71rziOw/vf/34+9alPlbpCvPbaa1x99dU8+uijtLS0cNFFF3HssccOctSyW4mSqqoqDjzwwD5fSyaTNDQ0lL5+/vnnc8kll1BfX091dTWf+9znmDNnDrNnzwbghBNOYOrUqZx99tlceeWVtLW18Y1vfIOLLrqIaDRaph9LRERERERk6OmcSURERGRwlKUaZJBLSowx3HLLLdxwww1ccMEFTJw4kV/+8pd8/OMf57777qOmpqaUJPnsZz9LEAT8v//3/wiFQlxwwQV0dnZy6aWXks1m+e53v8vjjz/ORRddxB/+8AcOOeSQwQ3+ba7su7z+5Cc/wXVdzjzzTDKZDCeeeCLXXntt6bjnedx6661ceOGFzJkzh2Qyybnnnsull15a7lBERERERESso3MmERERkTevuEdJOXZYLT6WMQbf90v7QBb309zTfVxzuRzLli3j0EMP5aSTTqKuro6RI0cyY8YMli1bRkNDAw8++CDnnXce733ve/E8j9WrV3P99ddz7rnn8uSTT7JmzRouv/xyDj74YI444ggWLVrEjTfeqETJINvjRMm8efP6/D0Wi3HNNddwzTXXDPg948aN4/bbb9/Tf1pERERERMR6OmcSERER2XOmjNUgq1ev5pZbbiEcDgMwadIkpk2btsePGw6HmTx5Mn/605946KGHGD9+PDfeeCOHHXYYkyZNYsmSJQRBwNixYwmHwxhjOProo7n22mtZvnw5K1eupKmpidraWhzHIRwOc/jhhzNv3jyMMXucyJGBlb2iRERERERERERERGRv8vrrG2hqqiYej1Q6FNmBobBHiVuGHIExhdsrr7zC1Vdfjeu6AHzoQx/iwAMP3GUiIpfL8dxz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NvUTERERERER+xRTJOU47TNKuMgAlCgRGabGHjmWse8cixt2rUuSAMz58hyckGPlIn+sJsa7vv2uwthZush/4IcOBKewYGzj/B71H0fhhT2rkmBu2OWADxxAw/4NlQ7Fevl8nvaOdqadOI0PfuyDTD1wKiebkznooIO49dZbWbt2bZ/2W5XghT0Ov+hwTGCUJBERERERERnmyrUJu1IkMhAlSkSGKS88tK22dlcoZu/bj+M6VscHDHkrtd3hOI6VG7d7YY/DPnVYpcPYK7iuy9SpUznwwANpaWkBwMPjzDPP5OCDDyaRSFQ4wgLb3+dERERERERkzxnKmyhRskT6Y/dKoIiIiAw5z/MYOXLn/Y8cx2G//farQEQiIiIiIiLydlVIbpRrE3Y13pL+2dMTRURERERERERERERkB+VKbqiiRAaiihIRERERERERERERsZLBEJjypDiMMRijVInsTIkSEREREREREREREbGammbJYFLrLRERERERERERERGxUnGPkvI8llHCRfqlihIRERERERERERERsVa5Ehzao0QGokSJiIiIiIiIyDCVSCRxXa/SYZQkk0mi0ShOOIQbj2Gy+UqHtI3j4MaiEPJwImGceBRcp9JRAeCEPZxoBCcUwo1FcBMxjB9UOqwSJx7FjYS3xhcliMcqHVKJE4vihEKYcKgwp4E944brFuY1HMKJRHDiMcj7lY6qIBLBiUQg5JFIJkilUtbs65BMpohGY0QiUUzg4Vv0WgAI/BBB4OAatxBfpQMqcQiMSxA4RCMxqqpSZLO5Sge1A0N395Z+vmrKluBQRYkMRIkSERERERERkWHqne+cSyqVqnQYJalUkv32249IQzNm+v4EPelKh7SNA15tNeFRTbiJGE44jMnbkchxXJdQayPhlkYwAV5DLViyaA3gRCOEx7biRsNED5pC0NNb6ZBK3ESc0MgmTDaHyWQx6WylQ9rGdfFG1OG1toDrYqqqwbdjWd0JhfDGtOLV1jBzzmxa9hlvTaIkkUgwefIk4vE4PT01eJ4dY1bk+2FyuTh+LiDozeE4dryPgEPej5L3fSbuux/HHXcsviXPt6J8Ps9dd92509eLrbeCsqVKRHamRImIiIiIiIjIMNXc3ExNTQ2OY0dlRDweo6amGjcZx6uvxkvGKx1SH05VAi8Rh7xPqKHWmkVrXAevOoWbiOHVpCAwViVKiIRwk3GcSAi3vgY3YdG8xiI4iTiEw7j1tWBbFVNNNU4ijlNVjZvzC3NrA8/FSVXhJBKMaGoi79qzzXEsFqWmpoZYLEo+H8EYeypKjIEgCBEEIUzggJ/Hdex4HzHGwTcBAYbqqipGjhxJYFOFFZDNZvG8/qsgDVCO32Rmu/+KbE+JEhEREREREZFh6q677iYcDlc6jJLa2lpMAFNG5el57Dn8Ld2VDqnEAULNDRAE5Ns2kn7+VQJL2tI4IY/oPqMxE0aTefE1csvbMBYtcLqJOOR83ESUnsefJejsqnRIJW51Csd1CXrTpBcstqraxXFdQmNaYPIEsq+tILd0BcaS5JwTCROdvC+hlkYeuG8eS5a+ak1FSU1NNblcnqqqFCefGuB5FlUJAfl8nHQPuMFawjyLix3xGVzypoVsMJbFzz3J3//+CLmcHe9xRUEQ0Nvb32vUlHGPElWUSP+UKBEREREREREZptra1gD2XAne09NDe0c7QW0v+Q3tBB32LKgDEA5hutP4nV3k17djMnYscBLyCNXVEHT34m/uJL9uk1V7bZhUopD0MgH+xnaCzZ2VDqnE5PIE3b2Ynl78DZsJunsqHdI2roubShB09xK0b8HfsMmePUqiEYLOLkx1inVtbaxYsdKaRElXVy2bN2/GGB/PS+OFLHmdljg4bh6XNCGnHYdMpQPaysWQxHXSdHRsZMWKldYlSgqVHgO/tynFIYNJiRIRERERERGRYa1cDUvKTQteb4mGTaQPSzoLAts64m0fky3xlWKDve59pJA+CXDKkfh3lHCR/ilRIsNeOBwesL9hJTiOQzgcxnVdjDHW9YMEMMb0e7PF9jEFQWBNv+WiHcfNpjneMS7b5hboE5et41d8HYfDYaviC4fDhEKFX+22jR3Q5/lmW2ywLSbXdQmHw0QiEeteH7a934mIiIiIiAw2g8E4BpwytN4yhsCx73xUKk+JEhnWHMdhypQpVvXkdRyHuro6amtryWazOI6Da9GmaFBYLMzlcuTzedLpNPm8RZvdAb7vk8vlcF2XdDpt3fhls1lyuVxpQdOmhc0gCMhms/i+b+XcAuTzeXK5HEEQ4LquVfNrjCGbzZJMJpkwYQLJZNKqBf9EIkFLSwv5fJ7e3l6rksSwbW6LySab5ha2vT5qa2vZb7/9aGxstC5R0tvby4YNGyodhoiIiIiIyJDZtj9JOfYoEemfEiUyrDmOwz777EMsFqt0KH2kUimqqqpKi+k2LaTDtkRJcdEwn89bFWMQBPi+TxAEZDIZqxZbjTH4vo/v+2Sz2dKCsC2CICCfz1s7t8UqCN/3McZYOb+5XI5EIsHo0aNJpVJWLaRHIhEaGhpKzz/bxm77ubXxva84v1VVVYwdO5b6+vpKh9SHMYauri4efvjhSociIiIiIiIypMp15l2uTeFl+FGiRIY1YwwLFy60qqIEoLGxkaamJqLRKPF43LrFwiAIStUG8Xi81MrHFsUkieM4JBIJqxaDoVBRAoVF62g0atX8BkFAb28vvu9bObdQqDowxuB5HvF43Kr5LSZvOjs7ef7551mzZo11FSWe53HEEUcQj8etrCgxxhAKhax87ysmcDZt2sRzzz3Hxo0bKx3STtLpdKVDEBERERERGVKF1EZ5zr2VKJGB2LdCJlJGxhhWrFiB67q7vSC3O5UAu1s1kMlk6O7uJhQKEYlErFoIhm1VB8YYIpGIdYmmfD5PJpPBcRwikYh1i8HFq9LD4bCViZJcLgdg5dxCYX+ITCZTGj+bXh/Fqoh0Ok1bWxuvv/56KVHyVqqHyv0+U1VVxT777IPrukQiEesSYcW5tfm9L5fL0dXVxapVq1i7du2g/ntv5TlTfP2KiIiIiIi83SjBIYPJrhUUkUFQrDx4K+1xdud7due+xc2qi61nbFpI3972cdkU4/Z7f9g2fv21FLIpPth53GyKz/bx2/51HgRB6dbf8bfymHt63+3jsfG1ATu/fm1SjKe46fxQVAvt7vzbVMEkIiIiIiIyFAwQYHDY83NI1ZPIQJQoERERERERERERERFrme3+u0ccbegu/VOiRERERERERERERESsZByDcQJw9rx9szHl2+9EhhclSkRERERERERERETEUsWGWXteC6LWWzIQJUpERERERERERERExEqFFEk5EyVKlcjOlCgRERERERERERERESsVmmUZnDK1zFKiRPqz543dREREREREREREREQGTXmSG+WqTJHhRxUlIiIiIiIiIiIiImKp8m3ArtZbMhAlSkRERERERERERETESttqQMqU4HCUKJGdKVEiIiIib0qmM4PjOUSSkUqHIiIiIiIiIm8TBoNxAnD2fBeJ4n4nIjtSokRERETe0JbVW1jw8wVEUhGmf3w6iYZEpUMSERERERGRtwVTxr1FtEeJ9E+JEhEREdml9uXtPHzFwzz9i6dxIy7p9jSzPj+L5IhkpUMTERERERGRt4FyJUq0mbsMRIkSERERGVDnqk4evuJh1j27jtoJtcSqY7x6x6s4jsPsL80mXhevdIgiIiIiIiIyrAVl28wdbeYuA1CiRERERAbkRTyqWquY9pFpPHjZg9SMqWHKGVNY++xavIhX6fBERERERERkmCvsK+LjlCnBEZQt6dK/TZs28cc//pE77riDdDrNMcccw+c//3ni8cKFhlu2bOF3v/sdf//733Ech9NPP51PfOITeF7hHHvZsmX87//+L4899hjNzc18+tOf5uijjx7UmEWJEpFha8WjK1j33Domv28yicYEjuNUOqQ+nvifJ4jVxjjwQwdaF1u6M83Tv3ya0bNHM3rWaOviA3j+b8+Tbk8z7cPTCEXteis3xvDojx+lYVIDk06dZN34bX5tMy/f/jITjptAw6QG6+KzTaIhwewvzSYUC+F6Ll7EY8JxExj7zrGEE+GKxWWMYcmfl9C1pouZF8/UPIqIiIiIiAxTpvRnuSpBBq+iJJ1Oc/3113Pfffdx3nnnkUql+OEPf8jGjRu54oorMMbwm9/8hr/85S988pOfJAgCvvOd7+C6Lp/4xCfo7Ozksssuo6enh6997Ws8+eSTXHzxxdxwww0cfPDBgxa3KFEislczZuA39lx3jieueYL219qZ+7W5RKoiQ76QuKv4ejf2cu+/3wvAAR84ANdzhyosYNexGd+w+vHVvPT3lzjhRyfQcnALjjv0i7C7ijHTkeH+b95PpiPD4Z89HC88tFf27yo2gM4VnTz+34/jhlz2PWFfq+bXz/q8eMuLrJy/kmMuO4aasTVaZN8Fx3WIJCN9vuaGXCKhyADfMfgCP+Dl217m7q/czdQzp4LZ9Qdmza+IiIiIiMjeq1BREuCw52sL2zfe8n0f3/eBwnlj8bYn1q5dy8KFC/nABz7A6aefDkB9fT2nn346n/vc5wCYN28e55xzDmeccQae59HW1savfvUrzj77bBYsWMDKlSv5/ve/z/Tp03nnO9/JokWLuPHGG5UoGWRKlIjspYwxdK/tpndTb7/Hq0ZWMfXMqcz/r/l4UY93fv2dQ9omxwSGjS9vxPj9L15OOWMKbQvb+Ofn/okbcpl65tQhS0YYY8in87S/1j7gfQ762EHc/637mffteZzwwxOo369+SBdbjTF0LO8g153r9/iow0cx+b2Tufdr9+KGXGZ8ZsaQJiNMYNj44sYBjx987sFseH4Dd//b3YSuDjH+qPFDOr+ZjgxbVm8Z8D4HfvhAHvr+Qzx0+UMcc9kxxOvjWkzfS5jAsGzeMu75+j2MmDKCAz98IBte2DDg/RsnN4KmVkREREREZK9XrooSg2HNmjXcfvvtRCKFiwD33Xdfpk6dWpbHd12XbDaL7/u4rksmk6G3t5dFixbR0tJCEASMHz+eSCSCMYZjjjmGn/3sZyxfvpwVK1bQ1NREfX09rusSiUSYNWsW8+bNwxijtYtBpESJyF7K+Ianf/U0z/7u2QHvk+3KkunM8MS1TzDjMzNINaeGLL58Js8tH7+FTGdmwPv0bOwh3Z7mmd89w34n70ckNXRXqG9eupmbP3DzgMf9nE/32m42vrSRtkVt1E2owwkN3S+jIBfwwLcfYNXjqwa8T7ojTT6T57GrHuOgjx5ErDY2ZPHlunPcdNZNAx43xtC9rptsV5ZX/vkKY+aMIRQbol85BpY9sIz7/v2+Ae+ST+fZsmYLi/+0mMM+dRjxem1IvrfI9eZ49a5X2fzKZnrW9fDXs/+6yw+Kn37609pLRUREREREZK9mMPhlqyiBgBdeeIErr7yydD750Y9+lClTpuzy/DKfz/PCCy+wZs2afo8nEgmmTJnCwQcfzB133EE8HieVSnHTTTfheR4dHR3U1taWEiBF9fX15PN5tmzZQk9PD+FwmHB4W6vrmpoauru7yeVyfb5PykuJEpG9lOM5TPvwNMa/a3y/xzNbMjz3h+dY8fAKZnxmBvGGoV0IDkVDnHTVSQT5/jfI6lrTxSM/fISq1ioOveDQId/roHZcLaf94rR+jxnfsOqJVSy8fiEjZ4xk5IyRON7QZuzdkMsRXzmCdEe63+O9G3t58mdPEoqFmPu1uUSro0MaXzgRHnD8oJCImv+T+cTqYkx+32S86BAuVDsw5ogxA8aXT+dZevdSXrjlBSa/ZzK142uHLjbZY+F4mP1P25/VT6wm25Vl9hdnU7tP7YD3d0ND2/ZNREREREREysuUGmbteUVJ8ZFmz57NVVddVUo8VFdXv2G1Rjab5cEHH+Rf//pXv8dbWlr4xje+wYc+9CHi8TgPPvggjuNw4okn8q9//YtkMkkoFMIYU2r5BYV9TYrJk3A4TBAEfY5nMhkikQiuq/PbwaREicheynEcasfXDrjIu/TepXSt6WLW52ZxyPmHDPkeEY7rMOrwUQMef/CyB/HzPsddcRwTjpswpHuAOI5DJBVhzJwx/R7v3dzLwl8tpPXQVuZ+dS6142uHvLTRcR1GTB0x4PFFv15E76Zejv7u0RzwgQOGfA8VN+QOOH7GGJbctIRodZSjLz2a0bNHD+n4OY5DckSS5Ihkv8c3vLiBTa9uYv/37M+sL84iVhtT6epexHEdxhwxhqMvPZr7vnkfa59Zy4EfOrAi+wiJiIiIiIjI0ChvosQQj8cZM2YM0eibv/A0Ho9z7rnn8qEPfajf457nUVVVheu6fOYznyklQB5++GEApk2bVkqAbNiwodSaa+HChVRVVTFy5Eiamppob2+nu7sbgCAoVL+MGzeOUEhL+YNJoysyTNXvW8+R3ziS5oOaCcVD1i0Ejz96PBOOn8Cow0dZt8AZjoc56OyDqB5TXWi5ZdnYAbQc2sLxPzyeUTPsGz+ASadN4uBzDqb5oGbrxi/RmGDmRTOp36+eZFPSuvjkjRWTJSf85wnkenLag0RERERERGQY21ZR0n/Xkt331h7HcRySySTJZP8XZha98sorbN68mebmZpYsWcJ3vvMdzj77bMaNG0cul2Py5MncdNNNjB49GoCrr76ak046iZqaGqZPn47ruvzhD3/gnHPO4ZlnnmHevHn84Ac/eEsxy5unRInIMFUztoaasTXgYOVCcLHKwMZFfi/qMfadY3Fcx8qxA2g6oKnwfyyd33FHjrN2/OL1ccbOHWvt2Nns1P89FTdsR6mv4zq0HtJats38RERERERExFbFapI9P4c3Q3AW+eqrr/LDH/6QVatWUV9fz5lnnsknP/lJQqEQnudx/vnn89Of/pTzzjsPx3E4+uijueSSS3Bdl1GjRvHFL36Rn/zkJ5x66qnU1NTw2c9+luOOO26QoxYlSkSGKRsTENsb6lZgu8NxnCHfk2R32Ty/to+f4ziqQHiLqkdXVzqEPhzXwdFkioiIiIiIDGsGQ4CPU7bWW+WqTOnfsccey9y5cwmCAMdxiEajpc3ZHcdh/PjxXHHFFeRyOQAikUhprxTP8zjiiCM47LDD8H1/p++XwaNEiYiIiIiIiIiIiIhYrXy1IINbUxIKhXa5n4jjOMRiMWKxWL/HPc8jkUgMVngyACVKRERERERERERERMRKxSoQhz3vTmKGpPmW7I2UKBERERERERERERERS21NbpjytMxSokT6o0SJiIiIiIiIiIiIiFjJYDAmAKcMFSXGYIwSJbIzJUpERERERERERERExFLFdlnl2oRdiRLZmRIlIiIiIiIiIsNUTU0tnmfPqX9dXR2JRAInGsGtSlq3VuUlEzjRMG48iludwGTClQ4JACfk4SZiuNEIbjKOW52CwK90WCVuMoEbixbmNZUA36LYUoXnG4GPU5XEdZ1Kh7SN6+Ik4zjRME4ihluVwuTzlY4KACcSwYnHIBKmuqaG+vp6a67Cr62tIZlMEo8nCIIwft6OuIp8P4wJPEwQJjAJjDXLry6BiREQJpFM0dBQTzabq3RQfRgT0NGxeaCjwJ6/fgsJF7ueM2IHW16pIiIiIiIiIlJmJ510ItXV1ZUOoySZTHDggQfwaijCCxNS9PbseRuV8nGoa0gyoSHKZhKsSFeTy9mxiOh5Hi2jkrQ0RFk5Jsn6SDVBUK4rq/dcLB5jYlOMaDTGC/tU093lVTqkkmQqyeT6KNkMvDyhhnRvtNIhlbiuy4jmKkbXx1nbW8UaU0dgSZIpFA4ztiVJbX2cI455F5MOnmZNoiSRiDN16lSi0ShX/9er9PT0VDqkPqqrq9l33xBbtvTw+rIEuawdy6+u69I4IsqoUWGaRx7E+95Xj2/J860ol8tz001/3Onrxc3cy5HgMGiPEumfHa9UERERERERESk7z/MIhew59fc8D9d1yRLQg0+3sWeRznEcosYnawIyBHTjk7UkPs9ArwnImoBeArqMT1CmTY3LwTc+GWNwCOg2Pl2WjBsAxieLIYOh2/j0WhSbawwp+s6rb0l8YePSawISJsD1XEKhkDWJkuL7iOu6dHSk6erqrXRIfRgTobc3R09Pno7OPJmMHVVCrusSSwT0pgOMKcyp41hUYUVh/5CBYzKU7ylox3NZ7GLPpyURERERERERKat//vMOPM+eq/vr6uoIAoPnefz977eyadOmSodU4jgO48aNI5/3ee2113jkkUfp7bVjATYcjjB9+kEcfPDBPPbYYyxZ8rxVV4LX1NSQTmeoqqriH/+4jQ0bNlQ6pJLGxkZc12PLli3ceedddHR0VDqkEs/zmDJlCrNnz2LRomdYuHARuVy20mEBEI/HOeKIOeyzzz7ce+99LFu2zJpESU1NDdlsjmQyad3zDWDUqFEYA6tXr+aBBx6ku7u70iEBEAqFmDp1KjNnHs7TTy/kmWeesaZqrsgY03+FkDGF5HA5EjtGFSXSPyVKRERERERERIapzZs3UejpbsdVw8YYuru78TyPTZs2sWHDxkqHVOI4UFNTTU9PD52dW9i4cSM9PXYkSiKRMB0dHfT09NDe3sGGDRutSpTk83m6uuycV9d16enpobu7m40bN9LebleipKOjnZ6eHjo6Oti4cYM1e0YkEnE6Ozvp6elh8+bNbNiw0ZpEie/7dHV1AVj3fANIJBL09PSwZUsXGzdupKvLnkTJ9s+3DRs2WpcoYYAN283W/5XjN9m2Nl4ifSlRIiIiIiIiIiIiIiKWKiRQjClT0t+SpJ/YRYkSEREREREREREREbGU2bp/SRkeyRi13pJ+KVEiw14qlbJq80KAZDJJOBwmCAJ837emfLUoCIKdbjbxfb8Uk03l5lD4hVuMz8b53TE213UrHdJOdozRJsW4PM8jkUhQVVVl1esjlUoRi8VKz0PbNuaz+bUB2+Y3HA6TTCapqqqqdEg7yWazVvXVFhERERERGWzFdlnlab6lPUqkf3atHouUmeu6HHHEEUSj0UqH0kd1dTVNTU309vZauVgdBAHZbJYgCOju7sZ1XasWXH3fJ5vNlmKyafyMMeTzeXK5HEEQkM/nrRq7HefWpo09oTB+xRjz+TxBEFg3v7lcjtraWg455BDGjRtn1WJ/NBplwoQJ5HI5urq6rJpf2+cWtr0+mpubmTFjBlu2bKl0SDvp6uriL3/5S6XDEBERERERGVKG8uy2VUiS2HMeL/ZQokSGvVgsZl2iJBqNkk6nmTdvHmvWrCGfz1c6pD5CoRCtra0kk0lWrFhBd7cdG48VxWIxxo8fTz6fZ/ny5WSz2UqHVOI4DrW1tTQ3N2/d8G6DVVUR4XCYkSNHEo/HrZxbKFRcjRkzhp6eHtasWWPV5nKe59HY2EhtbS3RaLRUvWGLaDRKKBRi4cKFLFu2jHQ6XemQ+kilUowePZru7m6r3/vi8TixWMyq516RbWMmIiIiIiIy2IwxGBNQjlRJ4bHsOY8XeyhRIsNaEAQ88MAD1rXeampqwvd91q1bxzPPPGPdYmYsFuPggw9mxIgRPPbYY6xfv77SIfVRU1PD3LlzSafTPPbYY3R1dVU6pBLXdRkzZgzTpk1j6dKlvPzyy1YttsbjcQ455BDq6+uZP38+GzZsqHRIO2lsbGT27Nls3LiRhQsX0tvbW+mQSsLhMJMmTWKfffbh2WefZcWKFda13srlckQiER566CE6OzsrHVIfTU1NzJw5k/Xr17No0SKr3/sef/xx1q1bV+mQdmJTYlhERERERGTolLNhlhIlsjO7Vo9FBkFHR4dV7WegsBiXTqfp7u6mvb3dusXCeDxOT08P6XSazs5O2tvbKx3STnp7e0mn03R0dFjVHsd1Xerq6kin03R1ddHe3m5VoiSTydDd3U0ikbB2biORCOl0mp6eHtrb261LlHR1dZFOp9myZQvt7e1WJUp836enp4cgCKycX9vf+2KxGN3d3VRVVVk5fsXWfiIiIiIiIm8nhf1JApxyVJRs3e9EZEdKlIiIiIiIiIiIiIiIxQzqmCWDSYkSEREREREREREREbGWMQanDLu5F/Yo2fPHkeHH3Z07f/vb38ZxnD63yZMnl46n02kuuugiGhoaSKVSnHnmmaxdu7bPYyxfvpxTTjmFRCJBU1MTX/nKV9RGQkREREREhg2dN4mIiIiUk4GtLbP29FZ4LLXekp3tdkXJAQccwD333LPtAbbbJPtLX/oSt912GzfddBM1NTVcfPHFnHHGGTz88MNAoXf6KaecQktLC4888ghr1qzhnHPOIRwO8/3vf78MP46IiIiIiEjl6bxJREREpDyKaZJy7VEi0p/dTpSEQiFaWlp2+npHRwfXXXcdN9xwA8cccwwAv/rVr5gyZQrz589n9uzZ3HXXXSxZsoR77rmH5uZmpk+fzne/+12++tWv8u1vf5tIJLLnP5GIiIiIiEiF6bxJREREpExMgDE+lCFRAmgzd+nXbrXeAnj55ZcZOXIkEyZM4KMf/SjLly8HYMGCBeRyOY477rjSfSdPnszYsWN59NFHAXj00UeZNm0azc3NpfuceOKJdHZ2snjx4j39WURERERERKyg8yYRERGR8irsL7LnN21SIv3ZrYqSWbNmcf3117P//vuzZs0avvOd7/DOd76T5557jra2NiKRCLW1tX2+p7m5mba2NgDa2tr6fNgvHi8e2x1r1qxhzZo1pb93dXXt1veLiIiIiIgMBlvOm3TOJCIiIsOBwWBMgFOG3dyNMWq/Jf3arUTJySefXPr/Bx10ELNmzWLcuHH86U9/Ih6Plz24XfnZz37Gd77znSH9N0VERERERN6ILedNOmcSERGR4UPpDRlcu916a3u1tbVMmjSJV155hZaWFrLZLO3t7X3us3bt2lJv3paWFtauXbvT8eKx3fHpT3+aBQsWlG4PPPDAW/9BREREREREBkmlzpt0ziQiIiLDQ7EKZM9vhkB7lEi/9ihR0tXVxauvvkprayuHHXYY4XCYe++9t3T8xRdfZPny5cyZMweAOXPm8Oyzz7Ju3brSfe6++26qq6uZOnXqbv3bra2tHHrooaXb9OnT9+RHERERERERGRSVOm/SOZOIiIgMB8ZsTXKYYI9voD1KpH+71Xrr3/7t3zjttNMYN24cq1ev5j/+4z/wPI8Pf/jD1NTUcP7553PJJZdQX19PdXU1n/vc55gzZw6zZ88G4IQTTmDq1KmcffbZXHnllbS1tfGNb3yDiy66iGg0Oig/oIiIiIiIyFDSeZOIiIhIORkC45dljxKMmnhJ/3YrUbJy5Uo+/OEPs3HjRkaMGMHcuXOZP38+I0aMAOAnP/kJruty5plnkslkOPHEE7n22mtL3+95HrfeeisXXnghc+bMIZlMcu6553LppZeW96cSERERERGpEJ03iYiIiNhpWwsvkb52K1Fy44037vJ4LBbjmmuu4ZprrhnwPuPGjeP222/fnX9WRERERERkr6HzJhEREZHyMQQY4wN7XlFijNnagkukr91KlIiIiIiIiIiIiIiIDD1VgsjgUaJERERERERERERERCwWUI6KEtR6SwagRImIiIiIiIiIiIiI2MkYcAymbPkNJUpkZ0qUiIiIiIiIiIiIiIi1jDE4ZSgoKexRokSJ7EyJEhERERERERERERGxksHgYDBlqwRRokR25lY6ABERERERERERERGRgZQrSVLOdIsML6ooERERERERERERERFLGcq3mTtbH0ukLyVKRERERERERERERMRSW2tAtLeIDCIlSkRERERERERERETEUgZMQJl2c0d7lEh/lCgREREREREREREREatpM3cZTEqUiIiIiIiIiIiIiIilDIYApwx7lBSSLUqUyM6UKBERERERERERERERi5UzwaFEiexMiRIRERERERERERERsVQxSVKGPUqGoKJk8eLF3HzzzSxcuJBcLsdf/vIXIpFI6fiWLVu48cYbue2223Ach/e85z2cc845eJ4HwOuvv84vfvELnnzySZqamjj//PM58sgjS9//yCOP8Ktf/YoVK1Zw4IEHcvHFFzN+/PhB/ZneDtxKByAiIiIiIiIiIiIiMjBT2Ih9T29DoL29HcdxGD16NE899RRBEJSOBUHA73//e/70pz/x/ve/n9NPP50rr7yS3/72twB0dnbygx/8gFdffZWLLrqIfffdl8997nM888wzADz33HN885vfpKWlhS9+8YusWbOGL33pS2zZsmVIfrbhTBUlIiIiIiIiIiIiImK18m3mPrhmz57NzJkzufPOO/nHP/7R59jq1au57777+MhHPsJZZ52F53msXbuW6667jo9+9KMsWLCAZcuW8b3vfY9DDjmEo48+mmeffZY//vGPTJs2jbvuuovW1lYuvPBCWlpaOOCAA3jf+97HvHnzOO200yr0Ew8PSpSIiLxNmSG6kkJEREREKqe5uRnPC1c6jJK6ulqqqqrwPI+WlhYikWilQypxHIempiZSqRT19XW0to6kt7e30mEBEImEaWhoIJVK0djYyKhRI8nn/UqHVVJTU01NTTWpVIqWlhZCIXuec42NhXEDaG1tJZFIVjiibUIhj8bGRlKpFA0NDYwcOZJsNlfpsACIx2PU1dWTSqVoamqitzdtzTlkTU011dXVJJNJWlqarXq+QeF9N5VKUVtbS2trK93dPZUOCYBQKFR6vjU2Fp5vuZwdz7ciYwLWrWvr7wjlbZdlMMaQzWZxnEI7L9d18Tyv9Pc94Xle6bbj47W1teH7PhMmTCAajWKM4fjjj+cXv/gFy5cvZ/ny5TQ1NdHQ0IDrukQiEWbNmsWDDz5IPp9n6dKlTJo0ierqalzXpbq6mqlTp/LCCy8oUbKHlCgRERERERERGWZ838cYw+WX/4DW1tZKh1Pi+z49PT0YYzjqqCNL/dhtkcvl6O3tZcaMw/joRz+C69rRsdwYQyaTIZvNMmvWTCKRSFkW88olCAJ6enoIgoC5c99h1bz6vk93dzeu63LyySdZM6dQmNdcLkc6nWbmzMOJRqPWzGsQBKTTafL5PHPmzCYcticZYfPzDSCfz9PT08Nhhx3KWWedac1zrpgYyGQyVr6PAKTTaT75yU+Sz+dLX/M8D9d1CYLyJupWrFjBDTfcQChUWB6fNm0ahx9++C6/J5/P8+qrr7Ju3bp+j8fjcaZNm0Y0OvBFAOl0upQAKaqvryefz9PZ2UlPTw/hcLj0mnMch9raWrq6uujq6qK3t5fq6urS8951XZLJJJ2dnbv188vOlCgREXmbsu0DkYiIiIiU1/HHH8/dd9+tz30iIrJXMMZw9NFH90kCTJs2jfPO+zjpdLqs/1Yul+O2224r/d11XWbMmLHL35nZbJY77riDBx54oN/jra2tXHrppbtMlHiehzEG399WFZhOp3Ech0gkQigUIgiCPvuaZDIZwuFw6Xg2my1VeBUTrtsnXuStUaJEREREREREZJhJpVJceumlZWsjIiIiMhSy2SzJZKFFnuu6HHHEEcycObOsrd+KVUnbtx5LJpNv+PsyFotx/vnn87GPfazf467rUlNTs8vHqK+vB2Djxo0EQYDjODzzzDP8/+3deWxUddvG8WuGMrVNN7B20xaqoqgsIkitiPxBXZDgEqOGYFJUNGhVjMYoGsUYFYyJcXkU44YmGAmi4IYistQlLIJUqJiyyohpqbaWTgt0m/v5g5cTB3l8lc6Z9ftJJsD5HZr7XJzOmbs3ZyYzM1OFhYXKy8vT/v371d7e7tS6bds2lZSUKC0tTfn5+dq7d68OHTqktLQ0dXZ2yu/3a+zYsf8mAhwDgxIAAAAAABKMx+NxftAEAEC8OPpujKPfpipc0tLS/vXf8Xq9ysjIcD736H85cOCAmpqa1NDQoK6uLv38889KT09Xfn6+iouLdcYZZ+j9999XcXGxJOnll1/WpZdeqpycHA0fPlwej0cLFy7UlClTVFtbq9WrV+vxxx+X1+vVmDFjNGfOHH3xxRe64IILtHDhQrW3tzMoCQMGJQAAAAAAAAAAhMF3332nJ554Qlu3blVjY6MmTZqk3NxcvfHGGzrrrLN0yy236LnnntO0adMkSRdeeKHuvfdeeb1eFRcX66677tKLL76oRYsWKSMjQ9OmTdMll1wiSbr44ovl9/v1yiuv6Mknn9Qpp5yiWbNmaeDAgVE84sTAoAQAklQ4b1sFAAAAAACAVF5ervfeey/kc0i8Xq8yMzPl8XhUWlqqp59+Wh0dHZIO30Vz5A6XPn36aOzYsRo5cqS6urrk9XqVnp7u3FWTlpamyspKXX/99erp6VFKSorS09Odz3XB8WNQgqQQSz8QPvJ+h3+uKZbqkw7Xc+Tx522x5lh1xoI/1xSL9UkKqS8WHZ1hrInVf9+jv2djqTaPxxMXzytS7J9/AAAAAIDY5fP5/vbtwo4MP9LT04+53qdPH2VmZh7318fxYVCChHVkatve3i6v1xvlakL98ccf8vv9ampqUiAQcCbIsaK7u1sNDQ3q6OhQS0uL2traol1SCK/XK7/fr87OTrW2turAgQPRLsnh9XrV1NQkv9+v3377TW1tberu7o52WY6enh7V19frwIEDamlpcT4cLJa0tLTI7/erpaVFgUBAhw4dinZJjo6ODjU2Nsrn86mpqUnt7e0KBoPRLsthZtq7d698Pp9aW1tj7t83NTVVfr9fzc3NMfvcV19fH7PPfZKc55NYOu8AAAAAAIh3HkuQ/yrZ2tqq7Oxs7d+/X1lZWdEuBzGgublZlZWV/DAJAJBQ+vfvr//85z/Kzs6OdimIAbwGxr/B+QIAAIBk809fA3NHCRJWv379NH/+fPl8PuftrgAAiGdmpq6urr+9DRsAAAAAAPw7DEqQsDweD//bFgCQcI58yB8AAAAAAAiP2PrgBgAAAAAAAAAAgAhiUAIAAAAAAAAAAJIWgxIAAAAAAAAAAJC0GJQAAAAAAAAAAICkxaAEAAAAAAAAAAAkLQYlAAAAAAAAAAAgaTEoAQAAAAAAAAAASYtBCQAAAAAAAAAASFoMSgAAAAAAAAAAQNJKiXYB4WJmkqTW1tYoVwIAAABExpHXvkdeCwN/h54JAAAAyeaf9kwJMyjZuXOnJKm4uDjKlQAAAACRFQgElJ2dHe0yEOMCgYAkeiYAAAAkn/+vZ0qYQUkwGJQkrV69WiNGjIhyNYmnpqZG48aNU3V1tc4999xol5OQyNhd5Osu8nUX+bqLfN1Fvu4yMwUCARUVFUW7FMSBoqIiLV26VFdccQXfky7hOc9d5Osu8nUX+bqLfN1Fvu4iX3f9054pYQYlXu/hj1vJzMxUVlZWlKtJPBkZGc6v5OsOMnYX+bqLfN1Fvu4iX3eRr/u4kwT/lNfrVX5+viS+J93Cc567yNdd5Osu8nUX+bqLfN1Fvu77Jz0TH+YOAAAAAAAAAACSFoMSAAAAAAAAAACQtBJmUFJYWKhZs2apsLAw2qUkJPJ1Hxm7i3zdRb7uIl93ka+7yBeILXxPuot83UW+7iJfd5Gvu8jXXQN8mUkAAAtxSURBVOTrLvKNDR4zs2gXAQAAAAAAAAAAEA0Jc0cJAAAAAAAAAADAv8WgBAAAAAAAAAAAJC0GJQAAAAAAAAAAIGkxKAEAAAAAAAAAAEmLQQkAAAAAAAAAAEhaDEoAAAAAAAAAAEDSYlACAAAAAAAAAACSFoMSAAAAAAAAAACQtBiUAAAAAAAAAACApJUwg5KXXnpJAwcO1AknnKCysjKtX78+2iXFha+++kqTJk1SUVGRPB6PlixZErJuZnr00UdVWFiotLQ0VVRUaPv27SH7NDc3a8qUKcrKylJOTo5uueUWtbW1RfAoYtPs2bN1/vnnKzMzU3l5ebr66qtVV1cXss+hQ4dUVVWlE088URkZGbr22mu1b9++kH38fr8mTpyo9PR05eXl6f7771d3d3ckDyVmzZ07V8OGDVNWVpaysrJUXl6uzz77zFkn3/CZM2eOPB6P7rnnHmcb+fbOY489Jo/HE/IYPHiws06+vffrr7/qxhtv1Iknnqi0tDQNHTpUGzZscNa5xh2/gQMH/uX89Xg8qqqqksT5C8QqeqbjQ8/kLvomd9EzRRZ9U3jRM7mPnsk99ExxyBLAggULzOfz2Ztvvmk//vij3XrrrZaTk2P79u2Ldmkxb+nSpfbwww/bBx98YJJs8eLFIetz5syx7OxsW7Jkif3www925ZVXWmlpqR08eNDZ5/LLL7fhw4fb2rVr7euvv7bTTz/dJk+eHOEjiT2XXXaZzZs3z2pra62mpsauuOIKKykpsba2Nmef6dOnW3Fxsa1YscI2bNhgF1xwgV144YXOend3tw0ZMsQqKips06ZNtnTpUsvNzbWZM2dG45BizkcffWSffvqpbdu2zerq6uyhhx6yvn37Wm1trZmRb7isX7/eBg4caMOGDbMZM2Y428m3d2bNmmXnnHOO1dfXO4/ffvvNWSff3mlubrYBAwbY1KlTbd26dbZr1y5btmyZ7dixw9mHa9zxa2xsDDl3ly9fbpJs1apVZsb5C8QieqbjR8/kLvomd9EzRQ59U/jRM7mLnsld9EzxJyEGJaNHj7aqqirnzz09PVZUVGSzZ8+OYlXx5+gX/cFg0AoKCuyZZ55xtrW0tFhqaqq9++67Zma2detWk2Tfffeds89nn31mHo/Hfv3114jVHg8aGxtNklVXV5vZ4Sz79u1r7733nrPPTz/9ZJJszZo1Zna4KfN6vdbQ0ODsM3fuXMvKyrKOjo7IHkCc6Nevn73++uvkGyaBQMAGDRpky5cvt3Hjxjkv+Mm392bNmmXDhw8/5hr59t4DDzxgF1100f9c5xoXXjNmzLDTTjvNgsEg5y8Qo+iZwoOeyX30Te6jZwo/+iZ30DO5i54psuiZYl/cv/VWZ2enNm7cqIqKCmeb1+tVRUWF1qxZE8XK4t/u3bvV0NAQkm12drbKysqcbNesWaOcnByNGjXK2aeiokJer1fr1q2LeM2xbP/+/ZKk/v37S5I2btyorq6ukHwHDx6skpKSkHyHDh2q/Px8Z5/LLrtMra2t+vHHHyNYfezr6enRggUL1N7ervLycvINk6qqKk2cODEkR4nzN1y2b9+uoqIinXrqqZoyZYr8fr8k8g2Hjz76SKNGjdJ1112nvLw8jRgxQq+99pqzzjUufDo7OzV//nzdfPPN8ng8nL9ADKJncg/Xk/Cjb3IPPZN76JvcQ8/kHnqmyKFnig9xPyj5/fff1dPTE3LSSFJ+fr4aGhqiVFViOJLf32Xb0NCgvLy8kPWUlBT179+f/P8kGAzqnnvu0ZgxYzRkyBBJh7Pz+XzKyckJ2ffofI+V/5E1SFu2bFFGRoZSU1M1ffp0LV68WGeffTb5hsGCBQv0/fffa/bs2X9ZI9/eKysr01tvvaXPP/9cc+fO1e7duzV27FgFAgHyDYNdu3Zp7ty5GjRokJYtW6bbb79dd999t95++21JXOPCacmSJWppadHUqVMl8fwAxCJ6JvdwPQkv+iZ30DO5i77JPfRM7qJnihx6pviQEu0CgGRQVVWl2tpaffPNN9EuJeGceeaZqqmp0f79+7Vo0SJVVlaquro62mXFvV9++UUzZszQ8uXLdcIJJ0S7nIQ0YcIE5/fDhg1TWVmZBgwYoIULFyotLS2KlSWGYDCoUaNG6amnnpIkjRgxQrW1tXrllVdUWVkZ5eoSyxtvvKEJEyaoqKgo2qUAAOIcfZM76JncQ9/kLnomd9EzRQ49U3yI+ztKcnNz1adPH+3bty9k+759+1RQUBClqhLDkfz+LtuCggI1NjaGrHd3d6u5uZn8/8+dd96pTz75RKtWrdIpp5zibC8oKFBnZ6daWlpC9j8632Plf2QNks/n0+mnn66RI0dq9uzZGj58uJ5//nny7aWNGzeqsbFR5513nlJSUpSSkqLq6mq98MILSklJUX5+PvmGWU5Ojs444wzt2LGD8zcMCgsLdfbZZ4dsO+uss5xb9bnGhceePXv05Zdfatq0ac42zl8g9tAzuYfrSfjQN7mHnsk99E2RRc8UXvRMkUHPFD/iflDi8/k0cuRIrVixwtkWDAa1YsUKlZeXR7Gy+FdaWqqCgoKQbFtbW7Vu3Ton2/LycrW0tGjjxo3OPitXrlQwGFRZWVnEa44lZqY777xTixcv1sqVK1VaWhqyPnLkSPXt2zck37q6Ovn9/pB8t2zZEnLRWb58ubKysv5yMcNhwWBQHR0d5NtL48eP15YtW1RTU+M8Ro0apSlTpji/J9/wamtr086dO1VYWMj5GwZjxoxRXV1dyLZt27ZpwIABkrjGhcu8efOUl5eniRMnOts4f4HYQ8/kHq4nvUffFHn0TOFD3xRZ9EzhRc8UGfRMcSTanyYfDgsWLLDU1FR76623bOvWrXbbbbdZTk6ONTQ0RLu0mBcIBGzTpk22adMmk2TPPvusbdq0yfbs2WNmZnPmzLGcnBz78MMPbfPmzXbVVVdZaWmpHTx40Pkal19+uY0YMcLWrVtn33zzjQ0aNMgmT54crUOKGbfffrtlZ2fb6tWrrb6+3nkcOHDA2Wf69OlWUlJiK1eutA0bNlh5ebmVl5c7693d3TZkyBC79NJLraamxj7//HM76aSTbObMmdE4pJjz4IMPWnV1te3evds2b95sDz74oHk8Hvviiy/MjHzDbdy4cTZjxgznz+TbO/fdd5+tXr3adu/ebd9++61VVFRYbm6uNTY2mhn59tb69estJSXFnnzySdu+fbu98847lp6ebvPnz3f24RrXOz09PVZSUmIPPPDAX9Y4f4HYQ890/OiZ3EXf5C56psijbwofeiZ30TO5j54pviTEoMTM7MUXX7SSkhLz+Xw2evRoW7t2bbRLigurVq0ySX95VFZWmplZMBi0Rx55xPLz8y01NdXGjx9vdXV1IV+jqanJJk+ebBkZGZaVlWU33XSTBQKBKBxNbDlWrpJs3rx5zj4HDx60O+64w/r162fp6el2zTXXWH19fcjX+fnnn23ChAmWlpZmubm5dt9991lXV1eEjyY23XzzzTZgwADz+Xx20kkn2fjx450X/GbkG25Hv+An39654YYbrLCw0Hw+n5188sl2ww032I4dO5x18u29jz/+2IYMGWKpqak2ePBge/XVV0PWucb1zrJly0zSXzIz4/wFYhU90/GhZ3IXfZO76Jkij74pfOiZ3EfP5C56pvjiMTOL1N0rAAAAAAAAAAAAsSTuP6MEAAAAAAAAAADgeDEoAQAAAAAAAAAASYtBCQAAAAAAAAAASFoMSgAAAAAAAAAAQNJiUAIAAAAAAAAAAJIWgxIAAAAAAAAAAJC0GJQAAAAAAAAAAICkxaAEAAAAAAAAAAAkLQYlAAAAAAAAAAAgaTEoAQAAAAAAAAAASYtBCQAAAAAAAAAASFoMSgAAAAAAAAAAQNL6L92izQvN6Md7AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 2000x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "env = FourRoomsMazeEnv(Maze(seed=1111, maze_type='fourrooms_random_layouts'), max_steps=fb_config['agent']['context_len'])\n",
    "\n",
    "fig, ax = plt.subplots(ncols=2, figsize=(20, 10))\n",
    "pred_policy_img = visualize_policy(env, layout_type=0, task_num=3)\n",
    "\n",
    "ax[0].imshow(pred_policy_img)\n",
    "pred_value_img = visualize_value_image(env, layout_type=0, task_num=3)\n",
    "ax[1].imshow(pred_value_img)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "645c69ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ -4,  -1,   0,   1,   6,  11,  19,  33,  47,  53,  46],\n",
       "       [  1,   1,   3,   5,   8,  14,  26,  44,  61,  70,  63],\n",
       "       [  2,   2,   3,   5,   8,  11,  15,  51,  77,  97,  86],\n",
       "       [  0,   2,   3,   6,  12,  10,  14,  55,  97, 142, 124],\n",
       "       [  3,   9,  12,  13,  20,  28,  42,  95, 177, 196, 175],\n",
       "       [ 10,  13,  16,  21,  36,  53,  68, 167, 237, 244, 197],\n",
       "       [  9,  12,  16,  24,  39,  69, 140, 224, 321, 302, 233],\n",
       "       [  9,  12,  15,  22,  32,  43,  67, 244, 426, 350, 300],\n",
       "       [ 10,  12,  14,  19,  26,  31,  39, 324, 418, 420, 385],\n",
       "       [ 10,  11,  13,  17,  21,  24,  28, 278, 413, 362, 352],\n",
       "       [  9,  12,  15,  13,  15,  20,  32, 274, 434, 389, 331]],\n",
       "      dtype=int32)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.load(\"q_func.npy\", allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "095582b1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c2bc4ed9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "724317ab",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jax2",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
