{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 575,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams['svg.fonttype'] = 'none'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import matplotlib as mpl\n",
    "import pandas as pd\n",
    "mpl.rcParams['pdf.fonttype'] = 42\n",
    "mpl.rcParams['font.family'] = 'serif'\n",
    "mpl.rcParams['font.serif'] = 'Times New Roman'\n",
    "mpl.rcParams['font.size'] = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 520,
   "metadata": {},
   "outputs": [],
   "source": [
    "mpl.rcParams['font.size'] = 9"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [],
   "source": [
    "for col in training_data.columns:\n",
    "\n",
    "    m = pd.Series(col).str.extract(r'^(?P<run>.+?) - (?P<ep>\\d+).*(?:/|_)(?P<tail>[^/_]+)$')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L64_skip8_3pbt_64_rollout_Gamma99_epoch2_20250426_181928_792734 - 2/reward/reward_min'"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "col"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<pandas.core.strings.accessor.StringMethods at 0x76a9713c5df0>"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>run</th>\n",
       "      <th>ep</th>\n",
       "      <th>tail</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L...</td>\n",
       "      <td>2</td>\n",
       "      <td>min</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 run ep tail\n",
       "0  Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L...  2  min"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "cols = training_data.columns\n",
    "\n",
    "# 1) Drop MIN/MAX columns\n",
    "mask = cols.str.contains(r'__MIN|__MAX')\n",
    "training_data = training_data.loc[:, ~mask]\n",
    "\n",
    "# 2) Rename the rest\n",
    "# Pattern is:    <run-name> - <epoch>/policy_stats/..._raw_score\n",
    "# We’ll pull out run-name and epoch, and form “runname_epoch#”\n",
    "new_names = {}\n",
    "for col in training_data.columns:\n",
    "\n",
    "    m = pd.Series(col).str.extract(r'^(?P<run>.+?) - (?P<ep>\\d+).*(?:/|_)(?P<tail>[^/_]+)$')\n",
    "    run  = m.loc[0, 'run']\n",
    "    ep   = m.loc[0, 'ep']\n",
    "    tail = m.loc[0, 'tail']\n",
    "\n",
    "    expname = col[:3]\n",
    "    if col.startswith('Epi_Ins9_Depth_Fix3_Tr_AR_LSTM'):\n",
    "        expname = 'LSTM'\n",
    "    new   = f\"{expname}_{ep}_{tail}\"\n",
    "    new_names[col] = new\n",
    "    if col=='Step': new_names[col] = 'Step'\n",
    "    # if col.endswith('step'): new_names[col] = f\"{expname}_{ep}_envstep\"\n",
    "\n",
    "training_data = training_data.rename(columns=new_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Step', 'LSTM_0_step', 'LSTM_1_step', 'LSTM_2_step', 'LSTM_0_score',\n",
       "       'LSTM_1_score', 'LSTM_2_score', 'LSTM_0_len', 'LSTM_1_len',\n",
       "       'LSTM_2_len', 'LSTM_0_min', 'LSTM_1_min', 'LSTM_2_min', 'Res_0_step',\n",
       "       'Res_1_step', 'Res_2_step', 'Res_0_score', 'Res_1_score', 'Res_2_score',\n",
       "       'Res_0_len', 'Res_1_len', 'Res_2_len', 'Res_0_min', 'Res_1_min',\n",
       "       'Res_2_min', 'Epi_0_step', 'Epi_1_step', 'Epi_2_step', 'Epi_0_score',\n",
       "       'Epi_1_score', 'Epi_2_score', 'Epi_0_len', 'Epi_1_len', 'Epi_2_len',\n",
       "       'Epi_0_min', 'Epi_1_min', 'Epi_2_min'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 81,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "training_data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Step', 'LSTM_0_envstep', 'LSTM_1_envstep', 'LSTM_2_envstep', 'LSTM_0',\n",
       "       'LSTM_1', 'LSTM_2', 'Res_0_envstep', 'Res_1_envstep', 'Res_2_envstep',\n",
       "       'Res_0', 'Res_1', 'Res_2', 'Epi_0_envstep', 'Epi_1_envstep',\n",
       "       'Epi_2_envstep', 'Epi_0', 'Epi_1', 'Epi_2'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "training_data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [],
   "source": [
    "##interpolate\n",
    "colors={'Res': 'C1', 'Epi': 'C0', 'LSTM': 'C2'}\n",
    "# Compute smoothed curve\n",
    "for expname in colors:\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}\"\n",
    "        training_data[col+'_step'].interpolate(method='linear', inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "from numpy import nansum\n",
    "\n",
    "\n",
    "import numpy as np\n",
    "from scipy import interpolate\n",
    "\n",
    "def gaussian_smooth_step(df, xcol, ycol, sigma):\n",
    "    \"\"\"\n",
    "    Smooth ycol in df using a Gaussian kernel defined over xcol,\n",
    "    first removing any (x,y) pairs where y is NaN.\n",
    "    \"\"\"\n",
    "    # Extract raw arrays\n",
    "    x_all = df[xcol].values\n",
    "    y_all = df[ycol].values\n",
    "\n",
    "    # Keep only the non-NaN points\n",
    "    valid = ~np.isnan(y_all)\n",
    "    x = x_all[valid]\n",
    "    y = y_all[valid]\n",
    "\n",
    "    # Prepare an output array\n",
    "    smoothed = np.full_like(x_all, fill_value=np.nan, dtype=float)\n",
    "\n",
    "    # Compute pairwise distances between all targets and valid points\n",
    "    # dx has shape (n_all, n_valid)\n",
    "    dx = x_all[:, None] - x[None, :]\n",
    "\n",
    "    # Un-normalized Gaussian weights\n",
    "    W = np.exp(-0.5 * (dx / sigma)**2)\n",
    "\n",
    "    # Normalize each row to sum to 1\n",
    "    row_sums = W.sum(axis=1, keepdims=True)\n",
    "    W /= row_sums\n",
    "\n",
    "    # Weighted average only over the valid y's\n",
    "    smoothed = W.dot(y)\n",
    "\n",
    "    return smoothed\n",
    "\n",
    "\n",
    "# Choose sigma (e.g., 5 units in 'Step')\n",
    "sigma = 1000000\n",
    "# Compute smoothed curve\n",
    "df = training_data[['Step']].copy()\n",
    "for expname in colors:\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}\"\n",
    "        # Smooth the data\n",
    "        df[col+'_step'] = training_data[col+'_step'].copy()\n",
    "        for stat in ['score','len','min']:\n",
    "            df[col+'_'+stat] = gaussian_smooth_step(training_data, col+'_step', col+\"_\"+stat, sigma)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Step', 'LSTM_0_step', 'LSTM_1_step', 'LSTM_2_step', 'LSTM_0_score',\n",
       "       'LSTM_1_score', 'LSTM_2_score', 'LSTM_0_len', 'LSTM_1_len',\n",
       "       'LSTM_2_len', 'LSTM_0_min', 'LSTM_1_min', 'LSTM_2_min', 'Res_0_step',\n",
       "       'Res_1_step', 'Res_2_step', 'Res_0_score', 'Res_1_score', 'Res_2_score',\n",
       "       'Res_0_len', 'Res_1_len', 'Res_2_len', 'Res_0_min', 'Res_1_min',\n",
       "       'Res_2_min', 'Epi_0_step', 'Epi_1_step', 'Epi_2_step', 'Epi_0_score',\n",
       "       'Epi_1_score', 'Epi_2_score', 'Epi_0_len', 'Epi_1_len', 'Epi_2_len',\n",
       "       'Epi_0_min', 'Epi_1_min', 'Epi_2_min'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "training_data.columns\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [],
   "source": [
    "for expname in colors:\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}\"\n",
    "        # Smooth the data\n",
    "        df[col+'_score'] /= 10\n",
    "        df[col+'_min'] /= 4.82\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "for expname in colors:\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}\"\n",
    "        df[col+\"_smooth\"]/=10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fig,ax=plt.subplots(figsize=(5.5, 3))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,ax=plt.subplots(figsize=(5.5, 3))\n",
    "# Compute smoothed curve\n",
    "df.plot(x='Step', title='Training data',legend=False,ax=ax,)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAAINCAYAAABI5sckAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/OQEPoAAAACXBIWXMAAA9hAAAPYQGoP6dpAADzmElEQVR4nOzdd3QU1dvA8e9uNr33RgophN47GLoUAQERBcHXAhYQReAnoGLvXVQUsKCoIIh0BaR3AoReEhIS0ntvW+f9Y5INkQAhpJL7OWfPlpm9++wQdu7c8lyFJEkSgiAIgiA0Kcr6DkAQBEEQhLonKgCCIAiC0ASJCoAgCIIgNEGiAiAIgiAITZCoAAiCIAhCEyQqAIIgCILQBIkKgCAIgiA0QaICIAiCIAhNkKgAXEOSJPLy8hC5kQRBEIS7nagAXCM/Px97e3vy8/PrOxRBEARBqFWiAiAIgiAITVCDqwD8888/dO/endjY2Bvus3HjRl544QWeeeYZduzYUeVtgiAIgiDIVPUdwLXS0tLQ6XQcO3bshvtcunSJd955h6NHjyJJEl27dmXTpk14e3vfdJsgCIIgCOUaVAXAzc2N++6776b7fPHFFwwbNgyFQoFCoaBXr158++23vPPOOzfdJgiCUNMMBgmDJKGXJIo1egrVOtQ6Axq9AY3OgE5vwCBROrBYgXF8sULiv2ON5ecSWr2E1iCh1RvQ6vXG/eQSKnksld8bkIyPbz2WuXyHa/etyyHQDlamWJiaVHitm7/Tda/VKUmCklzQqUGvAYO29ODqQVsM6jx5m0EPGMBgAEkPSPLBs/UApYn8HhMV2LiDZABzO7Cwq7/vVYkGVQEAUCpv3iuxa9cu5s2bZ3weHBzM2rVrb7mtMmq1GrVabXyel5dX3bAFQWgkJEkiMaeYy6n5nE/O43JqAWl5JWQXaSlU69DqJXSGshM3gIRBAn3pyV6rN5Q+ru9vcnfaOuseWnrU8Yky7SKcWA4x+yDrCuhKav4zhr4HvWbUfLl3oMFVAG4lMTERJycn43NbW1uSkpJuua0y77//Pm+++WbtBSsIQr2TJInT8TmsDIvnWGwWCTnFaHSG+g5LuAGlsW2jDujUsH0hhC2pvc9QmMgtAnX5vaqo0VUAFAoFFhYWxucajQZTU9NbbqvMggULmD17tvF5Xl4ePj4+tRC1IAh1Kb9Ey1/hCfxxLIHLaflo9Te+XLc0NcHByhRHK1PsLU0pVOtJzS8hp0iL+gYVBWszE/ycrQh2s6G5izXejla42JhjZaZEqVCAQgFSacuBJDf36w1yV4HBIKEyUWKhUmJuaoK5Sinfrn2sMsHURO7KFGqJXgur/w8i/5GftxoFISPg0CK5RaCMZwdoNRp8eoCDD1g4gMocFEqMJ3WFQn5c4Z7y+waq0VUAvLy8yM3NNT7Pz8/Hy8vrltsqY25ujrm5ee0FKwhCnYnLKuTXI3HsuJBKTEbhdX3ZlqYmBLvb0MXXgXtauBLsZou7nQVmKrnbsVijZ86aUxy+klLhfeYqJb5OVrTwsKVvkAu9A53xdbISJ+fGbve78slfZQEP/gwthsLqR8tP/koVPPQrhAyv3zhrUaOrAAwaNIjIyEjj86ioKAYMGHDLbYIg3D0K1Dr2Rqaz9Vwyp+NzSckrqbRZ393OnKFtPHi0lx9BbrY3LM9gkHhh1Um2X0jF1ETBE32ac28bD3ydrHC2NkOpFCf7u0rSKTj4pfx43FIIGQZn/4SLG8v3GfbBXX3yhwaYB6AsDe+16Xg/+eQTIiIiACrM79fpdISFhTFt2rRbbhMEofHS6g0cjMpg3p+n6fzWdtq+vo0Zv4Wz6XQycVlFxpP/f0/TDpZmtzz5Ayzdf4XtF1IxUyn55YkeLBjRii5+jrjamouT/91o97vyyPy2D0Dr+0GngV1vl293aw1dn6i/+OpIg2oBKCgoYMWKFQD8/PPPPPfcc7i4uLBy5Ur8/f0JCQmhQ4cOPP7448ydOxeNRsPnn3+Oh4cHwE23CYLQuBgMEuFx2Ww4lcSG04nkFeuu28feUkWwmy2SJHEyPgeDBKYmCtp62xOVVkBEaj7jvzvMuul9aO5iXennJGQX8cUOueXwrdFt6BXoXKvfS6hnyafh8nZ5cN6AV+TXzqyC7Fi5X18yQJ8XSgfu3d0Uklj5xigvLw97e3tyc3Oxs2tY8zUF4W6XW6QlPC6bk3HZnIzP4VRcDvnq60/6Po6WTOzuy8TuvsRnF/HyurOcS5Sn8N7b2p237m+Lh70FmQVqHl9+jDMJuQS72bBpZt9K55dP++U4/15IpXtzJ/54qqfo27/bbZkLx5ZBm7Hw4HJ5rueSeyDlrLzd3A7mRICZVb2GWRcaVAuAIAhNS3q+mtXH49l8JplLKXk3TV4T7GZDh2b22FuakpJXwtMrThAWmwWAvaUpb49py6j2nsYTuLONOd//X1dGfHmAy2kFfLnzMvOGtaxQ5q5Lqfx7IRWVUsE7Y9qKk//dTlsCZ1fLjztNke8TT8gnf4WJnNCn1egmcfIHUQEQBKEeSJLEnycSeGvThQpX+R52FjhZm5Kv1hGfVVzhPZfTCricVlDhNaUCxnT0Zt7wlrjbWfBfbrYWvDu2LU+vOMGSvdEMbeNBRx8HAEq0et7YeAGAJ/o2p4X7zccJCHeB2P1ylj9bTwjoL792Uu52xtQKNPnQ4t56C6+uiQqAIAh1Ki2/hAVrz7LzUhog9+ObmijJKNCQkldCSl55FjalAjr5OOLtaIm1uco4T95MpcTN1pyBrdzxdrC86ecNbePB6A5ebDydxOw/TrHl+XuwNDPhm91RxGUV4W5nzvODgmv1OwsNROQ2+b7FULmPX6+Di5vk1zT5citA8371F18dExUAQRDqhCRJbDqTxPy1ZynS6I2v514zuM/XyZJCtZ7MQg3eDhZsmtkXJ+s7z9Xx1v1tCIvJ4kpGIbNXnyK0hStf744CYOHI1tiYi5/Cu54kweXSCkDwUPn+6kEoygQza9AUQrNuYOlQbyHWNfFXLwhCrTuflMsn2yLYHZFufM3S1IQeAU508nGko68D7b3t+WpXFD8ejMHGXMXPT3SvkZM/gIOVGZ9O6MBjP4Xxz7kU/jknJ/t5uJsPI9vfOFmYcBfJjIacODAxh4DSq/wL6+V7O2/IiASfbvUWXn0QFQBBEGqUWqfncHQmp+JziEor4HRCToX+fBOlgjlDWvBYH3+szMp/gtadTODHgzEAfDqhwy3n7t+uPkEu/PRYd979+yIZBWomdG3Gi4Nb1OhnCA1Y3GH53ruLfMVv0Jc3/5fx6FD3cdUjUQEQBKFGSJLEqmPxfLItgsxCTYVtCuSVUq3MTPj5ie5083eqsD08Lpt5a+VpWM8PDGJom9rJ39E32IV/XrinVsoWGrj4o/K9bw/5Pu4wFKbLuf1z4uXXPEUFQBAE4bYYDBKvrD/LyjD5h9TJ2ozOPg609rIjX63jp4OxKBXwzaTO1538zyflMu3n42h0Boa0dmeWuCoXakNZBcCnp3x/aYt879cbIv6WZwE4B9ZPbPVEVAAEQbhjX+26bDz521uaklWoYcelNHaUjvQHuQleqVSQXajBztKUtPwS1p9MYtHOyxRr9bTztueLhzqK1LtCzSvKkvv4AXy6ywMCL22Wnzv6y/fubZtE9r9riQqAIAhVIkkSGQUasgo1ZBaoSS9Qk5pXwtZzKYTH5Rj3yy3WYqZSYmuuqtAVsP9yBvsvZ1Radp8gZ76d3AVrMRpfqA0Jx+V752CwcoKUc/KAQJWFPBYAmlzzP4gKgCAINyBJEiVaPTsuprH5TBLHYrPJ+k/f/rUsTJWM7uDF4Fbu9Aly5rUNF1gbnoCDlSlP9m1OdFoBpxNyickoBOTBgG287Jjc04/xnZuJK3+h9qSWpvn16ijflzX/Bw6E9NLlfz3b13lY9U1UAARBACAyNZ+/zyYTHpdDVGo+qXlq9P/JzasALM1MsDFX4W5nwZWMAgrVelp52rLu2T5YmMlNqF/tvMza8ARjv3+fIBdjGUUaHWqtAStzE8xVTavJVagnKefke/e28n1Z83/IcNj+qvzYQ1QABEFoYpJyilm4/pwxM9/NSECRRk+RRk9avhqQ+/y/m9wFCzMTCtQ6PtkWwfJDsQC8MbpNhZM/gJWZCiuzmv4WgnATqddUAHLiIeWMvPKfezs5NbDSFNxa1W+M9UBUAAShCbuUkseUH8JIz1ejUiroHejM2cRcsou02JireLZfIM1drHlt4zkyCipv/s8t1nLv5/vwdrQkKaeYEq0BgP8NDeHRXv51+G0EoRLaYsiUsz7i0RYubJAf+/SEvAT5sVtLUNVM0qnGRFnfAQiCUD8yCtQ88dMx0vPVhLjbsvG5vmQXacku0uLrZMU/L9zDjIFBJOeVkFGgwcJUyX3tPHGxMcfCVEmfIGce6+2Pr5MVap2BK+mFlGgNBLhY8+NjXZkxIKi+v6IgQNpFkAxg5QI27nB2jfx6q1GQfFp+3AQHAIJoARCEJkmSJOasPk1SbgnNXaxZ/XQvFu26zNnEXBytTPl9Wg+aOVqRmlfCJ9siAHhtZBsm9fC9rqzXR7UmNrOI5NxiXG3MCXKzEcvqCg1HWfO/R1vIugIJx+Tm/7YPwMaZpdtEBUAQhCZi85lk9kamY2aiZMmULiTnFRv77T+d0IFmjvJ66Ev3XaFYq6eTrwMPd/OptCyFQkFzF2uau1jXVfiCUHWp5+V797ZwZrX8OGAA2LrLYwGgSc4AANEFIAhNTl6Jlrc2XwBg+oBAgt1seG3DefQGieFtPRjY0h2Quwh+O3oVgFmDW4hpekLjVDYDwK0NnPlDftzhYShIg/xkQFE+O6CJERUAQWhivvj3Mun5agJcrHm2fyAbTycRFpOFhamSV0e2Nu73/f4YSrQGOjSzJzTY5SYlCkIDJUnlOQAUCsiOAVNraHkfJJde/TsHgblN/cVYj2q0AlBUVASARnPjZCGCINSfqLR8fjkcC8hT9PQGiQ/+uQTAjP5BeDtYApBTpGFF6X4zBwaLPn2hccpNKJ3mpypfC6DVKHk1wJSyAYBNs/kfaqgCcOLECVq0aMH48eMBiIiIYN68eaSmptZE8YIg1ABJknhz0wV0BonBrdwJbeHKd3uvkJxbgreDJdNCA4z7/ngwlkKNnlaedgxq5VaPUQvCHSjr/3cOhgvr5cftJ8j3TXwGANRQBeC5555j+vTpdO7cGYB27doxcOBApkyZUhPFC4JQAzadSWb/5QzMTJS8el8rLiTl8e0eeX70yyNaYWEqZ+XLK9Gy/GAMADMHBomrf6HxKmv+t3aG4myw8YCA/vJrZV0ATTADYJkaqQD07duXWbNm4erqanwtNTWVY8eO1UTxgiDcoZTcEhaulwdDPds/EEszE5797QRavdwaMKKdh3HfFYevkleiI8jNhmFtPG5UpCA0fGUtAOp8+b7NGHnFv5JceTwAiBaAO2Vra0t8fLzxSuHvv/9m7ty5DBky5LbKKSwsZMaMGbz66qvMmjULtVp93T579uxBoVBUuHXr1q1CGU5OTsZt69atu7MvJwiNXH6JlieWHyO3WEuIhw2mKgX3LdrP1cwifJws+fCBdsb/u0UaHT8ckH8YnxsQJEb+C41bWQUg47J833qMfJ9S2jJg7yOvDthE1UgegNmzZzN37lzWr1/P/Pnz0ev1jB8/nq+//vq2ynn22WcZO3YsY8eO5ZdffmHBggV89tlnFfbZtWsXq1evxsdHnpO8e/dudDqdcfuPP/7IkiVLcHR0BGDAgAF3+O0EofGKySjk2V9PcCklHzMTBZdTC/hkm7wueksPW5Y92hVnm/IUqD8djCWrUIOfsxUj23vWV9iCcOeuTQGsLZKb/316yM9F8z8ACkn6z3Jf1ZCcnIynpyeSJJGeno6zszMJCQl4enpiZla1VT+SkpIIDAwkOzsbCwsL0tPT8fPzIzU1FVtbW+N+cXFx+PqWZyObNm0aL7zwAm3btkWv1zNixAgWLVpESEjIbX+PvLw87O3tyc3Nxc7O7rbfLwgNRYlWz+I90Xy7OwqtoeJ/8a5+jkzo6sP9nbwqrMaXll/CgI/3UKjR88VDHRnTybuuwxaEmpMYDssGgIk56NXQ/SkY8bG8be00OLsaBrwC/V6q3zjrUY10AXz11VeAnBHMzc0NExMTPDw8ePjhh6tcxp49e3BxccHCwgIAV1dXzMzMCAsLq7DftSd/g8HAxYsXadtWTuKwfft2Dh48SMuWLRk6dChpaTdf3UytVpOXl1fhJgiNmcEgsfF0EkM+38uinZeNJ38TpYLHevuzc04//ny2NxO6+VQ4+ZfNECjU6Ong48DoDl719RUEoWaUNf9Levm+9f3l25JPyfdeneo0pIbmjroAvv76a9atW0d0dDRHjhypsC07O5vc3Nwql5WYmIiTU8W+GFtbW5KSkm74nsOHD9OrVy/j8+HDh5Ofn8/+/fuZPn06o0aN4vDhwyiVlddz3n//fd58880qxygIDYFapycqrYDcIi2WZiZYmcn/jU/GZbPiyFXOJ1WsyAa6WvPt5C60cLetrDgA1pxIYMuZZFRKBW/f30b0/QuNX1kFwKADa1fwLT1XqPPLxwR4dqyX0BqKO6oAPPfcc9jZ2bFmzRpjDoAyZmZm9O/fv8plKRQK49V/GY1Gg6mp6Q3fs27dOsaNG3ddOaGhoezevZuWLVty5MgRevfuXen7FyxYwOzZs43P8/LyjGMLBKGhKVDrWLTzMqvC4sgr0d1wP1OlwnjlP6yNB59M6ICN+Y3/q284lcjLf8mDop4fFEz7Zg41Grcg1IuyRYBATv6jLG3xSj4DSGDXDGxcK31rU3HHgwAfffRRQkND8ff3r/B6XFwc5uZVX1/Zy8vruhaDgoICvLxu3BR59OhRPvroo0q3ubq6MmHCBOLj42/4fnNz89uKURDqy8XkPKb+fJzEnGIA7C1NcbM1p1irp1ijR6PT42ZnQW6xlowCORPn3HtbMGNA5fP4JUli3+UMluyN5lB0JgBjOnrxnFjCV7gbSFL5SH+o2PyfdFK+9+pYpyE1RDUyC8DV1ZV169ZRUFBA2ZjCoqIifv75Zw4fPlylMvr3789TTz2FRqPBzMzM2PTfvXv3Svc/d+4crVu3vmHzPoBKpaJjx46392UEoYE5FJ3B07+cIF+tw8fJktdHtmFASzdMlArUOj2bTifzw4EYLibLTf/O1mZ8+EB7Brd2v64sSZLYei6Fr3ZFcaF0f5VSwdP9Apg9JEQ0/Qt3h+xYKMmRH1s6gV/f8m3G/v+OdRtTA1QjFYCxY8eSnJxMcXGxsQk9Pj6eESNGVLkMLy8vhg0bxt69exkyZAjbt29n+vTpWFhY8MknnzBq1KgKI/vXr1/P2LFjK5SxYcMGWrRoQatWrYiIiMDOzq5aswEEoaHYfCaJ2X+cRqM30L25E8se7Yq9pSkGg8RvR6/y5Y7LpOXL+TIsTU14sGszZg1ugZP19bNvMgrUzF97hh0X5cGxVmYmTOzuyxN9mxvXABCEu0LiifLHrUaCyTWnuoTSBHVNfAAg1FAFoH379mzfvp29e/diZWVFt27diIiIYP369bdVznfffcf8+fM5evQoWVlZfPDBBwCsXLkSf3//Cifz3bt389JLFadvhIWFMWXKFEJDQxkwYABvv/32HX83QagPUWn5vLbhvLF5flgbd754uBMWpibkFmuZ8Vs4B6IyAPCws+D/evvzcLdmOFpX3qW161IqL/15howCDWYmSp4KDeDJvs1xrKSiIAiNXsLx8sfXNv/nJcmtAwolNKu8dbkpqZE8ADNmzOCVV17By8uL2bNn895775Genk737t1JTk6uiTjrhMgDIDQEeyLSeHL5cfTX/Nfs5u/I66Pa4GZrzqM/hnEpJR8rMxP+r5cf+SU6dl5KIzWvBDdbC/oEuTCwpRs9A5zILdaydN8VVh2Tx8KEuNvyxcMdaeUp/r6Fu9g3vSD9Aphawfw4MCkdTH72T1j7pJz+9+l99RtjA1AjLQADBw6kffv2bNiwgcmTJxMQEEBOTg6hoaE1UbwgNBlXMwuZ+nP5yb+Djz0RKfkci81m5FcHsDQ1oVirx9ZcRXMXa77de6XC+1PySlgbnsDa8ITryn6iT3NeGhZiXPRHEO5Kei1kRMiPAweVn/wBrh6S7/361H1cDVCNVAAeeOABHnjgAePzixcvEh0djYeHWEhEEKrqeGwWT/58HF3pFL73x7VlYnc/knKKmbf2DPsvZ1CslZOa5Kt1nEnMRamAwa3cmdTDlxAPW2LSC9l1KY09kelEpRVgaqKgZ4AzMwcG07150815LjQhCSfKk/90fKTittgD8r1vL4QaqgD8l729PZ07d+bNN9/k9ddfr42PEIS7Qn6JlnUnE/n7bDJHrmQZX399VGsmdvdDkiSOXMnkWKy8zdnaDB8nS2zMTeni58iEbj4VBvB52lvSO8iFV5HTAZsoFZia1EjCT0FoHE79Kt8rTSFoUPnr2bFyy4DCBJqL1mm4wwpAZmYm+/btw9nZ+brm/k2bNvHRRx+JCoAgVGJdeAIfb4sgKbfkum025iZYm5nw/f4r/H02mfC4HAD6h7jyzaTOWN8kqc+1RFO/0CRF7ZTvvTqB6ppBrpHb5XvfnmDpUOdhNUTVrgAcOHCAESNGUFBQgEKhYNCgQfz9998oFAoWLFjAokWLeOutt2oyVkFo9IrUOh5aeoSziTdOk12g1vPS2vIkJmYqJTMHBPFs/0BU4mpeEG5MXQj5penjO02uuO3iRvk++N66jakBq3YFYN68ecyYMYOJEyeSnZ3NwoULee+99/j7779JTU1lz5499OzZsyZjFYRGLS2vhBGL9hsz9XnaWzB7SDCj2nuRVaSl/8d70OgNDG3tTpFWj7WZio6+Dozr5I2bncUtShcEgcNflT5QQMdJ5a/nxJf3/7cdd93bmqpqVwC8vb15//33jc/Xr1+Pv78/Q4YMYevWrTg4OKBWq0WqXUEAcou13HfNyf/RXn68ObqNMU3v6Yh0NHoDzRwt+W5Kl0rT9wqCcAsnfpLv3VpXHP1/ehUggf894OBb6Vubomq3Jzo7O1d47uTkxNSpU1m7di0ODg4A/PXXX3cUnCDcDYo1eu7/+gDppSf/mQMCeev+thVO8lvOyvkyRrTzFCd/QaiOhOOQnyI/7jW9/HVtMYQtkR//t1ugiat2C8CaNWs4f/58hdeuXr3Knj17ANDr9URFRTFx4sQ7ClAQGjOd3sCjPx4lNrMIgAe7NGPO0JYV9inR6tl1SU7PO6KdZ53HKAh3hT3vyfcKE2hzTTP/gS+gMB3sfaHtA5W+tamqdgXAx8eHfv36oVJVXoROp2Pz5s3VDkwQGjtJkpi39gzHYrMB6OzrwIcPtL9uvz0RaRRp9Hg7WNKhmX1dhykIjV9OPETtkh/79gIzK3lFwPN/wb6P5deHvFmxW0CofgXgiy++oF+/fjfdZ9CgQTfdLgh3K0mS+PzfSNaGJwLgYmPGT491r3S1vS1n5WbLEe08RPO/IFTHwUVAaersvET4tg8UZUJ+aSr6DpOgzdgbvr2pqnYF4FYnf5CX+BWEpkaSJD745xJL9slpek2UCn5+ojv2VtdffZRo9ey8mAqI5n9BqJYr++DYsvLn2THlj03MoeczMHAhiMr1dWolE6AgNFV6g8Sr68+xMizO+Nq8YSG08aq8aX9vZDpFGj1e9hZ09HGooygF4S6RHgG/P4jx6t+zE/SfByZmYG4Hri3AQnSr3YioAAhCDdHqDcxefZpNp5NQIP8kdfRx4Mm+ATd8z6bTctKS4WL0vyDcHoMe/noKdNdk07z3bWh+T/3F1MiItGKCUAMkSWL+2rNsOp2ESqkoux7htVGtMamk3x+gUK1jR2nz//0dveooUkG4S5z8FZJPlT93Dgb/vvUWTmNUIxWAl19+mY8//pjMzEwOHTqEv78/fn5+7Ny5syaKF4QG75fDV1kbnoCJUkFnP0cA7mvnSWdfxxu+598LqZRoDfg7W9HOWzRTCkKVGQxwaFHF13o8Lfr5b1ONVAD279/PjBkzsLW1ZdKkSQwcOJDz588bcwIIwt0sMaeYD/65BMD0/oGcuCpP+5s+IPCm7/v9qDxOYHRHb9H8Lwi3I3onZEaVPze1gg4i58ztqpEKwLhx47CysuKrr75CrVazaNEibGxs0Ol0NVG8IDRo7265QLFWTzd/R9RaPXqDRK8A5xsO/AM4l5hLWGwWKqWCSd1FalJBuC1nVld83nMGmNvUTyyNWI1UAAwGAzNmzOD111/n22+/xcrKirVr17J48eKaKF4QGqxLKXn8fTYFhQJeHtGKlcfiAZh6T/Obvu/jbREA3NfeEw97sdCPIFSZtgQi/il/rjKH3s/VXzyNWI3MApgzZw4XLlzgpZdews/Pj6SkJFxcXNi4cWNNFC8IDdY3u6MBGNHWk9PxOeSX6AhwsWZAiNsN37P2RAJ7I9MxNVHw4uAWdRWqINwdruwGTX75837zwdKh3sJpzGqkAqDRaAgKCsLMzAy9Xs/27duRJIkpU6bURPGC0CCl5Zew5Yw8je/Z/oHM+D0cgMf7Nq8045/BIPFbWBxvbpTX0Jg5MBh/F+u6C1gQGpucODjyLaSek5+bWkHqNWvQWLlA3xfrJ7a7QI10ATg6OvLJJ5+QlZXFjBkzmDdvHufPn+fll1+uieIFoUHaeCoJgyTn+E/KKeZqZhH2lqY80Nm7wn4Gg8Q/Z5MZsWg/C9efQ2eQuL+jF88NCKqnyAWhEYg7Aot7wZHFELNPvkVuhdz48n2GvClG/t+BGmkBeP7553n55Zc5c+YMy5YtY+fOnfTv35/PPvusJooXhAZp3Uk5z//Yzs348aCcfnRid1+szMr/W6XmlTB79SkORmUCYGuu4oXBwTzRp/JWAkEQgIJ0WDkRNAXQrBt0fVJeyCc/FbaXXlia2VRc9U+4bTVSAbCxsSEjI4MZM2Ywfvx4+vfvj16vZ/PmzcyePbvK5RQWFvLSSy/h6OhIQUEBH374Iebm5pXu5+PjQ3a2PN3qr7/+YuxYeaGHjRs3snPnTtRqNePHj2fw4ME18RUFoYLI1HzOJ+VhaqIgyNWaI1eyMFEq+L/efsZ94rOKmPT9EeKzirEwVfLUPQE80bc5DlZm9Ri5IDQC/y6E4ixwbwuPbpRX9wM4+2f5Pm3Hlb8uVEuNVABGjx7N9OnTCQkJ4dNPP+Xq1at88cUXSJJ06zdf49lnn2Xs2LGMHTuWX375hQULFlTaivDjjz+yZMkSHB3lJCsDBgwA4NKlS7zzzjscPXoUSZLo2rUrmzZtwtvb+7oyBOFO/FW6yl//EDdWlY78H9HOE097SwCKNDoe+ymM+Kxi/J2t+PGxbgS4imlKgnBLWTFw5g/58agvK57kYw+WP+4wqW7jugsppNs9S99EUVERVlZWaDQazMxu7yonKSmJwMBAsrOzsbCwID09HT8/P1JTU7G1tTXup9frGTFiBIsWLSIkJKRCGc888wxubm689dZbAMyYMQNHR0feeeedKsWQl5eHvb09ubm52NnZ3Vb8QtNhMEj0+XAXybklLBzZine2XESSYPPMvrQtzeg3f+0ZVh2Lx8POgg3P9cHdTkz1E4Qq2TJXXt0vcBBM+avitkWdISsarF1h7mXR/3+HamQQ4IkTJwgJCeHBBx8EICIignnz5pGamlrlMvbs2YOLiwsWFvIPpaurK2ZmZoSFhVXYb/v27Rw8eJCWLVsydOhQ0tLSjNt27dqFn195E2xwcDB79+69k68mCNc5ciWT5NwS7CxUhMVkIUkwrI2H8eT/99lkVh2LR6GAzx7qIE7+glBVmiI49bv8uM/zFbcZ9OVL/bYZJ07+NaBGKgDPPfcczz77LJ06dQKgXbt2DBw48LamASYmJuLk5FThNVtbW5KSkiq8Nnz4cPLz89m7dy+JiYmMGjUKg8FQaRmVvf9aarWavLy8CjdBuJW/Sgf/dfV3Ytv5VBQKmDUkGJDTAs9fewaAZ/sF0jvQpd7iFIRG5/I20BaCgy8071dxW9ROkOTfepH4p2bUSAWgb9++zJo1C1dXV+NrqampHDt2rMplKBQK49V/GY1Gg6mpaaX7hoaGsnv3bqKiojhy5EilZdzo/WXef/997O3tjTcfH58qxys0TcUaPf+cTQbkLIAAj/TwpaWHHXqDxKxVJ8kr0dHRx4EXh4gkP4JwW86vk+/bjL3+Cv/od/K9haNcQRDuWI1UAGxtbYmPjzcuaPL3338zd+5chgwZUuUyvLy8yM3NrfBaQUEBXl43XibV1dWVCRMmEB8fX2kZ+fn5N33/ggULyM3NNd7KyhGEG/n3YiqFGj025iqSckpwsTHjf0NbAvD1riiOxWZjY65i0cOdMDURq20LQpWpCyByu/z4v9P7CtIhprQ717dX3cZ1F6uRX6jZs2fz7rvv8t5772FlZcXYsWMZMmQIS5YsqXIZ/fv3JyEhAY1GA2Bsuu/evftN36dSqejYsSMAgwYNIjIy0rgtKirKOEOgMubm5tjZ2VW4CcLNrAtPAKBALS909f649thbmnI8Nosvd8p/e++MaYuvs5ieJAi3JXIr6IrBsTl4dqi4bddbYChdXK7VyLqP7S5VIxUAGxsbvvvuO5KTk4mNjaWoqIjffvvNOE2vKry8vBg2bJhx0N727duZPn06FhYWfPLJJ0REyIunbNiwgYsXLwLyYEM7OzvjbIBnnnmGHTt2AKDT6QgLC2PatGk18RUFgfR8NXsj043Pn+4XwJDW7uSVaHlh1SkMEozt5M2YTmLaqSDcFp0Gts6XH4cMq9j8f349hP9S/tyrY11GdlerkTwA0dHRfPTRR3z88ce4ublx6NAhoqOjb3stgO+++4758+dz9OhRsrKy+OCDDwBYuXIl/v7+hISEEBYWxpQpUwgNDWXAgAG8/fbbxvd36NCBxx9/nLlz56LRaPj888/x8PCoia8oCPwVnoChdNJsd38n/nevXPF8Z/MFEnOK8XGy5K3729RjhILQSF3cCIWlleuwpZAeCZ7tITcRzq4p309lAS4hlZch3LYayQMQGhqKm5sbP/30k3HO/vLly7l48SIffvjhHQdZV0QeAOFmOr21newiLdZmJuye2x83Owt2XUrlieXHUSjgj6d60b25060LEgShoqNL4J+X5KV9derrtzfvJ48B8O4K03bWfXx3qRrpAujfvz9//vlnhYQ9QUFBfP/99zVRvCDUu9XH4sku0gLw6YMdcLOzoECtY8FfZwF4sk9zcfIXhOqKKj2p93kRnjsOQ9+HbtPgnjnw5L/lYwL+OzZAuCM10gWg1WpJT083TgNMSEhg3rx5BAYG1kTxglCvtHoD7/0tjztp5mjJsHaeAHyzO4rUPDV+zlbMHSqaJQWhWoqzIXqX/LjNWHAJlm/X2lXa1Sv6/2tUjVQAnnvuOcaOHYtGo0GtVnPhwgV8fX3ZsGFDTRQvCPVq3clEcorlq/8XBsk/TPFZRfywX85K9up9rbEwNam3+AShUbu4GQxacGsNbi2v3y5JkHxafixaAGpUjVQAvL292b9/P2FhYVy9ehUvLy969uyJSlUjxQtCvdEbJD7/V57eZ6ZSMqqDnFfiu73RaPQG+gQ5M7iVW32GKAiN27m18v2NlvbNjoWSXDAxA9dWdRZWU1AjYwDUajWrVq2ia9euTJgwAaVSaZy2J9QNnd5AdHoBiTnFt70Ko3Bj+yLTSc4tAWBkO08sTE1Iyy9hzQk5H8DMgcHGBFiCINymgrTyBD9tb1ABKLv6d2sNKrGUdk2qkUv0KVOmsHfvXgYMGICHhwe9e/fmlVdeoX379jz00EM18RHCDWj1Bn48EMO3e6PJKR2kFuBqzTOhgTzQpRkmyqZ3corLLMLERIG3g+Udl/VXaeIfgAe7yqmiVx6NR6Mz0MnXgR5i4J8gVN/59XJ+f6/O4HyDMWPJp+R70fxf42qkAuDg4EBycjJKZXmDwpgxY3jggQdEBaCWZBao2RORxnd7r3A5rQAAS1MTtHoDV9ILeWntGX4Pi+P9ce1o5dl0pjR+uPUS3+6JRqGAV0a0Yuo9AdUuq1ijZ9v5FABcbcyMJ/stZ+UslY/08BNX/4JwJ8qa/9uNv/E+Safke69OtR5OU1MjFQB3d/cKJ3+AZcuWYWIiBkbVJJ3ewPHYbN7ecoHzSeUrF5qplMzoH8iMAUGU6Az8duQqX+2K4lR8DqO+OsDzg4KZ3j8Q1V2em353RBrf7okG5HFD7/59kZ4BzsZlem/XjoupaPRyd8qDXX1QKhVEpeUTmVqAqYmCIa3cayx2QbiRgoICvvjiC8LCwjAYDPzxxx9YW1vXd1h3Lice4o8Aihv3/0sSJJ2UH9dhBSApKYl33nkHvV5/XUr79PR0PvzwQyIiIti0aVOdxVQbaqQCMGzYMEJDQ+nZsydqtZrt27cTFRXFb7/9VhPFN3lJOcV8tesyf59NIbd0NPq1NDoDn++4zIm4HJ66J4CnQgO4v6M3r288x7bzqXz2byR7ItL4/KGO+DlX74ejSKPDIIGN+fV/MlFp+fwVnoithSmP9PTFzuLGKzDWFkmSWLTzMgBP9GlOan4JW84ks3TfFRZNrN4Px58nypv/y9L7/n1WbhHoE+SCvVXdf0+hbr3xxhusXbuW9u3bExMTw+nTpxk7dizZ2dns2rWLixcv4u/vX6sxzJs3jylTpvC///2P0NBQoqOjad++fa1+Zp04s0q+9+8Ldp6V75NzFUpy5AGAbq3rLDRTU1NycnIwM7t+zIGtrS0ODg7k5+fXWTy1pUYqAH369GHVqlWsWLGCq1ev8sgjjzBhwgRatBDLod6p/ZfTefbXcOPiMwAK4NFefjzW25/sYi0/7I/hn3PJ7ItMZ19kOgEu1vQPceOeYBdszFVsOp1MeFwOAz7Zg5O1Gd6OVvQNcmZc52YEutrc9PMPRmXw6fYIwuNyAGjnbc/MgUHc20ZOsbzjQirTfw9Ho5PX6V5/MpG/pvfGupKKQm06n5THybgczFRKnukfQGqumi1nktl6LoWcIg0OVrc3eCinSMOBy3Jq0uYu1rRwl5Nc/V26FPCIdjf4wRLuKt7e3hw7dgwLCwuWL1/Oq6++yq+//grIKcrrwvr165kzZw7m5uYcPXq02uWkpaWxe/fuhtEtazDAidL8/p0m33i/sqt/9zZ1OgDQ1dWVoKAg4uLirttmYWGBt/fdsd5Hjf1Ke3l5MW/ePONzvV7Pzp07GTRoUE19RJNz4moWTyw/hlYv0cnXgdwiLVcyCnmqXwALhsvTYZoDnR9xJD6riO/3X+GPY/FcySjkSkbMdeUZJMgo0JBRoOF0fA7f7I6mtacdfYKccbA042pWEecSc0nILsJEqcDC1MQ4Ar7M2cRcnlpxgnGdvXm8jz8zV55EozPQzd+R2MwiIlLz+ezfSBaOrLvaOsjN9QADQlxxs7XAzdaCEHdbIlLz2RORXmGBnrwSLR9tvcS5xDzua+fJk32bo/zPYMl/zqVQ2vrP+C7NALiSXsCllHxUSgX3thbN/03B2LFjsbCwqHTbmDFjMBgMtR5DSkrKdV2st0uj0fB///d/DePkD3BlF+TGgYU9tL7/xvvVQ/N/mZsd87tl7E+NdAoPHDjwulunTp149913a6L4JimzQM0zv4aj1UsMae3OG6PacCWjEFMTBU+HVhwtK0kSx2Kz2BOZTonOgJ2Fik6+Dgxs6cqwNh480sOXuUNbMKyNO2V/thamShTAheQ8lu2P4ePtEaw+Hs+F5DzySnRkF2mNJ38HS1NWPNmd468O5pl+gSgV8Fd4Ig8sPkyxVk+fIGdWTuvJx+PlZsnfjl4ls6CSfN61aOfFNAAGXdMvP6h0fv7OS2nG1yRJ4pkVJ/j1SByn4nN49++LfLUr6rry/jxe3vw/qr089/+fc3Lzf+8gl9tuURAqIUmgKaz7221Mk3VxcbnhNktLSzZv3ky3bt344YcfCAgI4L333iMxMZHHHnuMd999l759+/Lvv/8C8MMPPxASEsLu3bsJDQ3F1dWVQ4cOAZCfn89rr73GBx98gJ+fH1u3biUhIYG5c+diMBh47733WLp0KQD//PMPb731FsOGDeP55583jgv4bxzX2rRpE+fPn2fNmjV88cUXAJw7d46ZM2eyYMECBgwYwPHjx6/7jklJScyZM4eRI0fyyy+/4OPjQ79+/dBqtca433zzTebOnUvPnj05fvw4ERERtGzZkh49epCXl8eXX36JQqFg4cKFSJLEyZMnCeo7lksZemj/MJjKs3Uq+w5S4km+Oqrhzc2x9OrVi+XLl1NQUMCoUaOwt7cnMjKSPXv24OTkxNixY0lPTyclJYUuXbqwceNG8vPzmTp1Ku+88w6DBg0ytt7c6Hj9+uuvPP/888yaNYvNmzdX+e/kZsfywoULLFiwgLlz5zJ48GDS09NvUlLdqpEWAEdHR0aNGlWhVrRt2zYGDhxYE8U3Se/9fYn0fDXBbjZ88VBHvtghJ6MZ1NIdJ+vyk09OkYZX1p9jy5lk42t5JTpOxuXQzd+RJVM6Vtj/cHQms/44SWre9SdoS1MlBgnUuvKrGpVSQU6xlmm/HOeriZ2ZP7wlg1q58fhPYRSo9QB085dHx/dr4UpbbzvOJeax8XQSj/dpXrMH5QZS80o4m5iLQgEDQsqT8gxq5cbiPdEcuJyOJEkoFArWHE/gUHQmFqZKHurqw8+Hr/LVrsuM6eRlHB+RklvCibhsAFp72uHrbAVc0/zfVqwwWSO0RfCeV91/7stJYFYzg+iGDx/O008/zfnz51m1ahUajYbPPvuMwMBAXnnlFczNzVm0aBFDhgxhzJgxTJ06lePHj7Nz505mz57NokWL6N27N7/88gtt27ZlwoQJ9O3bl4KCApo1a8Ynn3zCp59+yssvv4y/vz8xMTFs2rSJxYsXU1xcTPPmzenRowejRo26Lo5rPfDAA3z11Vc8+OCDPPbYYxQXFzNhwgQOHz6Mvb09a9as4b777iM6Ohobm/JuQXd3d3x8fFi3bh0BAQFERkbi7+/Pzp07GTZsGHPnzuXll1/Gz8+Pzz//nIkTJ3L58mUWLlzIF198gZ2dHS+88AIrVqwgJCQEhUKBk5WKOd2gpYsJdPm/Gx/L4iJ+++ZjHC1h5htvMzpZS48ePejfvz+LFy8mKCgINzc3WrRowRNPPEFOTo4xHf2QIUMYPXo0X331FZIk8eqrr9KyZUvefPNNJk+eXOm/W3h4OEuXLmXfvn0AjBgxokp/Azc7lgqFgv/7v/9j//79WFhY0LlzZ5YuXcorr7xyp396NaJGKgBffPEFPj4+FV4bPHgwr776KlOnTq2Jj2hSTlzNZm14AgoFfDS+PdbmKuMV7v0d5R9MSZLYE5nOgrVnSckrQaVU8PygYCZ292VvZDpvbjzPsdhsxnxzkG8mdaZdM3kkfK9AZ3bN6c+WM8mcuJpNWn4JhWo9MRmFpF9z1d7Wy47zSXnoDBKOVqZkF2mZ8Vs4PzzWFaVCYTz5A3yx4zLrTyby3MBgxnT0rvMKwK7SK/wOzRxwtTU3vt7O2wFzlZLsIi3R6YXYW5rybmlO/zlDQpgWGkBMZhH7ItP5elcUHz8ozzPefCbJWMa4znLXwdXMQs4n5WGiVBjHPwiCnZ0d9vb2jBo1iu7duwPg4eGBtbU1CQkJnD17loICeZquk5NcUX7wwQcxNTWlQ4cO/P7778Zy5s6di5mZGffffz8ZGRmVft7KlSvJzMw0XsX369eP/Pz8SuO4mb///hsrKyvs7eXfhXHjxvHUU0+xfv16Jk8u75M3MTHB3t4eX19f+vbtC0BwcDBpaWkYDAbWr19Pq1Zyd2RGRgaBgYEUFBQwZswYnn76aWJiYmjevDnm5uasWLGCyZMn89ffO3h00SHIPC737d/oWCaG89aJfLr5WvHFyn/RGwwMHDiQpKQkevfuTc+ePVm/fj2PPfYY5ubm/Pnnn3z99decPn2aPn36GI/1sGHDyMzMJCwszPhvUdnxeuSRRxg+fLgxnu7duxMbG3tHx1KlUuHn52fsRtq2bVuDmsFRIxWA/578JUkiOjqadevW8dNPP9XERzQpX5aOZn+wSzM6+ToSkZLHlYxCFMDyQ7Es2XeFzEI18VnFAAS4WPP5Qx3p4OMAyH3WHZrZ88TPx4jLKmLctwd5oHMzuvk7oZckrqQXEh6Xzcm4bLT68uZQG3MVg1u58VRoIK297Nh5MZXnfj9JdpEWe0sVucU6nvn1BKrSvrGJ3X1o7WXP5/9GEptZxNw1p/G0l//QT8blkJZXgptd5f2nNcnY/N+yYkpeM5WSDj4OhMVkceJqFgeiMskt1tLGy47H+/gDcm7/fZHpbDydxCv3tcLByox1JxONZdzbWj7Zl43+7xXgXKFFRbgDplby1Xh9fG4NUigUFVo/PT09eeeddwgJCaF3795cvXrVuN+1VCqVcQzB5MmTiY6O5uGHH6Zr166sWbOm0s+Kj4+nQ4cOzJo1C8B4X1kcN3P58mVjMz7IJ3o/Pz8SExOv2/dGcaenp5Obm8sLL7xQ6eeOHDmS1atX07t3b5555hmmTp1KUlIS2dnZODdvB83bVfpZxrKuHiI+T+KNft3p/eKLAMyZM8e478SJE/njjz948MEHsbOzw8fHhw0bNnD58mXjeDQXFxe+//57HBwcuOeee1i9evUNj9eZM2fo2bNnVQ5fBbc6lmp1+YVVWQtFQ1EjYwCUSiUmJibGm0qlYvDgwcyePbsmim9STsfnsC8yHROlgucGBBOTUcikZfLIXwk4GpPFqfgc4rOKMVMpmdq3OVuev8d48i8T7G7Lpuf6MqyNB1q9xKpj8cxZc5qX/jzDd3ujCYvJQquX8LS34KGuPvz0WDdOLBzMFw93orWXnDhoUCt3fp/WA0crU3KLdSiAQrXeeBJdOLI1U3r6sf+lAcwf3hIXG7MKgwbf3nyBIo2O6lp+MIa+H+5i8vdHScguqnSfEq2eA1Hpxnj/q6ufIwAbTyWx6XQSSgV8MK69MSdCZ18HWnnaodYZ+PNEAlfSC4w5FgJcrI3N//+ck5v/h7cTV/81RqGQm+Lr+lbLA7ieffZZgoODjVemVXH16lXeeOMNLly4gFqtrjCg+loeHh6sW7euwmthYWG3HaOvry8xMTEVugokSaJly0oW47kBZ2dnDAYDW7ZsMb525swZSkrk34CyE/T27duZPHkyAwcO5LXXXqNNmzY3KrKiqwfxsFHwV0R5l2RJSQlnzpwBYPz48ezdu5dFixYxceJEJk+ezM8//4wkSZiaylN033rrLTQaDc8991yF5eorY2dnx8WLF6v8/cvc7Fh6eXlx4MABCgsLjdsOHjx4259RW2qkArBw4UKuXLlivMXGxpKTk8Nrr71WE8U3KcsPxQJyU7+9pSmP/niUzEL5D6tvkAtfPNSRZY925fepPTi6YBCvjmyNpVnlCZccrMz4dnJnVj3Vk8k9fekd6Mw9wS5M7unLe2PbsWdufw7NH8iH49szoKUb5qrry+nk68ifz/ampYct1w6d6h3ojJWZ3IBkba7imX6BHJg3kDdHtzHmCth0Jpn7Fh0gKu3258tuPJ3EG5sukJBdzIGoDJ5Yfsw41fBah6IzKNEa8LK3oJWn/B/cYJDIL9EiSRKdfeUKwJGYLACm3hNg7A4B+Spgck9fAFaGxbHh1DVX/6VN/fFZRZxJyEWpgKGi+b/J0ul06HSVV2j1+vIusZMnT5KRkUFRUREHDx6kuLiYmJgY49X+tWt1lD3+448/SEhIICAggNdee834etnnlV1hTpgwgZMnTzJp0iR27drF22+/XeGzr338X2ZmZmRlZXHp0iXGjBmDtbW1saUhJycHvV7PsGHDrnufwWC4bn0RSZJQqVSMHz+exx9/nJ9//pmtW7eyYsUKY3P38OHDiYmJwd3dXf5/Nnkyq1evZvTo0TeM0fgdtCVwZS8T25ryxZp9vPXWW+zZs4fZs2cb8y64uLjQv39/Tpw4ga+vL4888gjbtm1jwIAB1/1baLVa9uzZY/y3qOx4PfDAA6xYsYJz584BEBMTQ3p6eqX/5pIkGY/JzY7lfffdh8FgYNKkSRw+fJhPP/3UWBnYuHFj/ScSkmpAQUFBTRRT73JzcyVAys3NrZfPzynSSC1e+Vvym7dZOhmXLc1fe0bym7dZCliwRfKbt1k6FJVRL3FJkiQZDAYpMiVP+ungFclv3mYpcMEW6VxiTqX77r2UKvnN2yw1n79Z8pu3Werx7g4pNbe4yp9VrNFJ3d/9V/Kbt1mateqk1OXt7ZLfvM3Ssn3R1+378l/yMXpl3RlJpzdIn22PkNq+vlXym7dZar3wH2ngJ7slv3lyHIM/3SMVa3TXlZFXrJFaLfynNNZ/jfsfi8mUJEmSvt0TJfnN2yw9vORwlb+DcHc5fvy4NHjwYEmhUEhLly41/kb8+eefkpmZmfTwww9LycnJkiRJ0tKlSyU7Oztp9OjR0tq1ayU3Nzdp06ZN0rJlyyRAevvtt6XY2Fhp4sSJkouLi3TkyBHp9ddflwICAqR3331XmjVrlhQbGysVFBRI7777rgRIc+bMkSIjIyVJkqQ//vhD8vf3l9zd3aXFixffMI7/+v777yUXFxdp2bJlkiRJ0rFjx6Q+ffpIc+bMkWbMmCFduHDhuvekpaVJY8eOlVxdXaVDhw5JR44ckTw8PKTx48dLKSkpUmZmpvTAAw9IdnZ20qBBg6SkpKQK7585c6aUnZ0tSZIkFRYWStOnT7/hMa7wHQ6ukqTX7ST9RyHSgvnzJRcXF6lly5bSgQMHKrznl19+kbZv3258/vjjj0sGg8H4fPPmzZKjo6MUGhoqbd26VXJ1dZWWLl1a6fHSaDTSjBkzJFdXV2nChAnSo48+Ko0ePVo6duxYhc9MT0+Xxo0bJzk7O0v79++/5bHctWuXFBISIrm4uEiffvqp8fXnn39eeuGFF254POqCQpKqt3TcL7/ISRwUCgW9evUiKCiIc+fOMWXKFC5fvszw4cNZtmwZDg4ONVZZqW15eXnY29uTm5uLnV3d589fcTiWhRvO09LDli8e6siwL/cbtykUcPaNoZVm4qtrz/56gn/OpdDa044Nz/XB9D8phku0etq+vg2dQcLPyYqrWUXc186Tbx7pXKXyfzkcy2sbzuPtYMmuuf1YF57I/L/O4mZrzv55A4wtFQaDRK8PdpKap+anx7qy5WxKhex9//Xj/3Vj4A2W7p2/9gyrjsUbn1ubm3D6tXtRmSgZ8eV+LiTn8d7Ydkzq4Vul7yAIwh3YOBPCf4GuT8DIz+s7mrtWtbsAHnvsMfbv38/gwYMJCgoiPT2dgQMHkpGRwdKlS+nevXuFASrCrf1VOvhsQlcflu67AkCX0j7sYDebBnHyB3jr/rY4WplyITnPmHv/WhamJsZxBA9190GpgC1nkzmTkHPLsiVJ4vejcvatqfc0x1xlwrjOzXC3MyctX836awbonUnMJTVPjbWZCen5av48kYCJUsEnD3bg3JtD2TmnHz8+1pV2pWsBpOaXVPqZABO7Vzyxd/FzQmWiJCqtgAvJeaiUCoaL6X+CUPvUBXDuL/lx2wfqN5a7XLUrAB06dGDZsmV4esopUefPn09ubi7//PMPkyZN4n//+59YDOg2ZBaoORWfA0CP5k5sPC2Pjg50laeMdGjmUE+RXc/V1pw3RssDeb7eFUV0esF1+5T1vaflqbm/ozyV7qeDsbcs+1R8DpdS8jFXKRnXSc7AZ6ZS8mRfeUrhd3uvoDfIjVZlK/X1DXbh/X8uATDtngAORmUw/ttDLN4dTTNHK3oHOQNwPin3hp/bytO2wtLJ3f3l+FeFyZWR0BauOIrR/4JQ+06uAE0BOAWCX5/6juauVu0KQLdu3YyPjx49yvLly3nhhRdo27at8fVrp0YIN7cnIh1JgjZedoTHZaMzSHT0cTCOqv/vKP/6NrqDF/1DXNHoDbyy7ux1g4Q6+ToAEB6XzWO9/QE5kU6h+uazAlaFyc3w97XzrLDYzqQefthbmhKTUcjfZ5PR6Q38FS4396uU8lx/f2crNp1OZN3JRC6l5LM2PIGhX+zjRKyc1OfaFRT/a//lDGPFAuQKTF6Jlj9KuwWm9PKrwlERBOGOFKTDvo/lx32er/UZG01dtSsAmZmZnDt3jitXrjB58mT8/f154403jNuTkpJuK5ViU1eWzGZgSze2ll7ZDmvrwenSVoGODawCoFAoePv+tliYKjlyJYu14RXnD5e1AFxIyiPYzQZ/ZyvUOgO7I9IqKw6Qxw6UZdub0K1ibgkbc5Vx7v7nOyJZeSye1Dw1jlam7I2Uy3SxMScxpwRfJyu+mtiJ4W09kCQ4flWuAJyJz+XvM8moddePlC6bfVHmdEIOH/5ziXy1jmA3G/oFN6z5u4Jw18mIgt8fhKJMcG0FHW+ySJBQI6pdAXj33XcZP348QUFBqFQqNm/ejJWVFVevXuWTTz6hV69e5ObeuMlVKKfVG9gXKc9l7+bvyJEr8pS1tl525JXoMFMpCfG4+RzW+uDjZMULg+QVH9/7+yL5JeUtPs0cLXGzNUdnkDiXlMewtnJX0dbSfPqV2RuZTr5ah6e9Bd1L0wtf6/HezXG1NedKeiEL18tTdVp72lGg1uPvbGU80X81sROjOnjx7eQubHquL6HBcj53vSQx/fdwQj/aXaEiciYhh/2XM7j2WuPDrRH8VjoW4bVRra9bLEgQhBp0cTN8011e/MfSCR5cDiYNY8zT3azaFYCWLVty6dIlMjMzuXjxojEdpI+PDzNnziQyMpKiosqTt9xIYWEhM2bM4NVXX2XWrFkVMiiVyc3NNWZ+6tSpE0eOHLmuDCcnJ2OWp/8mzWiIjsdmk6/W4WxtRmqeGr1BoqWHLRkF8vz/tl521420byim3tOcAFdrsgo1rDhy1fi6QqGo0A1QtjDPoehMDIbKJ55sLl3P4L52npWecO2tTPl6YidsLeQfhr5BLsYWEhcbOeHKkNbuFbpL2jWz55cnexBSupyvnYWK1Dw1j/90jJfXnSUxp5gFf50FMCb9ae9tL+eoMVHyxqjW3COu/gWhdjW/ByzsoMUwmLoD3KqekEiovjs+qzg6OlYsUKnE3NzceLsdzz77LIMHD+add96hc+fOLFiw4Lp9PvzwQ8aNG8fu3bvx8fHh/vvvr5Bl6ccff2TJkiX8+++//Pvvv7dMOtEQlF2N9gtx5d8L8rK297bxMA4KbGj9/9cyNVHy3IAgAL7fH0OJtrx5vawbIPxqNh2aOWBlZkJWoYZLKdcnBirS6NhR+t1HdrjxAjE9Apw5OH8g/74YShc/Bwo0Fa/+Zw0OrvR9nf0cAHm0f1lXwu9H4+jzwS7OJ+XhYGVqXCTuhcHBnHh1CMcXDuaxOlrPQBCaNAt7mBEGk/4A58Bb7y/UiAZzWZmUlMSaNWuMizEMHz6c7777jvz8iieLwYMHM3HiRLp06cKvv/5KdnY2Fy5cAOSsTps3b6Z9+/YMHjyYwYMHN4qZCDtL17LvG+TCvstyV8DQNu6cLp0215BmAFRmdAcvvB0sySrUGFPmAnQuncIYHpeDqYnCuGrgoejrFzrZdSmNYq0eHydLOlyTqa8ydhamuNtbGGcVlOXmH9rGnTZelb+3tac8LTEyNZ/XR7Xh92k9CCidYeHvbMUXD3UkLqsIhQK6+jnhZG2GnYVppWUJglALbCrP0SHUngZTAdizZw8uLi7GNJKurq6YmZldl+f62iWG7ezssLOzo1kzebrY9u3bOXjwIC1btmTo0KGkpd14wBnIizTk5eVVuNW1uMwiotMLjVPQSrQGmjlaEuRqYxy13tAGAP6XykTJhK7yoL0/rkmm087bHpVSQUaBmoTsYnoHytPxjlzJvK6MzaflisPI9l5VWtBk8e5o8kp0+DhaEh6XA2Acj1CZsrwEF5PlCmXvQBd2zu7H6dfuZffc/hRr5JaLEHfbCrMPBEEQ7lYNpgKQmJhoXC6zjK2tLUlJN14tLDIykv79+xtzEQwfPpz8/Hz27t1LYmIio0aNMubfrsz777+Pvb298fbfVQ3rwq5L8tV/N39HDlyWr4yHtvHgcloBGp0Be0tT/JxrdvWy2vBg12YoFHDkSpZx4R4LUxPalJ54w+Oy6REgVwDCYrIqTLkrVOuM3SCj2t96ffjo9AJ+OCAnSrItvUof2d7TeJKvTIiHvC0lr4TM0mWPFQoF9lamKBQKwmLlgZdd/R1vWIYg3EpMTAz+/v43HP+0atUqRo0addMyCgoKePvttytMta6r+K5VlViFxq3BVAAUCoXx6r+MRqMxrupUmW+++YaPP/74unJCQ0PZvXs3UVFR1w0SvNaCBQvIzc013uLj42+4b23ZFSE3+fdr4cqO0q6Aodf0/7dvZl/lJT7rk5eDpbGJv2wcA8iLCYG8PHBbLzuszUzIK9ERcc04gP2X01HrDFiZmfDYT0cZ8eV+PvjnEvsi0wmLyeL7/VeY+vMxur6zg97v72Tc4kNo9RLeDhZcSM7DXKVkzr0hN43PxlyFf2lFqqwV4FrHS3MFdKtk9oHQdIWFhTFo0CCUSiVLliy5ZSuhl5cXr7/+OlZWlVfae/fuzbPPPnvTMszMzPDz8yM9Pb3acVc3vmtVJVahcWswFQAvL6/rpg0WFBTg5VX5FeG2bdsYOHAgzZtXPkjL1dWVCRMm3PSkbm5ubuxGKLvVpUK1jiPRcnO4k7U5eSXyTIAufo7GtLkNvf//Wve2lpfj3X6+vAJQPg4gG5WJki6lJ9ijMeXdAJtKR/8XafSk5Wu4kJzHd3ujefTHMCYsOcw7Wy6y42IaGQVqknJLyC2Wpxsm5shJkl4f1YbmLta3jK+VZ1k3QMUf8QK1zpglsHtzUQEQynXv3p1Jkybh5ubG008/fcvfCHNzcx5//HHjc7VazdKlS43PfX19GTFixE3LMDMzu2Vr5FdffVWF6G8d381UJVahcWswFYD+/fuTkJBgXFO5rOm/e/fu1+17/vx54uLiuP/++29apkqlomPHjjUea005GJWBRm/Ax8mSs6Un/CGt3TFRKjgdL5+QGvIMgP+6t7WcKz8sNovs0iWMO5dOBbyQlEeJVk+P0hPs0dJcB3qDxPbSxEee9hasnNaTLx7qyLjO3vg7W+FhZ0GgqzWe9uWtQ6YmCoLcbOje3InFj3Su8gI9ZQMBL/ynAnA8NguDJOcu8LS3rOa3F+5WJiYmqFS3PyfdYDDw3HPP3bQb80Zu1uq3c+fOalcABOFaDaYC4OXlxbBhw9i7dy8gD+ibPn06FhYWfPLJJ0RERAAQHR3NsmXLGDJkCLGxsZw+fZpvv/0WgA0bNnDx4kUAIiIisLOzIyTk5k3D9ams33tACze2Xyhv/i9U67icJjdT32pEfEPi62xFiLsteoPEgSh5PIO3Q3lCoDMJucYKQFhsFpIkseZ4PFq9PB7gx//rSq9AZ8Z08uazCR1ZMKIV+SVaotMLjSmRezR3YtPMvuyY3Y/VT/diRDvPKsdXNkbgwn9SAofFZJWW7XxnB0C4LZIkUaTR1fmtmgugAvKFyZw5cxg5ciS//PILPj4+9OvXD61Wi1qt5sMPPzQOSt6zZw9Hjhxhx44dvP766yQlJTFz5kxGjhxpLO+1115j4cKFTJgwoUqLp2VmZvLzzz+TmprK/Pnz2bt3LzNnzmTUqFG8/PLL+Pj4kJ2dzeLFi5k7dy5PPvkkDz/8MHq9/rr4Tp06xbhx43jjjTeYM2cOTk5OvPTSS8bveW2s69evp2vXrqxdu5bRo0fj4ODAX3/9ZYxr06ZNfPzxx/zvf/9DoVDQt29ffv3112ofZ6FuNKhUS9999x3z58/n6NGjZGVl8cEHHwCwcuVK/P39sbOzM7YUfPnll8b3rVq1CpD766ZMmUJoaCgDBgzg7bffrpfvURWSJLH7ktzH5+diRVq+GhtzFb2DnAmLka9IvR0scbOzuEVJDUtoCxciUvPZfzmdUR3kEf1d/R35+2wKh6IzmN4/CAtTJVmFGqLSCvh6dxQAPk6WtLpmCl9YTBYzfgtHZ5Do0Myeh7v7Mqil2x0dj7IugOj0Akq0eixM5SmiR8sqAAGi+b8uFWv1tH5tW51/7oW3hmJlVr2fPnd3d3x8fFi3bh0BAQFERkbi7+/Pzp07GTp0KH379mX+/PmAPGOpS5cuxjTpWq0Wb29vzp6VE0+dPXuW3377jejoaDIyMnB1dWXhwoU4O9+4Iurs7MwTTzzBvn37+OCDD9BqtRw6dIi//vqLN998k4CAAJRKpTGRmiRJODo6curUKTp37lwhvnbt2mEwGNi/fz/Lly9n0qRJ9OjRg9dffx1XV9cKsd5333088cQT7N+/n1WrVvHtt9/y0UcfMW7cOLKysnj66adJSEhAqVSydetWQkNDmTxZpPJt6BpUBcDFxYXvv//+utdPnDhhfHyzPv13332Xd999t1Ziq2nnk/JIySvB0tSEpNxiAPqHuGKuMjFOk+sZ0PiuSO8JdmXZ/hgOXM5AkiQUCgX9Q9z4+2wKOy+mMWtwCzr7OnIoOpOVx+JIyJa/+xPXJNwp0uiYu+Y0OoPEfe08WTSxU4WV+qrL094CBytTcoq0RKbm076ZA8UavXG8RQ/R/y/cgomJCfb29vj6+tK3b18AgoODSUtLQ6FQ3HDMEoCpqSnu7u7G5yEhIfz+++9oNBp27doFyOOeblYBqKxMDw8PgoKC6Ny5M507dwbkbgJJkvj7778xMTGhoKDguvjKvkvHjh3x8fHB09MTvV5PZmYmvr6+FWI1NTXF1taWMWPGYGVlRYcOHfjmm28AuHz5MhqNBqVSblBu2bIlxcXFVf4OQv1pUBWApqRspHxoCxf+PS93BQxtI/ehl60F0BivSLs3d8JMpSQpt4To9EKC3GwYEOKGQgFnE3NJyS2he3MnDkVnsva4vJqfQgHjOjczlvHL4avEZRXh7WDJBw+0q5GTv/w5Cjr6OLAnQp5d0L6ZA4evZKDVS3jZW+Dr1PCnW95NLE1NuPDW0Hr53Dvx3/55lUplnG58qxk71243MzMjOjqaLVu2MHXqVIBqdU+UpT2/VklJCfPmzePxxx/Hzs7OWO5/97v2edk4hxt9l//uW7Zf27ZtsbS05PTp03To0IGYmJgqdWcI9U9UAOrJztL5/6087dh2PhVzlZKBLd0oVOuM+e17NcIWAAtTE7r7O3EgKoP9l9MJcrPB1dacTj4OhMflsO5kYmlf+2VyS+SlgTv7OmJvKU/3LNbo+X6/PMd/1uBg4zz/mtIn0IU9Eekcis5k6j0B7LhYugpjK7dGMd3ybqJQKKrdFH832LVrF0uWLDGOe6opERERzJgxg0uXLhmvymuTtbU1X375JatXr+bgwYN88MEH9OnTp9Y/V7hzDWYQYFOSnFvMucQ8FArIKZKntA0IccPaXMW+yHR0Bgk/ZyuaOTbOEen3lK6+V5bYCODh7vJI/RWHY69LbHTtQL7fw+LIKNDQzNGSMZ28azy23kFypepQdAbZhRrjlMVBrdxv9jahCdPpdBUSihkMhuuu1Mue//fezMyMrKwsoqOj0Wq1SJJk3Hby5Eny8vJQq9Xs2LEDgNTUVLKysirs919mZmbk5eWh1WqNg6P1+vI1OM6dO0dBQQH5+fmEhYUZ85wkJiZeF9+tvsu12/67b9njoqIiPvvsM8aPH0+/fv3w9/c3zuYSGjZRAagHZSedzr6OxuQ/I9rLJ8Gy2QD3tnZvtFekZavnHb6SiUYn/3CO7uCFh50FSbkl9P9kT4X9B7aUc4CXaPUs2RsNwPT+QbWyAmJrTzsCXa0p0Rp4esUJMgrUuNiY0yfQpcY/S2j8jh8/zurVq0lLS2Px4sVcvXqVzZs3c/HiRQ4fPszRo0eJiIjg77//JjU1lRUrVgDw008/ATBu3Dh+++03fv/9d3JyctiyZQsXL17k6NGjjB8/noKCAtq1a4daraZ9+/YsXboUc3Nz1qxZQ3JyMhs2bLgupg4dOuDr68vAgQOxtLRk3bp1nD59mk2bNgEwZMgQPD09adu2LefPn+eee+5h6dKl2NvbV4jvwoULHDlyhD179nDlyhV++eUXAH799VfS09MrxLp161aSk5NZu3YtV69eZcOGDaSkpLB161ZMTEwoLCxk4MCBdOjQgeDgYLy8vIwDCIWGSyHdyZyYu0xeXh729vbk5ubWalKgcYsPEh6Xw8TuPqwMi8fOQkXYK4MxSBI93t1JvlrH6qd7NdqkNAaDRPf3dpJRoOb3qT3oHSSfXA9GZfD48mNodAZMFKCX5Ax9596U+4FXHI5l4YbzeNpbsOd//TFX1c5CTt/vv8I7Wy4an88e0oLnB1W+iqAgCDcXHh7O8ePHeeqppwC5NeLcuXPs2rWLF198sZ6jE25GtADUsdiMQsLjclAqIC5Lzsf9QJdmWJiasPl0MvlqHX7OVnT1a7w56ZVKBQNC5FaAsj52gD5BLvz7YiifP9TBmBGwrJlRozPw7R756v/Z/oG1dvIHeLSXv3HEf1c/R54KDai1zxKEu92bb75JUlISJSVyrg69Xt9olmJv6kQFoI79eUIe+d6+mQMHozJRKmBKTz80OgOL98hz4id190VZQyPf60tZn/rOS6kV+g39nK25v4M30WkFABRq9ByMyuSXw7Ek5ZbgZmtuXFmwtpiplKyc1pOD8wey+ulexnwAgiDcvoULF3Lw4EG8vb0JCAjggQceYNCgQQQGBtZ3aMItNN0huLVIqzew61IabrbmuNlZ4GJjhrnKhGKNnt+OXgUgLV+uLT/QuRnNXaz5YOslYjOLcLEx55GefvUZfo24J9gFMxMlVzOLiE4vIMjN1rjtWGwWmYUaTE0UaPUSL64+RV5pfv/ZQ1rUyQlZqVTg7dA4B1kKQkPStWtX/v333/oOQ6gGUQGoBal5JTy94kSF1xysTFEpFWQXaVEqIClHTgLkbmfBkz8fZ9cluan8jdGtsTFv/P8s1uYqegU6szcynW3nUytUADaclnOjD2vjweErmaTny8vzDmzpVutX/4IgCIKs8Z9pGqDMAjW+TlbkFGkoUOswSOXT/QAMpS3ixVq9MRWuUgEvj2jFyPY3ziTW2NzXzpO9kemsOR7P9P6BKBQKNDoD/5yVV/97qJsvs+8N4edDsbjbWfB4H/9G3/UhCILQWIgKQC2wNlcZB/hVxsfRgt5BLpiaKClU6/FxtGR0R68KV8l3g/vae/LmpvPEZhZxKDqTPkEubDqdRHaRFjdbc3oGOKEyUfLG6Db1HaogCEKTIyoAtcDByox23nZYlzblX0rJJ6dIi6WpCT893pWeAU1jzrm1uYpxnZux4shVPtkeQRc/R74pbfH4v97+qGphnr8gCIJQNaICUAuK1HrOJlZcctbdzpxlj3alfTOH+gmqnswcGMTa8AROxuXQ98NdZBRocLExZ0qvxj/QURAEoTETFYBa4GxjhouNOc7WZnjYW3BPsAsTu/saWwSaEjc7C94f145Zf5wio0Ae+f/Jg+2xq+Ec/4IgCMLtEZkAr1FXmQCbonOJuZy4mk2fIOe7bqyDIAhCY9T0LkmFetHW25623vb1HYYgCIJQSozCEgRBEIQmSFQABEEQBKEJEhUAQRAEQWiCxBiAa5SNh8zLy7vFnoIgCIJQf2xtbVEo7ixzqqgAXCM/Px8AHx+Rj14QBEFouGpitpqYBngNg8FAUlJSjdSs8vLy8PHxIT4+XkwpRByPa4ljUZE4HhWJ41GROB7lrj0W3t7eogWgJimVSpo1a1ajZdrZ2TX5P9prieNRThyLisTxqEgcj4rE8ShnZ2d3xyd/EIMABUEQBKFJEhUAQRAEQWiCRAWglpibm/P6669jbm5e36E0COJ4lBPHoiJxPCoSx6MicTzK1fSxEIMABUEQBKEJEi0AgiAIgtAEiQqAIAiCIDRBogIgCIIgCE2QqAAIgiAIQhMkEgHdocLCQl566SUcHR0pKCjgww8/rHSE5saNG9m5cydqtZrx48czePDgeoi2dlXlWOTm5jJ16lS2bdtGYGAg3377LT179qyniGtXVf82yqxatYrvvvuOPXv21F2Qdeh2jkdRURFLlizB2dmZFi1a3JV/I1U9Hu+99x4GgwGlUklRURFvv/12jSSBaYj++ecfXn/9dVavXo2/v3+l+zSF31K49bGokd9SSbgjU6ZMkf766y9JkiTp559/ll588cXr9rl48aLUrVs3yWAwSHq9XurUqZOUkJBQ16HWuqociwULFki///67dPz4cWnUqFGSm5ubVFBQUNeh1omqHI8yiYmJUtu2baV+/frVUXR1r6rHIzMzUxoxYoR05cqVugyvzlXleGzatEmaOnWq8fnjjz8urVq1qs5irEupqanSxo0bJUCKiYmpdJ+m8ltalWNRE7+logJwBxITEyULCwupuLhYkiRJSktLkywtLaW8vLwK+z399NPSwoULjc+nT58uvfLKK3Uaa22r6rHYuXOn8XFubq5kamoqhYWF1WmsdaGqx6PMzJkzpW+++eaurQDczvEYMmSItHv37jqOsG5V9Xh89NFH0kMPPWR8Pn36dGnJkiV1Gmtd0uv1Nz3pNYXf0jK3OhY18VsqxgDcgT179uDi4oKFhQUArq6umJmZERYWVmG/Xbt24efnZ3weHBzM3r176zTW2lbVYzFw4EDj47Lc3jW9/kJDUNXjAbBs2TImT56MlZVVXYdZZ6p6PDZv3szly5cJCwtjxIgRLFiwAK1WWx8h16qqHo/Ro0ezceNG/vzzT7Kzs8nIyGDKlCn1EXKdUCpvfkpqCr+lZW51LGrit1SMAbgDiYmJODk5VXjN1taWpKSkm+5X2T6NXVWPxbUiIyPp378/np6etR1enavq8YiKiiIvL4/u3btz4cKFugyxTlX1ePz222/06NGDWbNm8eSTT9KpUyckSeKDDz6oy3BrXVWPR0hICL///juTJk2iX79+rF27FktLy7oMtUFpCr+l1VHd31LRAnAHFAqFsQZfRqPRYGpqetP9KtunsavqsbjWN998w8cff1zbodWLqhwPvV7P4sWLmTVrVh1HV/eq+vdx/vx5+vbti5mZGc7OzkybNo1ffvmlLkOtE7fz/6WkpISNGzcSHR3NxIkT0el0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",
      "text/plain": [
       "<Figure size 550x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "colors={'Res': 'C1', 'Epi': 'C0', 'LSTM': 'C2'}\n",
    "# Compute smoothed curve\n",
    "for expname in colors:\n",
    "    if expname=='LSTM':\n",
    "        continue\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}_\"\n",
    "        i=0\n",
    "        for stat in ['score','len','min']:\n",
    "        # tmpdf=df.copy()\n",
    "        # if col.startswith('Res'):\n",
    "        #     tmpdf['Step']+= 480000\n",
    "        #     color='C1'\n",
    "        # else:\n",
    "        #     color='C0'\n",
    "        \n",
    "            df.plot(x=col+'step', y=col+stat,legend=False,xlabel=\"\",ax=ax[i],color=colors[expname])\n",
    "            i+=1\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top', 'right']].set_visible(False)\n",
    "line1, = ax[0].plot([], [], color='C1', label=\"Transfer to new reward loc.\")\n",
    "line2, = ax[0].plot([], [], color='C0', label=\"Initial training\")\n",
    "\n",
    "ax[0].legend(handles=[line1, line2],frameon=False)#, title=\"Column groups\")\n",
    "ax[2].set_xlabel('Environment Steps')\n",
    "ax[0].set_ylabel('Success Rate')\n",
    "ax[1].set_ylabel('trajectory length (frames)')\n",
    "ax[2].set_ylabel('100 consecutive success')\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/Training_local_resume.svg',bbox_inches='tight',dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### NEMO runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "###"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import wandb\n",
    "\n",
    "api = wandb.Api()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33m<johndoe>lin\u001b[0m (\u001b[33m<your_wandb_ID>\u001b[0m). Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "wandb.login()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 296,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs = api.runs(\"<your_wandb_ID>/SF_dmlab_NEMO_tech_grid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 545,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs = api.runs(\"<your_wandb_ID>/SF_dmlab_NEMO_newmaps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'project': 'SF_dmlab_NEMO_control',\n",
       " 'entity': '<your_wandb_ID>',\n",
       " 'order': '+created_at',\n",
       " 'filters': '{}'}"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs.variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "summary_list, config_list, name_list = [], [], []\n",
    "for run in runs:\n",
    "    # .summary contains output keys/values for\n",
    "    # metrics such as accuracy.\n",
    "    #  We call ._json_dict to omit large files\n",
    "    summary_list.append(run.summary._json_dict)\n",
    "\n",
    "    # .config contains the hyperparameters.\n",
    "    #  We remove special values that start with _.\n",
    "    config_list.append({k: v for k, v in run.config.items() if not k.startswith(\"_\")})\n",
    "\n",
    "    # .name is the human-readable name of the run.\n",
    "    name_list.append(run.name)\n",
    "\n",
    "runs_df = pd.DataFrame(\n",
    "    {\"summary\": summary_list, \"config\": config_list, \"name\": name_list}\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'00_control_see_0_H.L_1_H.R_1_r.siz_29_e.fra_4_20250507_220722_987086'"
      ]
     },
     "execution_count": 178,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs_df['name'][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['0/global_step', '0/len/len', '0/len/len_max', '0/len/len_min', '0/perf/_fps', '0/perf/_sample_throughput', '0/policy_stats/avg_true_objective', '0/policy_stats/avg_true_objective_max', '0/policy_stats/avg_true_objective_min', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '0/reward/reward', '0/reward/reward_max', '0/reward/reward_min', '0/stats/avg_request_count', '0/stats/master_process_memory_mb', '0/stats/memory_learner', '0/stats/memory_policy_worker', '0/stats/step_policy', '0/stats/wait_policy', '0/train/act_max', '0/train/act_min', '0/train/actual_lr', '0/train/adam_max_second_moment', '0/train/adv_max', '0/train/adv_mean', '0/train/adv_min', '0/train/adv_std', '0/train/entropy', '0/train/exploration_loss', '0/train/fraction_clipped', '0/train/grad_norm', '0/train/kl_divergence', '0/train/kl_divergence_max', '0/train/kl_loss', '0/train/loss', '0/train/lr', '0/train/max_abs_logprob', '0/train/num_sgd_steps', '0/train/policy_loss', '0/train/ratio_max', '0/train/ratio_mean', '0/train/ratio_min', '0/train/returns_running_mean', '0/train/returns_running_std', '0/train/same_policy_fraction', '0/train/valids_fraction', '0/train/value', '0/train/value_delta', '0/train/value_delta_max', '0/train/value_loss', '0/train/version_diff_avg', '0/train/version_diff_max', '0/train/version_diff_min', '0/zz_pbt/cfg_exploration_loss_coeff', '0/zz_pbt/cfg_learning_rate', '0/zz_pbt/cfg_max_grad_norm', '0/zz_pbt/cfg_ppo_clip_ratio', '0/zz_pbt/cfg_ppo_clip_value', '0/zz_pbt/cfg_value_loss_coeff', '1/global_step', '1/len/len', '1/len/len_max', '1/len/len_min', '1/perf/_sample_throughput', '1/policy_stats/avg_true_objective', '1/policy_stats/avg_true_objective_max', '1/policy_stats/avg_true_objective_min', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '1/reward/reward', '1/reward/reward_max', '1/reward/reward_min', '1/train/act_max', '1/train/act_min', '1/train/actual_lr', '1/train/adam_max_second_moment', '1/train/adv_max', '1/train/adv_mean', '1/train/adv_min', '1/train/adv_std', '1/train/entropy', '1/train/exploration_loss', '1/train/fraction_clipped', '1/train/grad_norm', '1/train/kl_divergence', '1/train/kl_divergence_max', '1/train/kl_loss', '1/train/loss', '1/train/lr', '1/train/max_abs_logprob', '1/train/num_sgd_steps', '1/train/policy_loss', '1/train/ratio_max', '1/train/ratio_mean', '1/train/ratio_min', '1/train/returns_running_mean', '1/train/returns_running_std', '1/train/same_policy_fraction', '1/train/valids_fraction', '1/train/value', '1/train/value_delta', '1/train/value_delta_max', '1/train/value_loss', '1/train/version_diff_avg', '1/train/version_diff_max', '1/train/version_diff_min', '1/zz_pbt/cfg_exploration_loss_coeff', '1/zz_pbt/cfg_learning_rate', '1/zz_pbt/cfg_max_grad_norm', '1/zz_pbt/cfg_ppo_clip_ratio', '1/zz_pbt/cfg_ppo_clip_value', '1/zz_pbt/cfg_value_loss_coeff', '2/global_step', '2/len/len', '2/len/len_max', '2/len/len_min', '2/perf/_sample_throughput', '2/policy_stats/avg_true_objective', '2/policy_stats/avg_true_objective_max', '2/policy_stats/avg_true_objective_min', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '2/reward/reward', '2/reward/reward_max', '2/reward/reward_min', '2/train/act_max', '2/train/act_min', '2/train/actual_lr', '2/train/adam_max_second_moment', '2/train/adv_max', '2/train/adv_mean', '2/train/adv_min', '2/train/adv_std', '2/train/entropy', '2/train/exploration_loss', '2/train/fraction_clipped', '2/train/grad_norm', '2/train/kl_divergence', '2/train/kl_divergence_max', '2/train/kl_loss', '2/train/loss', '2/train/lr', '2/train/max_abs_logprob', '2/train/num_sgd_steps', '2/train/policy_loss', '2/train/ratio_max', '2/train/ratio_mean', '2/train/ratio_min', '2/train/returns_running_mean', '2/train/returns_running_std', '2/train/same_policy_fraction', '2/train/valids_fraction', '2/train/value', '2/train/value_delta', '2/train/value_delta_max', '2/train/value_loss', '2/train/version_diff_avg', '2/train/version_diff_max', '2/train/version_diff_min', '2/zz_pbt/cfg_exploration_loss_coeff', '2/zz_pbt/cfg_learning_rate', '2/zz_pbt/cfg_max_grad_norm', '2/zz_pbt/cfg_ppo_clip_ratio', '2/zz_pbt/cfg_ppo_clip_value', '2/zz_pbt/cfg_value_loss_coeff', '3/global_step', '3/len/len', '3/len/len_max', '3/len/len_min', '3/perf/_sample_throughput', '3/policy_stats/avg_true_objective', '3/policy_stats/avg_true_objective_max', '3/policy_stats/avg_true_objective_min', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '3/reward/reward', '3/reward/reward_max', '3/reward/reward_min', '3/train/act_max', '3/train/act_min', '3/train/actual_lr', '3/train/adam_max_second_moment', '3/train/adv_max', '3/train/adv_mean', '3/train/adv_min', '3/train/adv_std', '3/train/entropy', '3/train/exploration_loss', '3/train/fraction_clipped', '3/train/grad_norm', '3/train/kl_divergence', '3/train/kl_divergence_max', '3/train/kl_loss', '3/train/loss', '3/train/lr', '3/train/max_abs_logprob', '3/train/num_sgd_steps', '3/train/policy_loss', '3/train/ratio_max', '3/train/ratio_mean', '3/train/ratio_min', '3/train/returns_running_mean', '3/train/returns_running_std', '3/train/same_policy_fraction', '3/train/valids_fraction', '3/train/value', '3/train/value_delta', '3/train/value_delta_max', '3/train/value_loss', '3/train/version_diff_avg', '3/train/version_diff_max', '3/train/version_diff_min', '3/zz_pbt/cfg_exploration_loss_coeff', '3/zz_pbt/cfg_learning_rate', '3/zz_pbt/cfg_max_grad_norm', '3/zz_pbt/cfg_ppo_clip_ratio', '3/zz_pbt/cfg_ppo_clip_value', '3/zz_pbt/cfg_value_loss_coeff', '_runtime', '_step', '_timestamp', '_wandb'])"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs_df['summary'][0].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 546,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "cols = pd.Series(runs_df['summary'][0].keys())\n",
    "\n",
    "# build your regex: contains “raw” OR ends with reward_min, len/len, or global_step\n",
    "regex = r'raw|reward_min$|len/len$|global_step$'\n",
    "\n",
    "filtered = cols[cols.str.contains(regex, regex=True)].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 547,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['0/global_step',\n",
       " '0/len/len',\n",
       " '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '0/reward/reward_min',\n",
       " '1/global_step',\n",
       " '1/len/len',\n",
       " '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '1/reward/reward_min',\n",
       " '2/global_step',\n",
       " '2/len/len',\n",
       " '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '2/reward/reward_min',\n",
       " '3/global_step',\n",
       " '3/len/len',\n",
       " '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '3/reward/reward_min']"
      ]
     },
     "execution_count": 547,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filtered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 298,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "01_hippo2025__e.fra_8_see_0_n.pol_4_H.L_64_r.siz_1149_20250503_175625_309577 64\n",
      "07_hippo2025__e.fra_8_see_1111_n.pol_4_H.L_64_r.siz_1149_20250503_175633_000050 64\n",
      "13_hippo2025__e.fra_8_see_2222_n.pol_4_H.L_64_r.siz_1149_20250503_182443_877673 64\n",
      "19_hippo2025__e.fra_8_see_7777_n.pol_4_H.L_64_r.siz_1149_20250503_183514_593090 64\n",
      "25_hippo2025__e.fra_8_see_8888_n.pol_4_H.L_64_r.siz_1149_20250503_184613_250819 64\n",
      "31_hippo2025__e.fra_8_see_9999_n.pol_4_H.L_64_r.siz_1149_20250503_185513_257429 64\n"
     ]
    }
   ],
   "source": [
    "# fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "# all_results = dict()\n",
    "# for L,R in zip([16,1,1],[8,8,1]):\n",
    "for L,R in zip([64],[8]):\n",
    "    \n",
    "    dfs=[]\n",
    "    for run in runs:\n",
    "        if run.config['Hippo_L'] == L and run.config['Hippo_R']== R and run.config['env_frameskip'] == 8 and run.config['num_policies'] == 4:\n",
    "            print(run.name,run.config['Hippo_L'])\n",
    "            for j in range(1,4):\n",
    "                for i in range(4):\n",
    "                    tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                    tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                    # tmpdf.index.name=filtered[i*4]\n",
    "                    dfs.append(tmpdf)\n",
    "    for df in dfs:\n",
    "        df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "    # 2) Build the union of all indices\n",
    "    union_idx = dfs[0].index\n",
    "    for df in dfs[1:]:\n",
    "        union_idx = union_idx.union(df.index)\n",
    "\n",
    "    # 3) Reindex + interpolate each DataFrame\n",
    "    aligned = []\n",
    "    for df in dfs:\n",
    "        # Reindex to the full union (creates NaNs where missing)\n",
    "        df2 = df.reindex(union_idx)\n",
    "        # Interpolate numeric columns along the index\n",
    "        df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "        aligned.append(df2_interp)\n",
    "\n",
    "    # Now every df in `aligned` has the same index = union_idx, with NaNs filled.\n",
    "    # You can concat or merge them directly:\n",
    "    result = pd.concat(aligned, axis=1)\n",
    "    all_results[f\"{L}_{R}\"] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 512,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "00_LSTM_control_e.fra_8_see_0_20250512_233602_590377\n",
      "01_LSTM_control_e.fra_8_see_1111_20250512_233602_300446\n",
      "02_LSTM_control_e.fra_8_see_2222_20250512_233602_897681\n",
      "03_LSTM_control_e.fra_8_see_7777_20250512_233607_038831\n",
      "04_LSTM_control_e.fra_8_see_8888_20250512_233607_038495\n",
      "05_LSTM_control_e.fra_8_see_9999_20250512_233607_035517\n"
     ]
    }
   ],
   "source": [
    "# fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "# all_results = dict()\n",
    "# for L,R in zip([16,1,1],[8,8,1]):\n",
    "# for L,R in zip([64],[8]):\n",
    "\n",
    "dfs=[]\n",
    "for run in runs:\n",
    "    if run.config['env_frameskip'] == 8 and run.config['num_policies'] == 4:\n",
    "        print(run.name)#,run.config['Hippo_L'])\n",
    "        for j in range(1,4):\n",
    "            for i in range(4):\n",
    "                tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                # tmpdf.index.name=filtered[i*4]\n",
    "                dfs.append(tmpdf)\n",
    "for df in dfs:\n",
    "    df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "# 2) Build the union of all indices\n",
    "union_idx = dfs[0].index\n",
    "for df in dfs[1:]:\n",
    "    union_idx = union_idx.union(df.index)\n",
    "\n",
    "# 3) Reindex + interpolate each DataFrame\n",
    "aligned = []\n",
    "for df in dfs:\n",
    "    # Reindex to the full union (creates NaNs where missing)\n",
    "    df2 = df.reindex(union_idx)\n",
    "    # Interpolate numeric columns along the index\n",
    "    df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "    aligned.append(df2_interp)\n",
    "\n",
    "# Now every df in `aligned` has the same index = union_idx, with NaNs filled.\n",
    "# You can concat or merge them directly:\n",
    "result = pd.concat(aligned, axis=1)\n",
    "all_results[f\"LSTM\"] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 277,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.ndimage import gaussian_filter1d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 382,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AJfLhcvlSr0tLVu2jI8++oiJEydy5pln0tjYePBuoBPNoWYue/My3tj5BrIkc+3URdy67h1d2O25eC9+lUuWyQSiClNGuLjnwukiW5xAIBDsg02bNuH1eg/KtRYsWMCiRYu4+OKLD9o1081hI+61tbVkZ2d3Wed0Oqmrq+v1mK1btzJ37lyKiooA3dr3+XysXLmS2tpazjvvPFS194IrkUgEr9fbZUoHDcEGtrZtxWFy8OBJt/Ld9x9EatsFzmLiP3yLH70ZoqYtRL7TwsPfOw6LSWSOEwgEAoB4PN6lsihAOBzmscce61dBL03T2Lsu2qOPPsq9997b63WBVJnyu+++m8zMTC677LJu5xnItQ82h424S5KUstqTRKPRfQ6J+Otf/9otclKSJGbPns3y5cuprKzkk08+6fX422+/HbfbnZqSkY4HyuScydw9526emX0PJ712PbRXgbsUfvQWv3s/yJpdbViMMv+49FgK3WLIm0AgEICexOaZZ56hsbGRr3/963z3u9/lwgsv5KijjsLQjzLP77//PqtXr+a9997j888/T61/9dVXue2221IB10l27drFAw88AMDDDz9MZWUlZrOZ//znPyxbtozzzjuPFStW9Onan332GcuXL2f16tW8//77fW5zujlsSr4+/fTT/OEPf2DLli2pdRkZGbzxxhvMnj272/5vvfUW4XCYBQsW9HrOK664grlz53LRRRf1uD0SiRCJRFKfvV4vpaWl6Sn52rYbHjsbvLWQORJ+8Dp//TzCXcsqALj3ouksPObwCb4QCASCI4ElS5Zw+eWXdzMmhxuHjeU+d+5campqiCbStCbd8TNnzuy278aNG6mqqtqnsIOelODoo4/udbvFYkn12yentNCyvUPYs8rgsrd4vpKUsP/qjPFC2AUCgeAg89VXX1FUVDTshR0OI3EvLi7mrLPOYuXKlYAeHLd48WKsVit33303FRW6MG7fvp2HHnqI+fPns2vXLr766iv+9re/AbB06VI2b94M6MkOXC7XoYmaN5j1PPBZo+GHb7Byj5HrXlwPwMUzS0VkvEAgEBwCcnNzueCCCw51Mw4Kh81QOIAHH3yQ6667jk8//ZTW1lbuuOMOAP79739TVlaGy+VKWfj3339/6rhnnnkGgNWrV3PppZcye/ZsTjvtNG655ZZDch9klsL3XwWzk/XtJhY9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",
      "text/plain": [
       "<Figure size 550x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "\n",
    "statsnames=[r'raw_score',r'len/len',r'reward_min']\n",
    "normalize=[10,1,4.82]\n",
    "colors=[]\n",
    "for L,R in zip([64,16,1,1],[8,8,8,1]):\n",
    "\n",
    "    # 1) Make sure each df is indexed by the same column:\n",
    "    #    (if not already, e.g. df.set_index('Step', inplace=True))\n",
    "    # df = all_results[f\"{L}_{R}\"]\n",
    "    # df.plot(x=df.index.name or 'Index', title=f'L={L}, R={R}',legend=False,ax=ax[i],)    \n",
    "    for i in range(3):\n",
    "        tmp=all_results[f\"{L}_{R}\"].filter(regex=statsnames[i]).copy()\n",
    "        # for key in tmp.columns:\n",
    "        #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "        tmp=gaussian_filter1d(tmp, axis=0, sigma=300,mode='nearest')\n",
    "        tmp=tmp/normalize[i]\n",
    "        means = tmp.mean(axis=1)\n",
    "        stds  = tmp.std(axis=1)/np.sqrt(24)\n",
    "\n",
    "        ax[i].plot(all_results[f\"{L}_{R}\"].index, means)#, color=f'C{i}')\n",
    "\n",
    "        # 2) draw a translucent band between mean–std and mean+std\n",
    "        ax[i].fill_between(\n",
    "            all_results[f\"{L}_{R}\"].index,\n",
    "            means - stds,\n",
    "            means + stds,\n",
    "            # color=f'C{i}',    # match the line color\n",
    "            alpha=0.2,     # control the band’s opacity\n",
    "            # label='±1 std'\n",
    "        )\n",
    "        # 2) Plot error bars\n",
    "        # ax[i].errorbar(\n",
    "        #     x=all_results[f\"{L}_{R}\"].index,     # your index (e.g. Step or step_bin)\n",
    "        #     y=means,#.values,    # the per-row means\n",
    "        #     yerr=stds,#.values,  # the per-row standard deviations\n",
    "        #     alpha=0.5\n",
    "        #     # fmt='-o',          # line with circle markers\n",
    "        #     # capsize=3,         # length of the errorbar “caps”\n",
    "        #     # ecolor='gray',     # errorbar color\n",
    "        #     # markerfacecolor='white',\n",
    "        #     # markeredgecolor='C0'\n",
    "        #     label=f\"{L}_{R}\"\n",
    "        # )\n",
    "\n",
    "ax[2].set_xlabel('Environment Frames')\n",
    "ax[0].set_ylabel('Success Rate')\n",
    "ax[1].set_ylabel('Trajectory Length (frames)')\n",
    "ax[2].set_ylabel('100 consecutive success')\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top','right']].set_visible(False)\n",
    "i=0\n",
    "for L,R in zip([64,16,1,1],[8,8,8,1]):\n",
    "    ax[0].plot([], [], color=f'C{i}', label=f\"L={L}, R={R}\")\n",
    "    i+=1\n",
    "ax[0].legend(frameon=False)\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/HippoL_HippoR.svg',bbox_inches='tight',dpi=300)\n",
    "# ax[].set_ylabel('Mean ± SD')\n",
    "# ax.set_title('Per-row mean and standard deviation')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 506,
   "metadata": {},
   "outputs": [],
   "source": [
    "tmpdf=all_results[f\"{L}_{R}\"].filter(regex=statsnames[0]).copy()\n",
    "df_means = tmpdf.groupby(rand_labels, axis=1).mean()\n",
    "\n",
    "# # rename the new columns if you like\n",
    "# df_means.columns = [f\"mean_group{g}\" for g in df_means.columns]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 507,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>rand_0</th>\n",
       "      <th>rand_1</th>\n",
       "      <th>rand_2</th>\n",
       "      <th>rand_3</th>\n",
       "      <th>rand_4</th>\n",
       "      <th>rand_5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>600000.0</th>\n",
       "      <td>3.450</td>\n",
       "      <td>1.7750</td>\n",
       "      <td>3.775</td>\n",
       "      <td>3.700000</td>\n",
       "      <td>0.650</td>\n",
       "      <td>1.975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>630000.0</th>\n",
       "      <td>3.450</td>\n",
       "      <td>1.7750</td>\n",
       "      <td>3.800</td>\n",
       "      <td>3.725000</td>\n",
       "      <td>0.650</td>\n",
       "      <td>1.975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>660000.0</th>\n",
       "      <td>3.400</td>\n",
       "      <td>1.7750</td>\n",
       "      <td>3.750</td>\n",
       "      <td>3.775000</td>\n",
       "      <td>0.650</td>\n",
       "      <td>1.975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720000.0</th>\n",
       "      <td>3.325</td>\n",
       "      <td>1.7750</td>\n",
       "      <td>3.725</td>\n",
       "      <td>3.850000</td>\n",
       "      <td>0.650</td>\n",
       "      <td>1.975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750000.0</th>\n",
       "      <td>3.425</td>\n",
       "      <td>1.7750</td>\n",
       "      <td>3.600</td>\n",
       "      <td>3.700000</td>\n",
       "      <td>0.650</td>\n",
       "      <td>1.950</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348930000.0</th>\n",
       "      <td>8.600</td>\n",
       "      <td>5.5875</td>\n",
       "      <td>4.450</td>\n",
       "      <td>4.541667</td>\n",
       "      <td>4.525</td>\n",
       "      <td>4.900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348960000.0</th>\n",
       "      <td>8.600</td>\n",
       "      <td>5.5875</td>\n",
       "      <td>4.450</td>\n",
       "      <td>4.541667</td>\n",
       "      <td>4.500</td>\n",
       "      <td>4.900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348990000.0</th>\n",
       "      <td>8.600</td>\n",
       "      <td>5.5875</td>\n",
       "      <td>4.450</td>\n",
       "      <td>4.541667</td>\n",
       "      <td>4.500</td>\n",
       "      <td>4.900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>349020000.0</th>\n",
       "      <td>8.600</td>\n",
       "      <td>5.5875</td>\n",
       "      <td>4.450</td>\n",
       "      <td>4.541667</td>\n",
       "      <td>4.575</td>\n",
       "      <td>4.900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>349050000.0</th>\n",
       "      <td>8.600</td>\n",
       "      <td>5.5875</td>\n",
       "      <td>4.450</td>\n",
       "      <td>4.541667</td>\n",
       "      <td>4.600</td>\n",
       "      <td>4.900</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10633 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             rand_0  rand_1  rand_2    rand_3  rand_4  rand_5\n",
       "600000.0      3.450  1.7750   3.775  3.700000   0.650   1.975\n",
       "630000.0      3.450  1.7750   3.800  3.725000   0.650   1.975\n",
       "660000.0      3.400  1.7750   3.750  3.775000   0.650   1.975\n",
       "720000.0      3.325  1.7750   3.725  3.850000   0.650   1.975\n",
       "750000.0      3.425  1.7750   3.600  3.700000   0.650   1.950\n",
       "...             ...     ...     ...       ...     ...     ...\n",
       "348930000.0   8.600  5.5875   4.450  4.541667   4.525   4.900\n",
       "348960000.0   8.600  5.5875   4.450  4.541667   4.500   4.900\n",
       "348990000.0   8.600  5.5875   4.450  4.541667   4.500   4.900\n",
       "349020000.0   8.600  5.5875   4.450  4.541667   4.575   4.900\n",
       "349050000.0   8.600  5.5875   4.450  4.541667   4.600   4.900\n",
       "\n",
       "[10633 rows x 6 columns]"
      ]
     },
     "execution_count": 507,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 504,
   "metadata": {},
   "outputs": [],
   "source": [
    "rand_labels =[]\n",
    "for i in range(6):\n",
    "    rand_labels+=[f\"rand_{i}\"]*4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 585,
   "metadata": {},
   "outputs": [],
   "source": [
    "cmap=plt.colormaps['rainbow']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 588,
   "metadata": {},
   "outputs": [],
   "source": [
    "cmap=cmap.resampled(5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 600,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 600,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(cmap(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 614,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHnRFWHRUaXRsZQB2aXJpZGlzX2RhcmswLjYgY29sb3JtYXAdZJ/xAAAAJHRFWHREZXNjcmlwdGlvbgB2aXJpZGlzX2RhcmswLjYgY29sb3JtYXDX2HaeAAAAMHRFWHRBdXRob3IATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcme6yd4QAAAAMnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ5RvQTcAAAFDSURBVHic7daxEYIAEABBpA8jEjNmLMC6rJJmGGLpwg9ut4IL7/Fa3r+FrOuzTScwaN3P6QQGfZ/HdAKD1ukAAOD/DAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAoBtl9wW2dpx09AAAAABJRU5ErkJggg==",
      "text/html": [
       "<div style=\"vertical-align: middle;\"><strong>viridis_dark0.6</strong> </div><div class=\"cmap\"><img alt=\"viridis_dark0.6 colormap\" title=\"viridis_dark0.6\" style=\"border: 1px solid #555;\" src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHnRFWHRUaXRsZQB2aXJpZGlzX2RhcmswLjYgY29sb3JtYXAdZJ/xAAAAJHRFWHREZXNjcmlwdGlvbgB2aXJpZGlzX2RhcmswLjYgY29sb3JtYXDX2HaeAAAAMHRFWHRBdXRob3IATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcme6yd4QAAAAMnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ5RvQTcAAAFDSURBVHic7daxEYIAEABBpA8jEjNmLMC6rJJmGGLpwg9ut4IL7/Fa3r+FrOuzTScwaN3P6QQGfZ/HdAKD1ukAAOD/DAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAoBtl9wW2dpx09AAAAABJRU5ErkJggg==\"></div><div style=\"vertical-align: middle; max-width: 514px; display: flex; justify-content: space-between;\"><div style=\"float: left;\"><div title=\"#290132ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #290132ff;\"></div> under</div><div style=\"margin: 0 auto; display: inline-block;\">bad <div title=\"#00000000\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #00000000;\"></div></div><div style=\"float: right;\">over <div title=\"#988b16ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #988b16ff;\"></div></div>"
      ],
      "text/plain": [
       "<matplotlib.colors.LinearSegmentedColormap at 0x76a85f521ee0>"
      ]
     },
     "execution_count": 614,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dark_cmap.resampled(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 631,
   "metadata": {},
   "outputs": [],
   "source": [
    "def darken_rgb(color, factor=0.7):\n",
    "    \"\"\"\n",
    "    Darken a color by linearly scaling its RGB channels.\n",
    "    color : any Matplotlib‐compatible color spec (name, hex, etc.)\n",
    "    factor: <1 for darker, >1 for lighter\n",
    "    \"\"\"\n",
    "    if type(color)==tuple:\n",
    "        # If color is already an RGB tuple, just use it\n",
    "        rgb = color\n",
    "    else:\n",
    "        rgb = to_rgb(color)\n",
    "    dark_rgb = tuple(max(0, c * factor) for c in rgb)\n",
    "    if len(dark_rgb)== 4:\n",
    "        # If color is RGBA, convert to RGB\n",
    "        dark_rgb=dark_rgb[0:3]\n",
    "\n",
    "    return dark_rgb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 618,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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c3Mzc+fO7a/he0Uo383diw+laMSe+4dwcNhd3JLC34+/pV/H6w2722JnVwwcOJBf/epXvPzyy2zZsiUjuEuXLuWVV17p8pzLL7+cpUuX4vV6effddznhhBMYMGAA11xzzW7NYVf0m+BeddVVGYEVBIFgMNirVhX9jSO2DnsrgiD06ha/v9ndFjvdIScnh4cffpirrrqKOXPmkJ2dzbRp05g2bdoOz7n99tt54403yMvL47HHHuMXv/jFvi+41113HZIkoes6y5cv73VXhb6mYzGvu6EkDg7fJsFgcK9fS+jrFjstLS288cYbnHPOOdstxm071hlnnMGzzz7LVVdd1a11oo5WOnl5eRx66KEMGjSoW/PbLew9yPe//337wgsvtF988UXbtm17w4YN9siRI21FUeySkhL7rbfe2pPD94iKigqbdM0ZZ3O2vX5ra2v7tv9kdsqyZcvsWbNm2fn5+fa1115rX3/99fa8efPsKVOmdOv8hQsX2iUlJfZNN91kNzU12bZt2//85z/trKws+7XXXutyrNLSUvvTTz+1bdu2a2tr7dzcXPviiy+216xZs9OxysvL7RtvvNF+9tln7XvvvdfesGHDbrzj7rFHq4UVFhby8ccfM3LkSAAOPfRQ6uvree+998jKyuKKK67Ya1J8Lcuiurp6n7AcHBy+q5/TTz75BFEUOfjgg7/tqewWe9SlcN5552XE9umnn+aTTz7hvffeY8CAAUA61m5vQRRFBg4c+G1Pw8HBYQds3ryZhoYGTjvttG97KrtNr1N7r7zySp5++ml0Xef4449n6NChGas1mUwC6dS566+/nvPOO69Tl8zFixf3dngHB4fvCIMHD96nxRb6QHAVRWHevHncf//9NDQ0sGbNGpqbmwE46qijmDJlClOmTGHkyJE8/PDDAKxevZqrr766U7lGBwcHh/2dXrsUCgsLWbNmDb/5zW94/fXXcbvdlJeXA3DmmWdy2GGHUV9fz/jx4zv5nC677DIuu+yy3g7v4ODgsM/Qa8E98MADufHGG7n77ruZMWMGDzzwAKtXr87sLygo2C43eezYsb0d1sHBwWGfo0+iFKLRKE1NTZSUlBCLxfaqXmUODg4Oewu99uE+99xzlJSUcNNNN+FyuXjqqaf497//3Rdzc3BwcNiv6LVL4W9/+xuff/45X375JQDnnHMOBxxwwD7R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",
      "text/plain": [
       "<Figure size 220x250 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.colors import LinearSegmentedColormap, to_rgb\n",
    "\n",
    "def darken_cmap(cmap, factor=0.8, n_shades=256):\n",
    "    \"\"\"\n",
    "    Return a new colormap which is the input cmap darkened by the given factor.\n",
    "    \n",
    "    cmap      : a Matplotlib Colormap instance (or name)\n",
    "    factor    : <1 makes it darker, >1 makes it lighter\n",
    "    n_shades  : number of discrete samples to generate\n",
    "    \"\"\"\n",
    "    # 1) Grab n_shades RGBA samples from the original\n",
    "    base = plt.get_cmap(cmap)\n",
    "    colors = base(np.linspace(0, 1, n_shades))[:, :3]  # drop alpha\n",
    "\n",
    "    # 2) Darken each RGB tuple\n",
    "    darkened = np.clip(colors * factor, 0, 1)\n",
    "\n",
    "    # 3) Build a new colormap (preserve alpha=1)\n",
    "    new_cmap = LinearSegmentedColormap.from_list(\n",
    "        f\"{base.name}_dark{factor}\", \n",
    "        np.hstack([darkened, np.ones((n_shades,1))])\n",
    "    )\n",
    "    return new_cmap\n",
    "\n",
    "# Example usage:\n",
    "orig = plt.cm.rainbow\n",
    "cmap = darken_cmap(orig, factor=0.7)\n",
    "cmap = cmap.resampled(5)\n",
    "\n",
    "fig,ax=plt.subplots(3,1,figsize=(5.5*0.4, 2.5))\n",
    "\n",
    "statsnames=[r'raw_score',r'len/len',r'reward_min']\n",
    "normalize=[10,1,4.82]\n",
    "colors=[]\n",
    "coloridx=-1\n",
    "for L,R in zip([64,16,1,1],[8,8,8,1]):\n",
    "    coloridx+=1\n",
    "    # 1) Make sure each df is indexed by the same column:\n",
    "    #    (if not already, e.g. df.set_index('Step', inplace=True))\n",
    "    # df = all_results[f\"{L}_{R}\"]\n",
    "    # df.plot(x=df.index.name or 'Index', title=f'L={L}, R={R}',legend=False,ax=ax[i],)    \n",
    "    for i in range(3):\n",
    "        tmp = all_results[f\"{L}_{R}\"].filter(regex=statsnames[i]).copy()\n",
    "        # tmpdf=all_results[f\"{L}_{R}\"].filter(regex=statsnames[0]).copy()\n",
    "        tmp = tmp.groupby(rand_labels, axis=1).mean()\n",
    "        # for key in tmp.columns:\n",
    "        #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "        tmp=gaussian_filter1d(tmp, axis=0, sigma=200,mode='nearest')\n",
    "        tmp=tmp/normalize[i]\n",
    "        means = tmp.mean(axis=1)\n",
    "        stds  = tmp.std(axis=1)/np.sqrt(6)\n",
    "\n",
    "        ax[i].plot(all_results[f\"{L}_{R}\"].index, means,lw=0.75 , color=cmap(coloridx))#, color=f'C{i}')\n",
    "\n",
    "        # 2) draw a translucent band between mean–std and mean+std\n",
    "        ax[i].fill_between(\n",
    "            all_results[f\"{L}_{R}\"].index,\n",
    "            means - stds,\n",
    "            means + stds,\n",
    "            # color=f'C{i}',    # match the line color\n",
    "            alpha=0.2,     # control the band’s opacity\n",
    "            # label='±1 std'\n",
    "            color=cmap(coloridx),\n",
    "            edgecolor=None\n",
    "        )\n",
    "        # 2) Plot error bars\n",
    "        # ax[i].errorbar(\n",
    "        #     x=all_results[f\"{L}_{R}\"].index,     # your index (e.g. Step or step_bin)\n",
    "        #     y=means,#.values,    # the per-row means\n",
    "        #     yerr=stds,#.values,  # the per-row standard deviations\n",
    "        #     alpha=0.5\n",
    "        #     # fmt='-o',          # line with circle markers\n",
    "        #     # capsize=3,         # length of the errorbar “caps”\n",
    "        #     # ecolor='gray',     # errorbar color\n",
    "        #     # markerfacecolor='white',\n",
    "        #     # markeredgecolor='C0'\n",
    "        #     label=f\"{L}_{R}\"\n",
    "        # )\n",
    "coloridx+=1\n",
    "for i in range(3):\n",
    "    tmp = all_results[f\"LSTM\"].filter(regex=statsnames[i]).copy()\n",
    "    # tmpdf=all_results[f\"{L}_{R}\"].filter(regex=statsnames[0]).copy()\n",
    "    tmp = tmp.groupby(rand_labels, axis=1).mean()\n",
    "    # for key in tmp.columns:\n",
    "    #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "    tmp=gaussian_filter1d(tmp, axis=0, sigma=300,mode='nearest')\n",
    "    tmp=tmp/normalize[i]\n",
    "    means = tmp.mean(axis=1)\n",
    "    stds  = tmp.std(axis=1)/np.sqrt(6)\n",
    "\n",
    "    ax[i].plot(all_results[f\"LSTM\"].index, means, color=cmap(coloridx), lw=0.75)#, color=f'C{i}')\n",
    "\n",
    "    # 2) draw a translucent band between mean–std and mean+std\n",
    "    ax[i].fill_between(\n",
    "        all_results[f\"LSTM\"].index,\n",
    "        means - stds,\n",
    "        means + stds,\n",
    "        # color=f'C{i}',    # match the line color\n",
    "        alpha=0.2,     # control the band’s opacity\n",
    "        # label='±1 std'\n",
    "        color=cmap(coloridx),\n",
    "        edgecolor=None\n",
    "    )\n",
    "\n",
    "ax[0].tick_params(axis='x', length=0)\n",
    "ax[1].tick_params(axis='x', length=0)\n",
    "ax[0].set_xticks([])\n",
    "ax[1].set_xticks([])\n",
    "\n",
    "ax[2].set_xlabel('Environment Frames')\n",
    "# ax[0].set_ylabel('Success Rate')\n",
    "# ax[1].set_ylabel('Trajectory Length (frames)')\n",
    "# ax[2].set_ylabel('100 consecutive success')\n",
    "ax[0].set_ylabel('Success Rate')#,fontsize=8)\n",
    "ax[1].set_ylabel('Episode frames')#,fontsize=8)\n",
    "ax[2].set_ylabel('consecutive \\n100 success')#,fontsize=8)\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top','right']].set_visible(False)\n",
    "i=0\n",
    "for L,R in zip([64,16,1,1],[8,8,8,1]):\n",
    "    ax[0].plot([], [], color=cmap(i), label=f\"L={L}, R={R}\")\n",
    "    i+=1\n",
    "ax[0].plot([], [], color=cmap(i), label=f\"LSTM\")\n",
    "ax[0].legend(frameon=False,loc='upper left',bbox_to_anchor=(0.97, 1))\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/HippoL_HippoR_LSTM_small.svg',bbox_inches='tight',dpi=300)\n",
    "# ax[].set_ylabel('Mean ± SD')\n",
    "# ax.set_title('Per-row mean and standard deviation')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: []\n",
       "Index: []"
      ]
     },
     "execution_count": 131,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "colors={'Res': 'C1', 'Epi': 'C0', 'LSTM': 'C2'}\n",
    "# Compute smoothed curve\n",
    "for expname in colors:\n",
    "    if expname=='LSTM':\n",
    "        continue\n",
    "    for pol in np.arange(3):\n",
    "        col=f\"{expname}_{pol}_\"\n",
    "        i=0\n",
    "        for stat in ['score','len','min']:\n",
    "        # tmpdf=df.copy()\n",
    "        # if col.startswith('Res'):\n",
    "        #     tmpdf['Step']+= 480000\n",
    "        #     color='C1'\n",
    "        # else:\n",
    "        #     color='C0'\n",
    "        \n",
    "            df.plot(x=col+'step', y=col+stat,legend=False,xlabel=\"\",ax=ax[i],color=colors[expname])\n",
    "            i+=1\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top', 'right']].set_visible(False)\n",
    "line1, = ax[0].plot([], [], color='C1', label=\"Transfer to new reward loc.\")\n",
    "line2, = ax[0].plot([], [], color='C0', label=\"Initial training\")\n",
    "\n",
    "ax[0].legend(handles=[line1, line2],frameon=False)#, title=\"Column groups\")\n",
    "ax[2].set_xlabel('Environment Steps')\n",
    "ax[0].set_ylabel('Success Rate')\n",
    "ax[1].set_ylabel('trajectory length (frames)')\n",
    "ax[2].set_ylabel('100 consecutive success')\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/Training_local_resume.svg',bbox_inches='tight',dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, row in run.history(keys=[\"accuracy\"]).iterrows():\n",
    "        print(row[\"_timestamp\"], row[\"accuracy\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [],
   "source": [
    "history = run.scan_history()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2688.0 819200.0\n",
      "3333.0 983040.0\n",
      "9037.0 2228224.0\n",
      "9471.0 2293760.0\n",
      "12936.0 2981888.0\n",
      "19563.0 4325376.0\n",
      "23729.0 5177344.0\n",
      "26269.0 5701632.0\n",
      "31308.0 6782976.0\n",
      "31639.0 6848512.0\n",
      "34788.0 7471104.0\n",
      "35642.0 7667712.0\n"
     ]
    }
   ],
   "source": [
    "for i, row in run.history(keys=['0/global_step']).iterrows():\n",
    "    print(row[\"_step\"],row['0/global_step'])\n",
    "    if i>10:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(118637, 37)"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "training_data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### newmaps runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "# all_results = dict()\n",
    "# for L,R in zip([16,1,1],[8,8,1]):\n",
    "for L,R in zip([64],[8]):\n",
    "    \n",
    "    dfs=[]\n",
    "    for run in runs:\n",
    "        if run.config['Hippo_L'] == L and run.config['Hippo_R']== R and run.config['env_frameskip'] == 8 and run.config['num_policies'] == 4:\n",
    "            print(run.name,run.config['Hippo_L'])\n",
    "            for j in range(1,4):\n",
    "                for i in range(4):\n",
    "                    tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                    tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                    # tmpdf.index.name=filtered[i*4]\n",
    "                    dfs.append(tmpdf)\n",
    "    for df in dfs:\n",
    "        df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "    # 2) Build the union of all indices\n",
    "    union_idx = dfs[0].index\n",
    "    for df in dfs[1:]:\n",
    "        union_idx = union_idx.union(df.index)\n",
    "\n",
    "    # 3) Reindex + interpolate each DataFrame\n",
    "    aligned = []\n",
    "    for df in dfs:\n",
    "        # Reindex to the full union (creates NaNs where missing)\n",
    "        df2 = df.reindex(union_idx)\n",
    "        # Interpolate numeric columns along the index\n",
    "        df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "        aligned.append(df2_interp)\n",
    "\n",
    "    # Now every df in `aligned` has the same index = union_idx, with NaNs filled.\n",
    "    # You can concat or merge them directly:\n",
    "    result = pd.concat(aligned, axis=1)\n",
    "    all_results[f\"{L}_{R}\"] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 549,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'openfield_map2_fixed_newmap5'"
      ]
     },
     "execution_count": 549,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs[0].config['env']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 553,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "04_newmaps_e.fra_8_see_0_env_openfield_map2_fixed_newmap1_20250512_234055_183698\n",
      "09_newmaps_e.fra_8_see_42_env_openfield_map2_fixed_newmap1_20250512_234102_021410\n",
      "03_newmaps_e.fra_8_see_0_env_openfield_map2_fixed_newmap2_20250512_234056_022337\n",
      "08_newmaps_e.fra_8_see_42_env_openfield_map2_fixed_newmap2_20250512_234102_016059\n",
      "02_newmaps_e.fra_8_see_0_env_openfield_map2_fixed_newmap3_20250512_234056_022335\n",
      "07_newmaps_e.fra_8_see_42_env_openfield_map2_fixed_newmap3_20250512_234102_015558\n",
      "01_newmaps_e.fra_8_see_0_env_openfield_map2_fixed_newmap4_20250512_234056_022134\n",
      "06_newmaps_e.fra_8_see_42_env_openfield_map2_fixed_newmap4_20250512_234057_117096\n",
      "00_newmaps_e.fra_8_see_0_env_openfield_map2_fixed_newmap5_20250512_234050_347843\n",
      "05_newmaps_e.fra_8_see_42_env_openfield_map2_fixed_newmap5_20250512_234057_111836\n"
     ]
    }
   ],
   "source": [
    "# fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "# all_results = dict()\n",
    "# for L,R in zip([16,1,1],[8,8,1]):\n",
    "# for L,R in zip([64],[8]):\n",
    "newmap_results=dict()\n",
    "for x in range(1,6):\n",
    "    dfs=[]\n",
    "    for run in runs:\n",
    "        cols = pd.Series(run.summary.keys())\n",
    "\n",
    "        # build your regex: contains “raw” OR ends with reward_min, len/len, or global_step\n",
    "        regex = r'raw|reward_min$|len/len$|global_step$'\n",
    "\n",
    "        filtered = cols[cols.str.contains(regex, regex=True)].tolist()\n",
    "        if run.config['env']=='openfield_map2_fixed_newmap'+str(x) and run.config['env_frameskip'] == 8:# and run.config['num_policies'] == 4:\n",
    "            print(run.name)#,run.config['Hippo_L'])\n",
    "            for j in range(1,4):\n",
    "                for i in range(4):\n",
    "                    tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                    tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                    # tmpdf.index.name=filtered[i*4]\n",
    "                    dfs.append(tmpdf)\n",
    "    for df in dfs:\n",
    "        df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "    # 2) Build the union of all indices\n",
    "    union_idx = dfs[0].index\n",
    "    for df in dfs[1:]:\n",
    "        union_idx = union_idx.union(df.index)\n",
    "\n",
    "    # 3) Reindex + interpolate each DataFrame\n",
    "    aligned = []\n",
    "    for df in dfs:\n",
    "        # Reindex to the full union (creates NaNs where missing)\n",
    "        df2 = df.reindex(union_idx)\n",
    "        # Interpolate numeric columns along the index\n",
    "        df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "        aligned.append(df2_interp)\n",
    "    result = pd.concat(aligned, axis=1)\n",
    "    newmap_results['openfield_map2_fixed_newmap'+str(x)] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 574,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['rand_0',\n",
       " 'rand_0',\n",
       " 'rand_0',\n",
       " 'rand_0',\n",
       " 'rand_1',\n",
       " 'rand_1',\n",
       " 'rand_1',\n",
       " 'rand_1',\n",
       " 'rand_2',\n",
       " 'rand_2',\n",
       " 'rand_2',\n",
       " 'rand_2',\n",
       " 'rand_3',\n",
       " 'rand_3',\n",
       " 'rand_3',\n",
       " 'rand_3',\n",
       " 'rand_4',\n",
       " 'rand_4',\n",
       " 'rand_4',\n",
       " 'rand_4',\n",
       " 'rand_5',\n",
       " 'rand_5',\n",
       " 'rand_5',\n",
       " 'rand_5']"
      ]
     },
     "execution_count": 574,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rand_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x250 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5*0.7, 2.5))\n",
    "\n",
    "statsnames=[r'raw_score',r'len/len',r'reward_min']\n",
    "normalize=[10,1,4.82]\n",
    "colors=[]\n",
    "for x in range(1,6):\n",
    "\n",
    "    # 1) Make sure each df is indexed by the same column:\n",
    "    #    (if not already, e.g. df.set_index('Step', inplace=True))\n",
    "    # df = all_results[f\"{L}_{R}\"]\n",
    "    # df.plot(x=df.index.name or 'Index', title=f'L={L}, R={R}',legend=False,ax=ax[i],)    \n",
    "    for i in range(3):\n",
    "        tmp = newmap_results['openfield_map2_fixed_newmap'+str(x)].filter(regex=statsnames[i]).copy()\n",
    "        # tmpdf=all_results[f\"{L}_{R}\"].filter(regex=statsnames[0]).copy()\n",
    "        tmp = tmp.groupby(rand_labels[:8], axis=1).mean()\n",
    "        # for key in tmp.columns:\n",
    "        #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "        tmp=gaussian_filter1d(tmp, axis=0, sigma=300,mode='nearest')\n",
    "        tmp=tmp/normalize[i]\n",
    "        # means = tmp.mean(axis=1)\n",
    "        # stds  = tmp.std(axis=1)/np.sqrt(6)\n",
    "\n",
    "        ax[i].plot(newmap_results['openfield_map2_fixed_newmap'+str(x)].index, tmp[:,0],color=f'C{x-1}')\n",
    "        ax[i].plot(newmap_results['openfield_map2_fixed_newmap'+str(x)].index, tmp[:,1],color=f'C{x-1}')\n",
    "\n",
    "        # 2) draw a translucent band between mean–std and mean+std\n",
    "        # ax[i].fill_between(\n",
    "        #     all_results[f\"{L}_{R}\"].index,\n",
    "        #     means - stds,\n",
    "        #     means + stds,\n",
    "        #     # color=f'C{i}',    # match the line color\n",
    "        #     alpha=0.2,     # control the band’s opacity\n",
    "        #     # label='±1 std'\n",
    "        # )\n",
    "        # 2) Plot error bars\n",
    "        # ax[i].errorbar(\n",
    "        #     x=all_results[f\"{L}_{R}\"].index,     # your index (e.g. Step or step_bin)\n",
    "        #     y=means,#.values,    # the per-row means\n",
    "        #     yerr=stds,#.values,  # the per-row standard deviations\n",
    "        #     alpha=0.5\n",
    "        #     # fmt='-o',          # line with circle markers\n",
    "        #     # capsize=3,         # length of the errorbar “caps”\n",
    "        #     # ecolor='gray',     # errorbar color\n",
    "        #     # markerfacecolor='white',\n",
    "        #     # markeredgecolor='C0'\n",
    "        #     label=f\"{L}_{R}\"\n",
    "        # )\n",
    "\n",
    "\n",
    "ax[2].set_xlabel('Environment Frames')\n",
    "# ax[0].set_ylabel('Success Rate')\n",
    "# ax[1].set_ylabel('Trajectory Length (frames)')\n",
    "# ax[2].set_ylabel('100 consecutive success')\n",
    "ax[0].set_ylabel('Success Rate')#,fontsize=8)\n",
    "ax[1].set_ylabel('Episode frames')#,fontsize=8)\n",
    "ax[2].set_ylabel('consecutive \\n100 success')#,fontsize=8)\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top','right']].set_visible(False)\n",
    "i=0\n",
    "for x in range(1,6):\n",
    "    ax[0].plot([], [], color=f'C{x-1}', label=f\"map{x}\")\n",
    "    i+=1\n",
    "ax[0].legend(frameon=False,loc='upper left',bbox_to_anchor=(0.97, 1))\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/training_newmaps.svg',bbox_inches='tight',dpi=300)\n",
    "# ax[].set_ylabel('Mean ± SD')\n",
    "# ax.set_title('Per-row mean and standard deviation')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 552,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['openfield_map2_fixed_newmap5'])"
      ]
     },
     "execution_count": 552,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "newmap_results.keys()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### local runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 524,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs = api.runs(\"<your_wandb_ID>/SF_dmlab\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 661,
   "metadata": {},
   "outputs": [],
   "source": [
    "from numpy import short\n",
    "\n",
    "\n",
    "runnames=[\n",
    "    'Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L64_skip8_3pbt_64_rollout_Gamma99_epoch2_20250426_181928_792734',\n",
    "    'ResumeLoc2_Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L64_skip8_3pbt_64_rollout_Gamma99_epoch2_20250429_003343_313502',\n",
    "    'Epi_Ins9_Depth_Fix3_Tr_AR_LSTM_DGBN243_Hippo16_skip8_3pbt_64_rollout_Gamma99_epoch2_20250512_180459_608550',\n",
    "    'Epi_Ins9_Depth_Fix3_Tr_AR_LSTM_DG_linear_Hippo16_skip8_3pbt_64_rollout_Gamma99_epoch2_20250513_155436_231723'\n",
    "]\n",
    "\n",
    "shortnames=['L64_R8','new reward','LSTM_sparse','LSTM_dense']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 526,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['0/global_step',\n",
       " '0/len/len',\n",
       " '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '0/reward/reward_min',\n",
       " '1/global_step',\n",
       " '1/len/len',\n",
       " '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '1/reward/reward_min',\n",
       " '2/global_step',\n",
       " '2/len/len',\n",
       " '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '2/reward/reward_min',\n",
       " '3/global_step',\n",
       " '3/len/len',\n",
       " '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '3/reward/reward_min']"
      ]
     },
     "execution_count": 526,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filtered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 527,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['0/global_step', '0/len/len', '0/len/len_max', '0/len/len_min', '0/perf/_fps', '0/perf/_sample_throughput', '0/policy_stats/avg_true_objective', '0/policy_stats/avg_true_objective_max', '0/policy_stats/avg_true_objective_min', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '0/reward/reward', '0/reward/reward_max', '0/reward/reward_min', '0/stats/avg_request_count', '0/stats/master_process_memory_mb', '0/stats/memory_learner', '0/stats/memory_policy_worker', '0/stats/step_policy', '0/stats/wait_policy', '0/train/act_max', '0/train/act_min', '0/train/actual_lr', '0/train/adam_max_second_moment', '0/train/adv_max', '0/train/adv_mean', '0/train/adv_min', '0/train/adv_std', '0/train/entropy', '0/train/exploration_loss', '0/train/fraction_clipped', '0/train/grad_norm', '0/train/kl_divergence', '0/train/kl_divergence_max', '0/train/kl_loss', '0/train/loss', '0/train/lr', '0/train/max_abs_logprob', '0/train/num_sgd_steps', '0/train/policy_loss', '0/train/ratio_max', '0/train/ratio_mean', '0/train/ratio_min', '0/train/returns_running_mean', '0/train/returns_running_std', '0/train/same_policy_fraction', '0/train/valids_fraction', '0/train/value', '0/train/value_delta', '0/train/value_delta_max', '0/train/value_loss', '0/train/version_diff_avg', '0/train/version_diff_max', '0/train/version_diff_min', '0/zz_pbt/cfg_exploration_loss_coeff', '0/zz_pbt/cfg_learning_rate', '0/zz_pbt/cfg_max_grad_norm', '0/zz_pbt/cfg_ppo_clip_ratio', '0/zz_pbt/cfg_ppo_clip_value', '0/zz_pbt/cfg_value_loss_coeff', '1/global_step', '1/len/len', '1/len/len_max', '1/len/len_min', '1/perf/_sample_throughput', '1/policy_stats/avg_true_objective', '1/policy_stats/avg_true_objective_max', '1/policy_stats/avg_true_objective_min', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '1/reward/reward', '1/reward/reward_max', '1/reward/reward_min', '1/train/act_max', '1/train/act_min', '1/train/actual_lr', '1/train/adam_max_second_moment', '1/train/adv_max', '1/train/adv_mean', '1/train/adv_min', '1/train/adv_std', '1/train/entropy', '1/train/exploration_loss', '1/train/fraction_clipped', '1/train/grad_norm', '1/train/kl_divergence', '1/train/kl_divergence_max', '1/train/kl_loss', '1/train/loss', '1/train/lr', '1/train/max_abs_logprob', '1/train/num_sgd_steps', '1/train/policy_loss', '1/train/ratio_max', '1/train/ratio_mean', '1/train/ratio_min', '1/train/returns_running_mean', '1/train/returns_running_std', '1/train/same_policy_fraction', '1/train/valids_fraction', '1/train/value', '1/train/value_delta', '1/train/value_delta_max', '1/train/value_loss', '1/train/version_diff_avg', '1/train/version_diff_max', '1/train/version_diff_min', '1/zz_pbt/cfg_exploration_loss_coeff', '1/zz_pbt/cfg_learning_rate', '1/zz_pbt/cfg_max_grad_norm', '1/zz_pbt/cfg_ppo_clip_ratio', '1/zz_pbt/cfg_ppo_clip_value', '1/zz_pbt/cfg_value_loss_coeff', '2/global_step', '2/len/len', '2/len/len_max', '2/len/len_min', '2/perf/_sample_throughput', '2/policy_stats/avg_true_objective', '2/policy_stats/avg_true_objective_max', '2/policy_stats/avg_true_objective_min', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '2/reward/reward', '2/reward/reward_max', '2/reward/reward_min', '2/train/act_max', '2/train/act_min', '2/train/actual_lr', '2/train/adam_max_second_moment', '2/train/adv_max', '2/train/adv_mean', '2/train/adv_min', '2/train/adv_std', '2/train/entropy', '2/train/exploration_loss', '2/train/fraction_clipped', '2/train/grad_norm', '2/train/kl_divergence', '2/train/kl_divergence_max', '2/train/kl_loss', '2/train/loss', '2/train/lr', '2/train/max_abs_logprob', '2/train/num_sgd_steps', '2/train/policy_loss', '2/train/ratio_max', '2/train/ratio_mean', '2/train/ratio_min', '2/train/returns_running_mean', '2/train/returns_running_std', '2/train/same_policy_fraction', '2/train/valids_fraction', '2/train/value', '2/train/value_delta', '2/train/value_delta_max', '2/train/value_loss', '2/train/version_diff_avg', '2/train/version_diff_max', '2/train/version_diff_min', '2/zz_pbt/cfg_exploration_loss_coeff', '2/zz_pbt/cfg_learning_rate', '2/zz_pbt/cfg_max_grad_norm', '2/zz_pbt/cfg_ppo_clip_ratio', '2/zz_pbt/cfg_ppo_clip_value', '2/zz_pbt/cfg_value_loss_coeff', '3/global_step', '3/len/len', '3/len/len_max', '3/len/len_min', '3/perf/_sample_throughput', '3/policy_stats/avg_true_objective', '3/policy_stats/avg_true_objective_max', '3/policy_stats/avg_true_objective_min', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_len', '3/policy_stats/avg_z_00_openfield_map2_fixed_loc3_lenweighted_score', '3/reward/reward', '3/reward/reward_max', '3/reward/reward_min', '3/train/act_max', '3/train/act_min', '3/train/actual_lr', '3/train/adam_max_second_moment', '3/train/adv_max', '3/train/adv_mean', '3/train/adv_min', '3/train/adv_std', '3/train/entropy', '3/train/exploration_loss', '3/train/fraction_clipped', '3/train/grad_norm', '3/train/kl_divergence', '3/train/kl_divergence_max', '3/train/kl_loss', '3/train/loss', '3/train/lr', '3/train/max_abs_logprob', '3/train/num_sgd_steps', '3/train/policy_loss', '3/train/ratio_max', '3/train/ratio_mean', '3/train/ratio_min', '3/train/returns_running_mean', '3/train/returns_running_std', '3/train/same_policy_fraction', '3/train/valids_fraction', '3/train/value', '3/train/value_delta', '3/train/value_delta_max', '3/train/value_loss', '3/train/version_diff_avg', '3/train/version_diff_max', '3/train/version_diff_min', '3/zz_pbt/cfg_exploration_loss_coeff', '3/zz_pbt/cfg_learning_rate', '3/zz_pbt/cfg_max_grad_norm', '3/zz_pbt/cfg_ppo_clip_ratio', '3/zz_pbt/cfg_ppo_clip_value', '3/zz_pbt/cfg_value_loss_coeff', '_runtime', '_step', '_timestamp', '_wandb'])"
      ]
     },
     "execution_count": 527,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "run.summary.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 536,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L64_skip8_3pbt_64_rollout_Gamma99_epoch2_20250426_181928_792734\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ResumeLoc2_Epi_Ins9_Depth_Fix3_Tr_AR_SS_DGBN243_Hippo16_L64_skip8_3pbt_64_rollout_Gamma99_epoch2_20250429_003343_313502\n",
      "Epi_Ins9_Depth_Fix3_Tr_AR_LSTM_DGBN243_Hippo16_skip8_3pbt_64_rollout_Gamma99_epoch2_20250512_180459_608550\n",
      "Epi_Ins9_Depth_Fix3_Tr_AR_LSTM_DG_linear_Hippo16_skip8_3pbt_64_rollout_Gamma99_epoch2_20250513_155436_231723\n"
     ]
    }
   ],
   "source": [
    "# fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "# all_results = dict()\n",
    "# for L,R in zip([16,1,1],[8,8,1]):\n",
    "# for L,R in zip([64],[8]):\n",
    "local_results=dict()\n",
    "for x in range(4):\n",
    "    dfs=[]\n",
    "    run=api.run(\"<your_wandb_ID>/SF_dmlab/\"+runnames[x])\n",
    "    cols = pd.Series(run.summary.keys())\n",
    "\n",
    "    # build your regex: contains “raw” OR ends with reward_min, len/len, or global_step\n",
    "    regex = r'raw|reward_min$|len/len$|global_step$'\n",
    "\n",
    "    filtered = cols[cols.str.contains(regex, regex=True)].tolist()\n",
    "    if run.config['env_frameskip'] == 8:# and run.config['num_policies'] == 4:\n",
    "        print(run.name)#,run.config['Hippo_L'])\n",
    "        for j in range(1,4):\n",
    "            for i in range(3):\n",
    "                tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                # tmpdf.index.name=filtered[i*4]\n",
    "                dfs.append(tmpdf)\n",
    "    for df in dfs:\n",
    "        df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "    # 2) Build the union of all indices\n",
    "    union_idx = dfs[0].index\n",
    "    for df in dfs[1:]:\n",
    "        union_idx = union_idx.union(df.index)\n",
    "\n",
    "    # 3) Reindex + interpolate each DataFrame\n",
    "    aligned = []\n",
    "    for df in dfs:\n",
    "        # Reindex to the full union (creates NaNs where missing)\n",
    "        df2 = df.reindex(union_idx)\n",
    "        # Interpolate numeric columns along the index\n",
    "        df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "        aligned.append(df2_interp)\n",
    "    result = pd.concat(aligned, axis=1)\n",
    "    local_results[shortnames[x]] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 539,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0/reward/reward_min</th>\n",
       "      <th>1/reward/reward_min</th>\n",
       "      <th>2/reward/reward_min</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>660000.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>690000.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720000.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750000.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>780000.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>143160000.0</th>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>143190000.0</th>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>143220000.0</th>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>143250000.0</th>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>143280000.0</th>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "      <td>4.820138</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>4647 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0/reward/reward_min  1/reward/reward_min  2/reward/reward_min\n",
       "660000.0                0.000000             0.000000             0.000000\n",
       "690000.0                0.000000             0.000000             0.000000\n",
       "720000.0                0.000000             0.000000             0.000000\n",
       "750000.0                0.000000             0.000000             0.000000\n",
       "780000.0                0.000000             0.000000             0.000000\n",
       "...                          ...                  ...                  ...\n",
       "143160000.0             4.820138             4.820138             4.820138\n",
       "143190000.0             4.820138             4.820138             4.820138\n",
       "143220000.0             4.820138             4.820138             4.820138\n",
       "143250000.0             4.820138             4.820138             4.820138\n",
       "143280000.0             4.820138             4.820138             4.820138\n",
       "\n",
       "[4647 rows x 3 columns]"
      ]
     },
     "execution_count": 539,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tmp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 533,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['0/global_step',\n",
       " '0/len/len',\n",
       " '0/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '0/reward/reward_min',\n",
       " '1/global_step',\n",
       " '1/len/len',\n",
       " '1/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '1/reward/reward_min',\n",
       " '2/global_step',\n",
       " '2/len/len',\n",
       " '2/policy_stats/avg_z_00_openfield_map2_fixed_loc3_dmlab_raw_score',\n",
       " '2/reward/reward_min']"
      ]
     },
     "execution_count": 533,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filtered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def darken_rgb(color, factor=0.7):\n",
    "    \"\"\"\n",
    "    Darken a color by linearly scaling its RGB channels.\n",
    "    color : any Matplotlib‐compatible color spec (name, hex, etc.)\n",
    "    factor: <1 for darker, >1 for lighter\n",
    "    \"\"\"\n",
    "    if type(color)==tuple:\n",
    "        # If color is already an RGB tuple, just use it\n",
    "        rgb = color\n",
    "    else:\n",
    "        rgb = to_rgb(color)\n",
    "    dark_rgb = tuple(max(0, c * factor) for c in rgb)\n",
    "    if len(dark_rgb)== 4:\n",
    "        # If color is RGBA, convert to RGB\n",
    "        dark_rgb=dark_rgb[0:3]\n",
    "\n",
    "    return dark_rgb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 621,
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib.colors import LinearSegmentedColormap, to_rgb\n",
    "\n",
    "def darken_cmap(cmap, factor=0.8, n_shades=256):\n",
    "    \"\"\"\n",
    "    Return a new colormap which is the input cmap darkened by the given factor.\n",
    "    \n",
    "    cmap      : a Matplotlib Colormap instance (or name)\n",
    "    factor    : <1 makes it darker, >1 makes it lighter\n",
    "    n_shades  : number of discrete samples to generate\n",
    "    \"\"\"\n",
    "    # 1) Grab n_shades RGBA samples from the original\n",
    "    base = plt.get_cmap(cmap)\n",
    "    colors = base(np.linspace(0, 1, n_shades))[:, :3]  # drop alpha\n",
    "\n",
    "    # 2) Darken each RGB tuple\n",
    "    darkened = np.clip(colors * factor, 0, 1)\n",
    "\n",
    "    # 3) Build a new colormap (preserve alpha=1)\n",
    "    new_cmap = LinearSegmentedColormap.from_list(\n",
    "        f\"{base.name}_dark{factor}\", \n",
    "        np.hstack([darkened, np.ones((n_shades,1))])\n",
    "    )\n",
    "    return new_cmap\n",
    "\n",
    "# Example usage:\n",
    "orig = plt.cm.Dark2\n",
    "cmap = darken_cmap(orig, factor=0.7)\n",
    "cmap = cmap.resampled(5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 622,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHHRFWHRUaXRsZQBEYXJrMl9kYXJrMC43IGNvbG9ybWFwRmzKagAAACJ0RVh0RGVzY3JpcHRpb24ARGFyazJfZGFyazAuNyBjb2xvcm1hcNs8JC8AAAAwdEVYdEF1dGhvcgBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ7rJ3hAAAAAydEVYdFNvZnR3YXJlAE1hdHBsb3RsaWIgdjMuNy4zLCBodHRwczovL21hdHBsb3RsaWIub3JnlG9BNwAAAVBJREFUeJzt1sENQUEAAFFcnejARR9KEH0oTh0akHylCA2sq5XMexXMcdb76+W94i+dn9vZCQzsXsvsBAYOx/vsBAZuj9PsBL7YzA4AAH7PAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAI+gAnrghUGiBB9AAAAABJRU5ErkJggg==",
      "text/html": [
       "<div style=\"vertical-align: middle;\"><strong>Dark2_dark0.7</strong> </div><div class=\"cmap\"><img alt=\"Dark2_dark0.7 colormap\" title=\"Dark2_dark0.7\" style=\"border: 1px solid #555;\" src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHHRFWHRUaXRsZQBEYXJrMl9kYXJrMC43IGNvbG9ybWFwRmzKagAAACJ0RVh0RGVzY3JpcHRpb24ARGFyazJfZGFyazAuNyBjb2xvcm1hcNs8JC8AAAAwdEVYdEF1dGhvcgBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ7rJ3hAAAAAydEVYdFNvZnR3YXJlAE1hdHBsb3RsaWIgdjMuNy4zLCBodHRwczovL21hdHBsb3RsaWIub3JnlG9BNwAAAVBJREFUeJzt1sENQUEAAFFcnejARR9KEH0oTh0akHylCA2sq5XMexXMcdb76+W94i+dn9vZCQzsXsvsBAYOx/vsBAZuj9PsBL7YzA4AAH7PAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAIMgAAEGQAACDIAABAkAEAgCADAABBBgAAggwAAAQZAAAI+gAnrghUGiBB9AAAAABJRU5ErkJggg==\"></div><div style=\"vertical-align: middle; max-width: 514px; display: flex; justify-content: space-between;\"><div style=\"float: left;\"><div title=\"#136f53ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #136f53ff;\"></div> under</div><div style=\"margin: 0 auto; display: inline-block;\">bad <div title=\"#00000000\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #00000000;\"></div></div><div style=\"float: right;\">over <div title=\"#474747ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #474747ff;\"></div></div>"
      ],
      "text/plain": [
       "<matplotlib.colors.LinearSegmentedColormap at 0x76a84b89cac0>"
      ]
     },
     "execution_count": 622,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cmap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 652,
   "metadata": {},
   "outputs": [],
   "source": [
    "orig = plt.cm.rainbow\n",
    "cmap = darken_cmap(orig, factor=0.7)\n",
    "colors = cmap.resampled(5)(np.arange(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 653,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHnRFWHRUaXRsZQByYWluYm93X2RhcmswLjcgY29sb3JtYXDJZS8vAAAAJHRFWHREZXNjcmlwdGlvbgByYWluYm93X2RhcmswLjcgY29sb3JtYXAD2cZAAAAAMHRFWHRBdXRob3IATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcme6yd4QAAAAMnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ5RvQTcAAAIGSURBVHic7dZBboMwFEXRT7LKbrP7K+6EINXGgSSdvXMmkem3DYNKd/mq71ZVtd6qqqpa99s/X+/vzrXjucf6Pnk+rNvTe8bvOLn38lx7un/t/j48X168d7l6Xjc3eb4ux9/RtnuWbX3r1su277bt29fDXNvmuvU2v8z2T84f9k/W1+f6eydzdXJeTfbv+x7ndPure4/unOHeOt43PN/Xk++ov+/T7xv2T87fn7erc5N722zu+PzHfL9/OK9139G682f3zuYmz/f3O507OW89mVuf7/t4blvXtq61+/2v56d/X9877+Pfyb2v/v68ef5032z+4vu+eO7j/wUACCIAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQL829V1Az5wEiwAAAABJRU5ErkJggg==",
      "text/html": [
       "<div style=\"vertical-align: middle;\"><strong>rainbow_dark0.7</strong> </div><div class=\"cmap\"><img alt=\"rainbow_dark0.7 colormap\" title=\"rainbow_dark0.7\" style=\"border: 1px solid #555;\" src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHnRFWHRUaXRsZQByYWluYm93X2RhcmswLjcgY29sb3JtYXDJZS8vAAAAJHRFWHREZXNjcmlwdGlvbgByYWluYm93X2RhcmswLjcgY29sb3JtYXAD2cZAAAAAMHRFWHRBdXRob3IATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcme6yd4QAAAAMnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHYzLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZ5RvQTcAAAIGSURBVHic7dZBboMwFEXRT7LKbrP7K+6EINXGgSSdvXMmkem3DYNKd/mq71ZVtd6qqqpa99s/X+/vzrXjucf6Pnk+rNvTe8bvOLn38lx7un/t/j48X168d7l6Xjc3eb4ux9/RtnuWbX3r1su277bt29fDXNvmuvU2v8z2T84f9k/W1+f6eydzdXJeTfbv+x7ndPure4/unOHeOt43PN/Xk++ov+/T7xv2T87fn7erc5N722zu+PzHfL9/OK9139G682f3zuYmz/f3O507OW89mVuf7/t4blvXtq61+/2v56d/X9877+Pfyb2v/v68ef5032z+4vu+eO7j/wUACCIAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQAIAAAIJAAAIJAAAIJAAAIBAAgAAAgkAAAgkAAAgkAAAgEACAAACCQAACCQAACCQAACAQL829V1Az5wEiwAAAABJRU5ErkJggg==\"></div><div style=\"vertical-align: middle; max-width: 514px; display: flex; justify-content: space-between;\"><div style=\"float: left;\"><div title=\"#5900b2ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #5900b2ff;\"></div> under</div><div style=\"margin: 0 auto; display: inline-block;\">bad <div title=\"#00000000\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #00000000;\"></div></div><div style=\"float: right;\">over <div title=\"#b20000ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #b20000ff;\"></div></div>"
      ],
      "text/plain": [
       "<matplotlib.colors.LinearSegmentedColormap at 0x76a85a752d60>"
      ]
     },
     "execution_count": 653,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cmap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 647,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors[0]= list(darken_rgb('C0', factor=0.7))+[1]\n",
    "colors[1]= list(darken_rgb('C0', factor=0.5))+[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 654,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_list= [colors[0],colors[0],colors[-1],colors[-1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 655,
   "metadata": {},
   "outputs": [],
   "source": [
    "custom_cmap = mpl.colors.ListedColormap(new_list, name='local_training')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 656,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHXRFWHRUaXRsZQBsb2NhbF90cmFpbmluZyBjb2xvcm1hcMYcjYcAAAAjdEVYdERlc2NyaXB0aW9uAGxvY2FsX3RyYWluaW5nIGNvbG9ybWFwwDdodgAAADB0RVh0QXV0aG9yAE1hdHBsb3RsaWIgdjMuNy4zLCBodHRwczovL21hdHBsb3RsaWIub3JnusneEAAAADJ0RVh0U29mdHdhcmUATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmeUb0E3AAABLklEQVR4nO3WMQGAMBDAwIJA9trEIHXBD7lTkDHXXu+3gKS9nukEYMg9HQAA/M8AAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAg6cRADMWWmRP0AAAAASUVORK5CYII=",
      "text/html": [
       "<div style=\"vertical-align: middle;\"><strong>local_training</strong> </div><div class=\"cmap\"><img alt=\"local_training colormap\" title=\"local_training\" style=\"border: 1px solid #555;\" src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAABACAYAAABsv8+/AAAAHXRFWHRUaXRsZQBsb2NhbF90cmFpbmluZyBjb2xvcm1hcMYcjYcAAAAjdEVYdERlc2NyaXB0aW9uAGxvY2FsX3RyYWluaW5nIGNvbG9ybWFwwDdodgAAADB0RVh0QXV0aG9yAE1hdHBsb3RsaWIgdjMuNy4zLCBodHRwczovL21hdHBsb3RsaWIub3JnusneEAAAADJ0RVh0U29mdHdhcmUATWF0cGxvdGxpYiB2My43LjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmeUb0E3AAABLklEQVR4nO3WMQGAMBDAwIJA9trEIHXBD7lTkDHXXu+3gKS9nukEYMg9HQAA/M8AAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAgyAAAQZAAAIMgAAECQAQCAIAMAAEEGAACCDAAABBkAAAg6cRADMWWmRP0AAAAASUVORK5CYII=\"></div><div style=\"vertical-align: middle; max-width: 514px; display: flex; justify-content: space-between;\"><div style=\"float: left;\"><div title=\"#5900b2ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #5900b2ff;\"></div> under</div><div style=\"margin: 0 auto; display: inline-block;\">bad <div title=\"#00000000\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #00000000;\"></div></div><div style=\"float: right;\">over <div title=\"#b20000ff\" style=\"display: inline-block; width: 1em; height: 1em; margin: 0; vertical-align: middle; border: 1px solid #555; background-color: #b20000ff;\"></div></div>"
      ],
      "text/plain": [
       "<matplotlib.colors.ListedColormap at 0x76a8863251c0>"
      ]
     },
     "execution_count": 656,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "custom_cmap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.ndimage import gaussian_filter1d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 665,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 137.5x250 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5*0.25, 2.5))\n",
    "labelnames=['orig. Rew.','new Rew.','LSTM','LSTM_dense_in']\n",
    "statsnames=[r'raw_score',r'len/len',r'reward_min']\n",
    "normalize=[10,1,4.82]\n",
    "colors=[]\n",
    "for x in range(4):\n",
    "\n",
    "    # 1) Make sure each df is indexed by the same column:\n",
    "    #    (if not already, e.g. df.set_index('Step', inplace=True))\n",
    "    # df = all_results[f\"{L}_{R}\"]\n",
    "    # df.plot(x=df.index.name or 'Index', title=f'L={L}, R={R}',legend=False,ax=ax[i],)    \n",
    "    for i in range(3):\n",
    "        tmp = local_results[shortnames[x]].filter(regex=statsnames[i]).copy()\n",
    "        # tmpdf=all_results[f\"{L}_{R}\"].filter(regex=statsnames[0]).copy()\n",
    "        # tmp = tmp.groupby(rand_labels, axis=1).mean()\n",
    "        means = tmp.mean(axis=1)\n",
    "        # for key in tmp.columns:\n",
    "        #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "        means=gaussian_filter1d(means, axis=0, sigma=100,mode='nearest')\n",
    "        means=means/normalize[i]\n",
    "\n",
    "\n",
    "        ax[i].plot(local_results[shortnames[x]].index, means, color=custom_cmap(x),linestyle='--'if x%2==1 else None,lw=0.75)#, color=f'C{i}')\n",
    "\n",
    "\n",
    "ax[2].set_xlabel('Environment Frames')\n",
    "# ax[0].set_ylabel('Success Rate')\n",
    "# ax[1].set_ylabel('Trajectory Length (frames)')\n",
    "# ax[2].set_ylabel('100 consecutive success')\n",
    "# ax[0].set_ylabel('Success Rate')#,fontsize=8)\n",
    "# ax[1].set_ylabel('Episode frames')#,fontsize=8)\n",
    "# ax[2].set_ylabel('consecutive \\n100 success')#,fontsize=8)\n",
    "ax[0].set_xticks([])\n",
    "ax[1].set_xticks([])\n",
    "# set xtick length to 0\n",
    "ax[0].tick_params(axis='x', length=0)\n",
    "ax[1].tick_params(axis='x', length=0)\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top','right']].set_visible(False)\n",
    "i=0\n",
    "for x in range(4):\n",
    "    ax[0].plot([], [], color=custom_cmap(x),linestyle='--'if x%2==1 else None, label=labelnames[x])\n",
    "    i+=1\n",
    "\n",
    "ax[0].legend(frameon=False,loc='upper left',bbox_to_anchor=(0.97, 1))\n",
    "fig.savefig('/home/<johndoe>/Neuripsfigs/local_training_small.svg',bbox_inches='tight',dpi=300)\n",
    "# ax[].set_ylabel('Mean ± SD')\n",
    "# ax.set_title('Per-row mean and standard deviation')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rand_labels =[]\n",
    "for i in range(6):\n",
    "    rand_labels+=[f\"rand_{i}\"]*4"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Tech Grid"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "runs = api.runs(\"<your_wandb_ID>/SF_dmlab_NEMO_tech_grid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "SF_dmlab_NEMO_tech_grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1081,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs = api.runs(\"<your_wandb_ID>/SF_dmlab_NEMO_tech_grid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1083,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['0/global_step',\n",
       " '0/len/len',\n",
       " '0/policy_stats/avg_z_00_openfield_map2_fixed_newmap1_dmlab_raw_score',\n",
       " '0/reward/reward_min',\n",
       " '1/global_step',\n",
       " '1/len/len',\n",
       " '1/policy_stats/avg_z_00_openfield_map2_fixed_newmap1_dmlab_raw_score',\n",
       " '1/reward/reward_min',\n",
       " '2/global_step',\n",
       " '2/len/len',\n",
       " '2/policy_stats/avg_z_00_openfield_map2_fixed_newmap1_dmlab_raw_score',\n",
       " '2/reward/reward_min',\n",
       " '3/global_step',\n",
       " '3/len/len',\n",
       " '3/policy_stats/avg_z_00_openfield_map2_fixed_newmap1_dmlab_raw_score',\n",
       " '3/reward/reward_min']"
      ]
     },
     "execution_count": 1083,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filtered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "37_hippo2025__e.fra_4_see_0_n.pol_4_H.L_64_r.siz_1149_20250503_191243_995501 64\n",
      "49_hippo2025__e.fra_4_see_2222_n.pol_4_H.L_64_r.siz_1149_20250505_000148_144620 64\n",
      "43_hippo2025__e.fra_4_see_1111_n.pol_4_H.L_64_r.siz_1149_20250505_000148_328278 64\n",
      "55_hippo2025__e.fra_4_see_7777_n.pol_4_H.L_64_r.siz_1149_20250505_002946_524207 64\n",
      "61_hippo2025__e.fra_4_see_8888_n.pol_4_H.L_64_r.siz_1149_20250505_004114_074337 64\n",
      "67_hippo2025__e.fra_4_see_9999_n.pol_4_H.L_64_r.siz_1149_20250505_005244_908356 64\n",
      "39_hippo2025__e.fra_4_see_0_n.pol_8_H.L_64_r.siz_1149_20250503_191913_285101 64\n",
      "51_hippo2025__e.fra_4_see_2222_n.pol_8_H.L_64_r.siz_1149_20250505_000146_604290 64\n",
      "45_hippo2025__e.fra_4_see_1111_n.pol_8_H.L_64_r.siz_1149_20250505_000148_333201 64\n",
      "57_hippo2025__e.fra_4_see_7777_n.pol_8_H.L_64_r.siz_1149_20250505_002946_523519 64\n",
      "63_hippo2025__e.fra_4_see_8888_n.pol_8_H.L_64_r.siz_1149_20250505_004613_896391 64\n",
      "69_hippo2025__e.fra_4_see_9999_n.pol_8_H.L_64_r.siz_1149_20250505_005313_264613 64\n",
      "41_hippo2025__e.fra_4_see_0_n.pol_16_H.L_64_r.siz_1149_20250505_000147_009999 64\n",
      "47_hippo2025__e.fra_4_see_1111_n.pol_16_H.L_64_r.siz_1149_20250505_000147_361796 64\n",
      "53_hippo2025__e.fra_4_see_2222_n.pol_16_H.L_64_r.siz_1149_20250505_002647_346694 64\n",
      "59_hippo2025__e.fra_4_see_7777_n.pol_16_H.L_64_r.siz_1149_20250505_003414_788545 64\n",
      "65_hippo2025__e.fra_4_see_8888_n.pol_16_H.L_64_r.siz_1149_20250505_004847_723109 64\n",
      "71_hippo2025__e.fra_4_see_9999_n.pol_16_H.L_64_r.siz_1149_20250505_005814_288585 64\n",
      "36_hippo2025__e.fra_4_see_0_n.pol_4_H.L_8_r.siz_253_20250503_191143_918035 8\n",
      "42_hippo2025__e.fra_4_see_1111_n.pol_4_H.L_8_r.siz_253_20250505_000147_010164 8\n",
      "48_hippo2025__e.fra_4_see_2222_n.pol_4_H.L_8_r.siz_253_20250505_000147_365306 8\n",
      "54_hippo2025__e.fra_4_see_7777_n.pol_4_H.L_8_r.siz_253_20250505_002946_665409 8\n",
      "60_hippo2025__e.fra_4_see_8888_n.pol_4_H.L_8_r.siz_253_20250505_004015_032381 8\n"
     ]
    }
   ],
   "source": [
    "result_grid=dict()\n",
    "for skip in [4,8]:\n",
    "    for L in [64, 8]:\n",
    "        for num_policies in [4,8,16]:\n",
    "        \n",
    "            dfs=[]\n",
    "            for run in runs:\n",
    "                cols = pd.Series(run.summary.keys())\n",
    "\n",
    "                # build your regex: contains “raw” OR ends with reward_min, len/len, or global_step\n",
    "                regex = r'raw|reward_min$|len/len$|global_step$'\n",
    "\n",
    "                filtered = cols[cols.str.contains(regex, regex=True)].tolist()\n",
    "                if run.config['Hippo_L'] == L and run.config['Hippo_R']== 8 and run.config['env_frameskip'] == skip and run.config['num_policies'] == num_policies:\n",
    "                    print(run.name,run.config['Hippo_L'])\n",
    "                    for j in range(1,4):\n",
    "                        for i in range(4):\n",
    "                            tmpdf2 = run.history(keys=filtered[i*4:i*4+j+1:j],samples=100000,pandas=True)\n",
    "                            tmpdf=tmpdf2.groupby(tmpdf2[filtered[i*4]].apply(lambda x: 30000*(x//30000)))[filtered[i*4+j]].mean().reset_index(name=filtered[i*4+j])\n",
    "                            # tmpdf.index.name=filtered[i*4]\n",
    "                            dfs.append(tmpdf)\n",
    "            for df in dfs:\n",
    "                df.set_index(df.columns[0], inplace=True, drop=True)\n",
    "\n",
    "            # 2) Build the union of all indices\n",
    "            union_idx = dfs[0].index\n",
    "            for df in dfs[1:]:\n",
    "                union_idx = union_idx.union(df.index)\n",
    "\n",
    "            # 3) Reindex + interpolate each DataFrame\n",
    "            aligned = []\n",
    "            for df in dfs:\n",
    "                # Reindex to the full union (creates NaNs where missing)\n",
    "                df2 = df.reindex(union_idx)\n",
    "                # Interpolate numeric columns along the index\n",
    "                df2_interp = df2.interpolate(method='index', limit_direction='both')\n",
    "                aligned.append(df2_interp)\n",
    "\n",
    "            # Now every df in `aligned` has the same index = union_idx, with NaNs filled.\n",
    "            # You can concat or merge them directly:\n",
    "            result = pd.concat(aligned, axis=1)\n",
    "            result_grid[f\"{skip}_{L}_{num_policies}\"] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,ax=plt.subplots(3,1,figsize=(5.5, 2*3))\n",
    "\n",
    "statsnames=[r'raw_score',r'len/len',r'reward_min']\n",
    "normalize=[10,1,4.82]\n",
    "num_policies=4\n",
    "colors=[]\n",
    "for L in [64, 8]:\n",
    "    for num_policies in [4,8,16]:\n",
    "\n",
    "    # 1) Make sure each df is indexed by the same column:\n",
    "    #    (if not already, e.g. df.set_index('Step', inplace=True))\n",
    "    # df = all_results[f\"{L}_{R}\"]\n",
    "    # df.plot(x=df.index.name or 'Index', title=f'L={L}, R={R}',legend=False,ax=ax[i],)    \n",
    "        for i in range(3):\n",
    "            tmp=result_grid[f\"{skip}_{L}_{num_policies}\"] .filter(regex=statsnames[i]).copy()\n",
    "            # for key in tmp.columns:\n",
    "            #     tmp[key]=gaussian_filter1d(tmp[key].values, sigma=10000,mode='nearest')\n",
    "            tmp=gaussian_filter1d(tmp, axis=0, sigma=300,mode='nearest')\n",
    "            tmp=tmp/normalize[i]\n",
    "            means = tmp.mean(axis=1)\n",
    "            stds  = tmp.std(axis=1)/np.sqrt(24)\n",
    "\n",
    "            ax[i].plot(result_grid[f\"{skip}_{L}_{num_policies}\"].index, means)#, color=f'C{i}')\n",
    "\n",
    "            # 2) draw a translucent band between mean–std and mean+std\n",
    "            ax[i].fill_between(\n",
    "                result_grid[f\"{skip}_{L}_{num_policies}\"].index,\n",
    "                means - stds,\n",
    "                means + stds,\n",
    "                # color=f'C{i}',    # match the line color\n",
    "                alpha=0.2,     # control the band’s opacity\n",
    "                # label='±1 std'\n",
    "            )\n",
    "\n",
    "\n",
    "ax[2].set_xlabel('Environment Frames')\n",
    "ax[0].set_ylabel('Success Rate')\n",
    "ax[1].set_ylabel('Trajectory Length (frames)')\n",
    "ax[2].set_ylabel('100 consecutive success')\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines[['top','right']].set_visible(False)\n",
    "i=0\n",
    "for L,R in zip([64,16,1,1],[8,8,8,1]):\n",
    "    ax[0].plot([], [], color=f'C{i}', label=f\"L={L}, R={R}\")\n",
    "    i+=1\n",
    "ax[0].legend(frameon=False)\n",
    "# fig.savefig('/home/<johndoe>/Neuripsfigs/HippoL_HippoR.svg',bbox_inches='tight',dpi=300)\n",
    "# ax[].set_ylabel('Mean ± SD')\n",
    "# ax.set_title('Per-row mean and standard deviation')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
