{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# imports\n",
    "from tueplots import bundles\n",
    "import wandb\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import figsizes\n",
    "\n",
    "import sys\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "sys.path.insert(0, '.')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "from analysis import sweep2df"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/Cellar/python@3.9/3.9.6/Frameworks/Python.framework/Versions/3.9/lib/python3.9/_collections_abc.py:940: MatplotlibDeprecationWarning: Support for setting the 'text.latex.preamble' or 'pgf.preamble' rcParam to a list of strings is deprecated since 3.3 and will be removed two minor releases later; set it to a single string instead.\n",
      "  self[key] = other[key]\n"
     ]
    }
   ],
   "source": [
    "plt.rcParams.update(bundles.neurips2022(usetex=True))\n",
    "plt.rcParams.update({\n",
    "    'text.latex.preamble': [r'\\usepackage{amsfonts}', # mathbb\n",
    "                            r'\\usepackage{amsmath}'] # boldsymbol\n",
    "})"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Data loading"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# Constants\n",
    "ENTITY = \"ima-vae\"\n",
    "PROJECT = \"priors\"\n",
    "SWEEP_ID = \"k2u5yzbe\"\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "api = wandb.Api(timeout=200)\n",
    "runs = api.runs(ENTITY + \"/\" + PROJECT)\n",
    "sweep = api.sweep(f\"{ENTITY}/{PROJECT}/{SWEEP_ID}\")\n",
    "filename = f\"mlp_sweep_{SWEEP_ID}.csv\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "pycharm": {
     "name": "#%%\n",
     "is_executing": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Encountered a faulty run with ID autumn-sweep-49\n",
      "Encountered a faulty run with ID lemon-sweep-48\n",
      "Encountered a faulty run with ID fancy-sweep-47\n",
      "Encountered a faulty run with ID cosmic-sweep-46\n",
      "Encountered a faulty run with ID rare-sweep-45\n",
      "Encountered a faulty run with ID still-sweep-44\n",
      "Encountered a faulty run with ID winter-sweep-40\n",
      "Encountered a faulty run with ID daily-sweep-39\n"
     ]
    }
   ],
   "source": [
    "runs_df = sweep2df(sweep.runs, filename, save=True, load=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "outputs": [],
   "source": [
    "runs_df = runs_df[runs_df.gamma_square <= 1e5]"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Data inspection"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "outputs": [
    {
     "data": {
      "text/plain": "             cima4min_neg_elbo                                          \\\n                         count      mean       std       min       25%   \ngamma_square                                                             \n10.0                      20.0  0.000323  0.000192  0.000081  0.000206   \n100.0                     20.0  0.000080  0.000047  0.000044  0.000049   \n1000.0                    20.0  0.000085  0.000036  0.000038  0.000061   \n10000.0                   20.0  0.000194  0.000122  0.000070  0.000122   \n100000.0                  20.0  0.002921  0.004313  0.000150  0.000670   \n1000000.0                 20.0  0.011433  0.014424  0.000535  0.003817   \n\n                                            \n                   50%       75%       max  \ngamma_square                                \n10.0          0.000280  0.000422  0.000786  \n100.0         0.000068  0.000087  0.000239  \n1000.0        0.000069  0.000124  0.000152  \n10000.0       0.000150  0.000206  0.000508  \n100000.0      0.001527  0.002333  0.015286  \n1000000.0     0.007682  0.013934  0.067504  ",
      "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 tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">cima4min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>0.000323</td>\n      <td>0.000192</td>\n      <td>0.000081</td>\n      <td>0.000206</td>\n      <td>0.000280</td>\n      <td>0.000422</td>\n      <td>0.000786</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>0.000080</td>\n      <td>0.000047</td>\n      <td>0.000044</td>\n      <td>0.000049</td>\n      <td>0.000068</td>\n      <td>0.000087</td>\n      <td>0.000239</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>20.0</td>\n      <td>0.000085</td>\n      <td>0.000036</td>\n      <td>0.000038</td>\n      <td>0.000061</td>\n      <td>0.000069</td>\n      <td>0.000124</td>\n      <td>0.000152</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>20.0</td>\n      <td>0.000194</td>\n      <td>0.000122</td>\n      <td>0.000070</td>\n      <td>0.000122</td>\n      <td>0.000150</td>\n      <td>0.000206</td>\n      <td>0.000508</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>0.002921</td>\n      <td>0.004313</td>\n      <td>0.000150</td>\n      <td>0.000670</td>\n      <td>0.001527</td>\n      <td>0.002333</td>\n      <td>0.015286</td>\n    </tr>\n    <tr>\n      <th>1000000.0</th>\n      <td>20.0</td>\n      <td>0.011433</td>\n      <td>0.014424</td>\n      <td>0.000535</td>\n      <td>0.003817</td>\n      <td>0.007682</td>\n      <td>0.013934</td>\n      <td>0.067504</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs_df[[ \"cima4min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "outputs": [
    {
     "data": {
      "text/plain": "             mcc4min_neg_elbo                                          \\\n                        count      mean       std       min       25%   \ngamma_square                                                            \n10.0                     20.0  0.772567  0.069567  0.657052  0.718902   \n100.0                    20.0  0.817722  0.070872  0.690639  0.764773   \n1000.0                   20.0  0.820650  0.074847  0.673085  0.781316   \n10000.0                  20.0  0.819645  0.075730  0.677624  0.774213   \n100000.0                 20.0  0.819170  0.073330  0.687830  0.777809   \n1000000.0                20.0  0.818180  0.073318  0.700416  0.778697   \n\n                                            \n                   50%       75%       max  \ngamma_square                                \n10.0          0.787214  0.803759  0.913309  \n100.0         0.829019  0.861029  0.967725  \n1000.0        0.835685  0.866475  0.973323  \n10000.0       0.845035  0.867481  0.968253  \n100000.0      0.834189  0.870567  0.966177  \n1000000.0     0.830764  0.869964  0.965708  ",
      "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 tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">mcc4min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>0.772567</td>\n      <td>0.069567</td>\n      <td>0.657052</td>\n      <td>0.718902</td>\n      <td>0.787214</td>\n      <td>0.803759</td>\n      <td>0.913309</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>0.817722</td>\n      <td>0.070872</td>\n      <td>0.690639</td>\n      <td>0.764773</td>\n      <td>0.829019</td>\n      <td>0.861029</td>\n      <td>0.967725</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>20.0</td>\n      <td>0.820650</td>\n      <td>0.074847</td>\n      <td>0.673085</td>\n      <td>0.781316</td>\n      <td>0.835685</td>\n      <td>0.866475</td>\n      <td>0.973323</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>20.0</td>\n      <td>0.819645</td>\n      <td>0.075730</td>\n      <td>0.677624</td>\n      <td>0.774213</td>\n      <td>0.845035</td>\n      <td>0.867481</td>\n      <td>0.968253</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>0.819170</td>\n      <td>0.073330</td>\n      <td>0.687830</td>\n      <td>0.777809</td>\n      <td>0.834189</td>\n      <td>0.870567</td>\n      <td>0.966177</td>\n    </tr>\n    <tr>\n      <th>1000000.0</th>\n      <td>20.0</td>\n      <td>0.818180</td>\n      <td>0.073318</td>\n      <td>0.700416</td>\n      <td>0.778697</td>\n      <td>0.830764</td>\n      <td>0.869964</td>\n      <td>0.965708</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs_df[[ \"mcc4min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "outputs": [
    {
     "data": {
      "text/plain": "             min_neg_elbo                                                    \\\n                    count      mean       std       min       25%       50%   \ngamma_square                                                                  \n10.0                 20.0  4.263436  0.002470  4.258281  4.261927  4.263021   \n100.0                20.0  4.276257  0.005615  4.267282  4.271860  4.276455   \n1000.0               20.0  4.329178  0.021063  4.294472  4.311069  4.327895   \n10000.0              20.0  4.504620  0.079485  4.392209  4.443849  4.498628   \n100000.0             20.0  5.145434  0.364360  4.777776  4.901717  5.043657   \n1000000.0            20.0  8.800124  2.260568  6.828425  7.397291  8.272244   \n\n                                   \n                   75%        max  \ngamma_square                       \n10.0          4.265005   4.268206  \n100.0         4.278580   4.288528  \n1000.0        4.343697   4.373414  \n10000.0       4.560320   4.651727  \n100000.0      5.209848   6.169360  \n1000000.0     9.172992  16.827099  ",
      "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 tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>4.263436</td>\n      <td>0.002470</td>\n      <td>4.258281</td>\n      <td>4.261927</td>\n      <td>4.263021</td>\n      <td>4.265005</td>\n      <td>4.268206</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>4.276257</td>\n      <td>0.005615</td>\n      <td>4.267282</td>\n      <td>4.271860</td>\n      <td>4.276455</td>\n      <td>4.278580</td>\n      <td>4.288528</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>20.0</td>\n      <td>4.329178</td>\n      <td>0.021063</td>\n      <td>4.294472</td>\n      <td>4.311069</td>\n      <td>4.327895</td>\n      <td>4.343697</td>\n      <td>4.373414</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>20.0</td>\n      <td>4.504620</td>\n      <td>0.079485</td>\n      <td>4.392209</td>\n      <td>4.443849</td>\n      <td>4.498628</td>\n      <td>4.560320</td>\n      <td>4.651727</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>5.145434</td>\n      <td>0.364360</td>\n      <td>4.777776</td>\n      <td>4.901717</td>\n      <td>5.043657</td>\n      <td>5.209848</td>\n      <td>6.169360</td>\n    </tr>\n    <tr>\n      <th>1000000.0</th>\n      <td>20.0</td>\n      <td>8.800124</td>\n      <td>2.260568</td>\n      <td>6.828425</td>\n      <td>7.397291</td>\n      <td>8.272244</td>\n      <td>9.172992</td>\n      <td>16.827099</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "runs_df[[ \"min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Data Pre-processing"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "$$ \\sigma_k^2 (x) = \\left(-n''(\\mu_k^\\phi(x)) + \\gamma^2 \\left\\Vert \\left[ J_f(g(x))\\right]_{:k}\\right\\Vert^2\\right)^{-1} $$"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "outputs": [],
   "source": [
    "df_rhs = pd.DataFrame(runs_df[[col for col in runs_df.columns if \"rhs\" in col]].stack().droplevel(1), columns=[\"rhs\"])\n",
    "df_lhs = pd.DataFrame(runs_df[[col for col in runs_df.columns if \"sigma\" in col]].stack().droplevel(1), columns=[\"lhs\"])\n",
    "df_rhs_lhs_gamma_sq = df_rhs.merge( df_lhs, left_index=True, right_index=True).merge(runs_df[\"gamma_square\"], left_index=True, right_index=True)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [],
   "source": [
    "df_mse_sources_mean_decoded_sources = pd.DataFrame(runs_df[[col for col in runs_df.columns if col == \"mse_sources_mean_decoded_sources\"]].stack().droplevel(1), columns=[\"mse_sources_mean_decoded_sources\"])\n",
    "df_mse_obs_decoded_mean_latents = pd.DataFrame(runs_df[[col for col in runs_df.columns if col == \"mse_obs_decoded_mean_latents\"]].stack().droplevel(1), columns=[\"mse_obs_decoded_mean_latents\"])\n",
    "df_mse_gamma_sq = df_mse_sources_mean_decoded_sources.merge( df_mse_obs_decoded_mean_latents, left_index=True, right_index=True).merge(runs_df[\"gamma_square\"], left_index=True, right_index=True)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Plot"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "outputs": [],
   "source": [
    "log10 = \"\\log_{10}\"\n",
    "x = r\"{\\boldsymbol{x}}\"\n",
    "gsq = \"\\gamma^2\"\n",
    "phi = r\"{\\boldsymbol{\\phi}}\"\n"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_71233/799380064.py:45: MatplotlibDeprecationWarning: Starting from Matplotlib 3.6, colorbar() will steal space from the mappable's axes, rather than from the current axes, to place the colorbar.  To silence this warning, explicitly pass the 'ax' argument to colorbar().\n",
      "  cbar = fig.colorbar(im)\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 396x122.371 with 4 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZQAAACCCAYAAABhPT6SAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAqi0lEQVR4nO2de3Qc1Z3nv7/u1st6yw/ZWMZ62ELBGNtCNo8Ym4cwyzCbyRDbsJlMJtlZXpPdnN0TwGZPdicnJzNgmDmT3UkmYHPyOiFDjGFn85iEIIgDzBqDLWyMCEi4W8aysWxLlvWwXt392z/qllRqVXV3dVd13Vbfzzl13KrHrZ/vvVW/ur/7u78fMTMUCoVCoUgXn9cCKBQKhWJuoBSKQqFQKBxBKRSFQqFQOIJSKAqFQqFwBKVQFAqFQuEISqEoFAqFwhGUQlEo5jhEVGb812qfYu5DRPVE9DwR3edK+WodikIxdyGihwEwgBCAVmZ+0GyflzIqMgcR1QPoZ+YBN8oPuFFoqixYsIBra2txYWAC/QMTICJULyxA8TypxMxaDh8+fJ6ZF3pxb71tFakxPBLGub5xTIYZ0aj2EVhY4EPNknkIBAiAZfu2MfM7RFQH4O44+xxBb+fRsQgujUbg9xFKSwPw+8jJ2+QsZm18jb+YBzky9fdHPN4BYMxwym5m3i1+9wOoF4qlnZmDTson1Zu6trYWhUv+HkuWAEsM+5dU+/D8MzemXf6pU6ewdOnStMtxC7flI6ITrhWegNraWhw6dCitMnKx/ZgZd9/7Jk73TmDBCvNz/upLtfj855Zbte8AEd3CzK8S0WNx9jlCbW0t7tj6I7x+sA/hMMNHQF4e4e++cTXWra5Iu/xc7ANGzNp4yBfFP1VNd44tZzvGmLnFoogWZm4jIgDYCuAJJ+WTag4l9PGw6f5PeqN47w/9aZff1dWVdhluIrt8XiN7/Tgt34u/OoUbP/MaTvdOxD3vn37YjUuXwqbHmDnEzK+K3+9Y7XOKwaFJ/O7fziMc1kZRUQbGJxhf++ujCEfSN6/nWh9IBvITAmX+qS0BQSJqBtACYHeik+0i1QhlfMK6wz3wyDG88YvNGZRGofCOJ77zAX7+Um/S57/wq1OWx4joVgAVMbsZgG6HYmZ+0aaIppw5N4ZFjbP3T0wCR98bwDVrKp24jcIA+YC8eQkVCQDAYOJqd0MWqRSKQpHrMDNefeOsLWUCACOXIpbHmPmVdOVKlmjU+tiPn+9WCsUFiAiBQjle5XJIoVAoAAD/c9f7+N2/nbd9XdOKUstjYoRSHu/6RCMUMYlbAaAV2iTvgF0Z3zk2aPcSRTIQwZ8nx+xFTimU+fPney1CXGSXz2tkr5905ev4cDAlZZIIh0Yozcy8T0zmbkcK9ncnVijM9T6QCuQD/AVyvMrlkCJDrFq1ymsR4iK7fF4je/2kK9/e/9uT+r2bklufSETfA3Acmg29Itm5E2beJ362AthnPCYWyd0HAMXlJhMogmVLgGg0itdee23Wseuvvx6hUAg1NTXo7e3FyZMnZxxfunQpampq4PP5EA6H8cYbb8wqY+PGjejs7ERdXR16enpw6tTMeaVly5ahuroaPT09qKurw4EDB2aVsWnTJnR0dKCxsRGhUAhnzpyZcby2thZVVVXo7e1FTU0NDh48OOO4ULg4evQoVq1ahc7OTpw9e3bGOfX19SgtLUV/fz+qq6tneT8GAgFs3LgR7e3tWLt2LTo6OtDX1zdLVuM9A0qhZJ4jR46gubnZazEskV0+r5G9ftKVb3IyzgREHG7dtAAL5xcke3oQmslqkIgeMjuBiLbG7Gpj5gEi0pXJDJdLscZhNwCUV11hOQ755s5m+Hw+3HTTTabHm5qaAAAlJSVoaGgwPWd8fByBQMCyjCuvvBIAsHLlSqxcuTLufazKWL169dR5+rmxlJWVmZbR3q7Nda9Zs2ZKHl2mWCorK+PKofclXR4ryEcIFCQ3Ke82OaVQZH4ZAfLLFw/xlRpk5ja37iF7/aQr31WfKsNrb1p/iZpx/xeX4wtbl9u5ZD2AnUS0F0CV2QmG0cgUQpnsgKaQXkbMKEVn2dJ5pjddND8PK+qs53mSZa73gZQggj9fjle5HDM5GcJsmCwTssuXgEOY7ZrqKLLXT7ryxfOQMuOOWxbhz7fVTplZkiQIzWwVFFtSMHMbM9/GzPebKRydwgI//uGbq1FSPP1q2dBciWefutaOjJbM9T6QCkSAL+Cf2rwkY2ot3S/YK1eaf/nYIRw2X/wlC7LLZxejbf2yyy7D/v37ZxxfvHgx6urq0NnZiVWrViW0rY+MjMwqQ7eth0IhNDY2empbHx8fR1dXl6VtffPmzXFt6+CFKCzwYWw8sWb54vYaXL/20qz6SJLj0EYnsaYtR1i/rgq/ee5GjFwKIz/PhzwHPZBkf0Y8kS9H51AOAaiP3Wl86ZSUr8TM9VbThCPjaU/ojY2NST2hNzysRQrI5ISeXazs62bnGm3rLS0tnMhmnci2XlBQkNB27qVtvbu7e6psqzLi2dZHxyL4yQtvAnEUit8HfHfXWlzVFNcLOB6PAWiANg9iOdJwAhWDLzOQRCYvz6UwvnRqLr+KzZQJAHz13qvSntArLCyUekJP/9rM5ISeXeKYO1oBzCciSwWjiE9RoR//+NgafP2xDvT1T2ByMoqIQbcE/ISHvrIyHWUCZr4IwNFwKwqPIYIvz/NXOQAXFIqdL9hYFi8qRGGhD2NjM7/QVtYVY+1VFc4IqHAFZnY0yFyusrKuBM89vQEnT4+Co8CC+fl4/8NB5Of5cOUVZY6ajxRzA/LN4RFKul+wLz13A769O4hXXj+LvADhi9svx+f+uMYR2VparAJwyoHs8nmN7PXjlHxEhMsN3lLr15k6Y+UkudIH7OL1ZLxOxtRasl+wfr8fX3twJb72oLnJKR16e3tRUlLieLlOIbt8XiN7/cSTbzLMCPYCvQMAGCgpApYtBBaWZT5PCBGVMXNWxkHJ5j7gFjSXTV4ycvgjRnsQiEaXY8jHWFsnZ7Kfqir1JRoP2evHSr5j3YxX3tVCuRshApYvZHxmgzY/kkFaATgSXTjTZGsfcBUfwZefl/n7mjDnDbJ7fsv4fQcwNAqMjPvw6rvA99vkTHs8NDTktQhSI3v9xMp3YZjxnV8yXj46W5kAWmyr7rPAwc4MCTiNnF9USZBtfSAT6CMUffOSOa1QjoQYQ6PGPdpzNDACvH9SPqUSDDqajXPOIXv96PJdGmf8y5uMH7wCTFhHlZ/incz/t+Tr/EmSLX0goxDBl5c3tXnJnFYor75rfew3rqSXUeQ6UWb8+HdA0EY6kwm51+opsgAK+Kc2L0moUIiozPivQqGw5tgJ4NK411IkJGtNXorZpGLyIqJdbsgS9+5E9DAAJqIQtIm8B90QQqGYK7z1of1r7IXiSh9mfiGzd1S4ChEokLypS+SUr3BDlEQjlDZm/jtouRPkzmwzB1i0aJHXIkiN7PWzaNEiDI/Zv66syHlZ5irZ0AcyDhEoLzC1AVhARIcM230mVw24IUqi8dEAEd3CzK8S0WNuCKCYprHROjmRQv76WV7XCO6yf90N5hF6FCbI3gc8kY8INHMy/jwzm66wFJFMggDqiaiemR31Iog7QmHmEDO/Kn6r+D8u09HR4bUIUiN7/Rw5loI2AdDkTCCIhBDRrUT0OBF9j4geI6K7MnNn55C9D3giHxHg909vcRCRTIJwyeSVtNMyEd0K4DYA5dCGS28nmz5UkRx6UEiFObLXT11DEw5+Yu+aW1bDbj4T2xBRHbQ50LeZeadxPxHdC+C4/uEoO7L3AS/kI5tzKCL01W1uyJKMl5fe6fqYeSczP8jMjwJ4h4juJaJb3BAsF/n973/vyX2J6BYiuouIysR2LxE9JJtnn1f1kyzHjr5l6/zaRcDa+szMyDPzHmY+ErMvxMx7ABzOiBAOIHsf8EQ+IiCQN715SFLrUOZKZ5QdZs/WmzUAaBfxnV4B0AdgD0SeGlnwsH6SIp9GE58kCPiAO65xURgDzBxKcPxiojKIqJ6ImonoESKqcEw4m8jeBzyTLxCY3jwk4d2NnZGIngLwEbR8CuXM/GIyndErllQAnwyYH1u+MJOSSM9xZu4monIAlbopU7iLK5KECPjMBuDnCQYqfh/w5zcDRfmZ9RdO02zdLzZAy/Y4YCjX0cycKkmezSR5+ghFAuyqs+MAdjPzIBE95IZATrJ9I/C/fml+7LPOpLieK1xDREEATwB42rA/qc8tIqqHNsnXCq1/DDgtYLawYgnh7k8zfvE2cGlC2+cjoCAAkA+oq9a8ukqLMqdMnJhDYeYBq5GJ05k5VZI8jaST5OmT8hJgV6GsB7CTiPZC+0pJCq9eOH4/4cE7GM+9DlwYBoAo5pf58B8+rR1TaDDzk+LF8jNmfkGMVLYj+ZhPzcy8T0wub4d4ueQqSxcQHrjDaylmIszTsftCAPaI9p7CLEkegFbRxm3QctGrhGqy4PAIhYjWmXn1EtGtzPxKvGvtKpQgtJzUrbC3MMazF05RPuHLt2q/R0cnUFQk7yqya6/1ZthERLXGF44wY+4hotpkrjckVWuFIU+506aQxYsXzypDN4WEQiE0NjZ6agq58sor0dXVZWoKISJs3rw5s6YQgV2ztVmSPCJqFyusW+HhB4NXz0iyeCEfg8B+R01eu4W5O/aD8gK0OVZLyM4kEhE9DuBvoY1UtjKzrVAsRPQIgH3GxTQxL51rnn322RnXOGl/PXz4MK677jpp7a/j4+O4/fbbXXvp3HzzzYfNFjwR0SFo5swZuwHUMfP6mHNNUzwTUSu0D45+sxFoS0sLx8pql66uLkszhgx4LR8RmbZvzDkPA3haN1uLSBiO4UQ7x8PrOk6E2/KZtXFzUwO/sefxqb+LN21P2A8S3CPlBGx2FUo5gHrxZ5XZ8CfVFw7gfmccHBycsn3KiNvyWb1wxEvGOMpoE7+3MvOTSZTbCmAHtPZ92ewL14m2zfX2S0SSCmUvgFsB7IX2DN/tpAxuPMPDo4zX39ciOPspijV1PmxoBPw++czWXjzDzZ9awa9/f/q7oOSGP01XodQC2AVtRLLDjuOVLZOXKDjuinmL4fKMFw4MZpFM0t/fL/ULySv5jEqDiIIGE0lCZSKub8O0EnINr+pnYmICkxMT8Pv9yMvLg9/CNVP2/iVI1WztCeOTjGd/D4xMRXD24e0u4MwA8KfXeSiYBd70AQL7HJ2UbwVwr/h9N7QlBEmRzMLGz8WzpScTvoGZ25j5Nma+30zhZIru7m5HyolEIujr68P5c+cQiSSRQSlJnJLPLjFtWG6x33MyUT/MjOGhIYSCQQSPH0fw+HH0nDyJ3t5enD59GidOnMCJ7m7Tdveq/VLgOLSArxUey5GQjo+B0YmZ+8JR4MRZ4PygfGtSPOkDpM2h6JsDhJh5UJi9bMX6SmYdygsiBtADmPZfr4Q2HDrOzM+kIHDWcuLECUTC0xmRBgc1U2O9hZtjlvAEEd0vfpP4TQDqkKW5x1OBmfHJ6dMYG4sfMjgSieDjEydQV18f9zxJeQzaQtZ+eGQpsMPxM+bpk6MMnB0AFkg/IHQfBhD1ObqgsU7MlwPax0fciXgjSUkh5kpeAbR5FJkXM7rJyMjIDGVi5ER3N5bX1mZWIOfYZuEmuM4LYbxieHg4oTLRYWZMTEwgPz/fZamcJRmztUz0x0nRfvYiYL7CI8cgQtRBLy9mfoaI1orfR+xcm1ToFWNMp1xVJgDQG+O1ZcRJ01emiRNJWj6bggsMDg7iRHc3zsV41CVifFz+1IyAM2ZrrxibtD6mrS1TMDSFom+pIuL5PSwWwgLAfMPvpEiUsbEMwDPQsjb+LNujCy9evNhrEeLipXzC0+uCbsIUXyh3AzjimVAxuFE/Q4OD6Dt/PqUYTBPj40Bp6dTfsvavbDZbR6LWx8bjKBuv8KYPEKLkyKT8ALRIGc9Ac6JqgebVm/SkvKVCES+YFgC/BfA8gG1pCCoFdXW2lG3G8Uo+YS89DqBShNTZAG10stcTgSxwo376L1xIOaBffkHBjL9l7l9z0Wx9YcRrCWbjRR9gIqfmUC6I9UnHMR27zVamXkuTl3AlfVwUug3ANpGU5yFgepic7GpqGejs7PRahLh4KN/bIqL0k9Ds6/cy890sWe5xp+uHmS3nxJJh3rx5M/6WuX/NRbO1jCMUb/oAIeLLm9rS4BoRgult0UcG7BaQKGPjOwC2QPP4eYeZHzWsrA0Ks0jsQkZpWbVqldcixMVD+SoNv1l/4chmW3e6fogIPl9S04imxF4rY/8S+W32QgulI1V7po2EM3xe9AEmQsQXmNrSYC+0hckvAoAIGPq2nQISPk3M/AC0UcrfAlosINLyy98D4H5kUSBAs7AtMuGhfDuJ6CUi+m3M711eCWSGG/VDaWRLjL1Wtv4lzNZ7oJmt74ONgK7ZAKX+LeAaXvWBCAWmtngkyGvz36GNUu7S3Ybtenkl6zb8guH3Awbh1kFbVZnVk/WK3HQbZuas9s5LhIgivQ7aeiLdbN0ALfuqozG8vGBBaeJzcgG2NylvmdcGwFvQFrzC8K8tbOl4MTKZgpnfyXbPL4W123Acd+I5QTqjk6r5tuYqPSOB2Vp6ahdZH9uoFqEICBEEpjYAC4jokGGbyrwaL3WIiDzdrW+pSGJ30Hg/EX1PbLWp3FCRPRDRWn2B01wkVe+uecXFKC8vT3yiJBjM1o8lOlc2tqzT0n3EUlIIXK6yrgLQppIi8E9tAM4zc4thm5qWIKKtQqnoeW1gOLZWvNsfT9U6YXcGZ68esl5M8HWnctNsJS8vD5OTErqWuIDw9ugXv1tkXquQKvqkfDQaZ7FDDEVFRdKuN4lHrMee+FCo4gSZGr2mpJDwZ5sYv24H+oYAgFFfTbi9Ob0R5lyCQYhw0iaveHlt5hve77emIovtFMBEdIvohFnnenj99dendX0gjkLxO5CCM135HCaopydItXM5jRv1U1lZif7+/qRGK0QU19QlWfuZIjy+yqFF/V4PQGqFAgCLKgh/cQswMcmYnJxE8byCxBd5hDd9IHmFYshFZTZHUkdEnxO/q2AjhpeOLZOXWKdQSUTfA5A4VZxkhEKhxCfFYX6cl4kTNvV05XOYfjH0laat3aifsvJyVFRWmn7tGj8SAoEAqqurUVBg/TKTrP2suBdaUMgNSCHaMBF55vmXn0c4+XH6dRwOh9F75gxCwSBCwSDOnj3rmHOGF31AM3n5praUy9GsEMehRU9IenW8EdtOy2LoLNWCt2SpqalJ6/r8/HxUVFRgYGBgxv7CoiKUlqbvcpKufE4iJnOTmpQnonpoL6dWALvjTfylgxv1Q0SorKxERUUFotEoiAjMPMMcxszw+XwJTSwytZ8VYo3RHmjrUh62c60wlVS4IVeypFvH0WgUp3p6ZiiQ4aEhjI+NoWbZsrTNaJ70ASZEos7kQ7HrJhxLyqtg7ESjzNQLJxG9vb0oKSlJq4yq+fNRXlGBgQsXEGVGRUUF8vKcifTphHxOEeN00ZzAmy+eK6JjuFk/RGRqtrSz8FGm9rNCmLyOQzN5pRJ/f8CkTGMab+zfv3/GcSfTeB89ehTXXnttymm8y8vKEA6HZymO8fFxHDx4EBs2bEgrjffExAS2bNniWhpvMxhAmJ1flENEt0ALx5K0t2dKCiWFCVvLF04mO2NXVxeWL1/uSE75Y++9N6uMdHPKDw8Po6GhIaOdMQ4PQPNLJ2i2dkuFIlI8V8Tud7ptP/roI8u2DYVCaGxsdKRtDxw4MKuMZNq2u7sb0WjUtG2JCJs3b5ahbR+DFvTzCQDNRNQC4GdGV2IySeMN7WMwCKCeiOoNtngIL6LdgJYC+KabbjK98erVqwEAVsebmpoAACUlJWiwyC80OTmJQCBgWcaVV2q+xCtXrjTN7d7X12c6CvH5fGhqaoLP55uSs6mpaUqmWPSsjLFy6H18zZo1U/LoMsVSWVlpWoZOc3MzgOl6s4Lh3AhlRrnMr4oPkO3JXmMrp/zURUS3GidszXLLm1xTAe3lss/YGY24nVN+//79lo3nJWNv/RaRo68jGo3Cv7AGBXd+Cf6CIsfvQ8nlHF9rHHWKkUq/yN5m+bJh5n269wgzPxFbrhNtm0z7RUcuItz9AcJ/OATu/wQw9u+CIuStuRF5a28EubDM2uv+lUz7xpxfDi0AbLMxDXSc8yugBYq9P1uf4fPnzk0lxYtlvrA+pIPbfcCsja9Y1cy7905/SN10VXFKOeWJqM6Q/luP/7aHme9OtoxUTV79Yml+ObRwx0ah4r1wdN/nWS+cXGXkB98CJkYBaB4SfK4HYz/8Fgq/9HVXlEoSrCeiKvF1che0aKMMLaQ1zFI4E1E8V8SMwJEwRn/5ffCZE9YnjY9i8q3fgocHUHDjn2ROOEkR8ylTUYiTOH8AwG1uyuQ2ly5dsjw2PDyctkLximjUERdqNsR7awDQZkeZACkqlHgTtrK+cGRk4pMTU8oklrGf/j2Kv/z1DEs0RYX4el3PzI8mWuSUwBUxI4y++JQ2IkmC8PtvIX/DFpA3CjvjCFfQw1arn4norlyJeBGOE106WxKmxcIghKPpj7hF/+jW/yaiW4hoXSbmUGoNfyaasJXihQNo9naZmPzNj6wPWiiaDFEltgYx7K1McH5GMLYfR8KYOPw7hDveBCaSS9trJHqxD/5FznrkyNa/dCwSbFWIf6VOsBWLrHWs44V8zHBEocwuV1v0qisVMUkfMprFYknV5JX0hK1MSOfWOSHlF1EbNO+fcmhZ2+6H5hXkOXr7MTPGfvVDRD9J3eefXYh9Ll3/MjBXEmzJXMeAd/KFnTF5WfEoEe0QZvC41gq7wSHXAgAz7xSjksMQYe2zgSxZeOYp4uujT//NzE/KYg7R2y96tgfR3o/TKosvOr9WM1v6V7YqE8DdOnYilIsnCxuZEI5Mby7QB80j8CFo0xaW2B2hxJ2wlZ3GxkavRZAe4RLeIH5LFcNLb7/ouVNANL2Vzb7KOGFsU0S2/kVET0EbbV4DQxy+bMbNOk41WKh+LQ+cx4oF5WCOuuJFaHlvABF2dYSyg7XUwGW6t6cVqfyvjRO2e6CNUrICszUKilkExQh0JwCpPrn19qPSCmjW1tTxzV+SvkAxSNi/DjPzFgA7AewWX5hZjYR1jGh/L0af+weMvvhdjP3L0xj9yROIfNKdsfszw9URiq5EEikTIDWFIuWErcIx6klLG1sGLTGTdPgWL0e6+V9zJFJtP2mZN1uhteUCj+WRmlTSQXN4EqM/fwY82AeEJ+HnCPjSEMb+9UfgS8MuSGlOODK9eYndGmyD9tVqnLCtcFgmhbfshbZOaA+09paO6MnO9PK/BpwJlSM7Iu7eNmjtWIWYNWO5SH5+vuWxwiL7buSREx8A4YnZB8KTmOzKTH46t0codrA1h8LMIWHu0idvE66uVWQXYsL2AWBqpax08MQYwMnnMIklsO5mB6WRG2a+SET3Q0v7+4wh/UROUlhYiIkJEwUAoKiw0HZ50ZFBIGK2toURHuyHtfpyDob3IxMdWwpF5glbReqIydtY0yVBM5Osz7xE8fEtSN3XnxbWoKB5s4PSZAVBAG+JdQS3IQtyoLhFSWmpZeiVefPm2S4vMnTB+mDfGetjDsIMOBR9P23senkF9Tj5siRdssPGjRu9FmEm/nwgYv61lGGeN4vHlmoaULfQ2y/a35vS9b7Lr0Dhv/uCkyLNQLr+Nc1jAB4FcA80989HoCmZdgAvZ9OHYbp1bGXy8vl8CKQQNTwa6rA8xudOWR5zEs3klZFbJcSuIVr6Cdt4dHZ2ei3CTALORwhNBavgnnZCLmSCqfZL0dzlX1LrqjundP1LwMzvMPN2ETBwB7T5lAegza20iCRqWUG6dTwyMmK6n5kxGifOlyXjcSJapOnabodwmKe2eBBRPRE1E9EjZhHC08Xu0yX9hG086urk0oH+ZXKtW5Advf38l18B+Owr48DKtQ5LNBPZ+pcZYqHqRWZ+RVgb9kFCs6YV6dax1fwJM2PCIr13XPzuOXhwJIKohbwzzuNZXl4LiOiQYbvPcHozM7dDe38nHZY+WeymAL7IzA+ICJT9CS+QjJ6eHq9FmEHejZ+1POZfLa35xDP09vMVlyH/hjtteXoF1t8GX7G7Pgay9a9kYOY2aJ5gWUG6dZyfn2/qMk5EyE8pUV68EUFqHleTg8M48qWH8euyNfh16Rq8ccM2DB79wFoCnjVCOc/MLYZt9/S5U8F7W+HCoCDhHEq2TdjG49SpU6ZJd7zCn5+PvOvvxOSBXwHQuiYBQOUiFN5wh5eiSYmx/fJWXQt/TQMm/3AY0cF++BdfDp4cR/T8afirLwcqFyLy4TugwnnIW/1p+CsXZlS+bCJesD/ZSLeOi4uL0d/XNyuHfCAQQFEKk/KIu7o+tbVSb935l7jY/j54QhsxXXz7XRy4+fPY3PEby7tEIsnfi4haoY1MHR8UJDMpnxUTttlK/tU3wN/UgvDBl9D7cQhLb98K/4LLvBYrK/CVL0DBdbdbn7D8U5kTRmKEA01FnFNYlnhtbuPz+bC0pgbnz5/HpZEREBHmFRdjwYIFqS12jWd6TWG+7mJ7B4aOfQiOMXVFJyZxYvdz5hdx4rmTKZE0ZbIDmlPGy9AUi2MkVChOTtgS0S5m3mH3urmOPz8f/hv/PYL79+PyLFYmqn3lJJmMqokgonoAu6B5hWV1TqNAIIDFixc7U1hVNXDaNHklMK/UdnEjH50ATFbsR8cnMHTsQ9NrNJNXco4qwsTp2vx3quHrbSMSbFVk6n65zLv/+Rvo+cE+8GQYhUur0bz3H1G5/mpX7+lE+0ZGx3DsK3+N0//8C7DuB0lA8RX1+NSuHUAKFgnF1Ail3Oowkh+h3CuyNioEvoIiWL7KU3AcKb2qEdExk4l4nw8V61cDL8w+pM+hyEDGFIpgIHaH8EC4DwAuu+wy7N+/f8bxxYsXo66uDp2dnVi1ahVee+21WYVef/31CIVCqKmpQW9vL06ePDnj+NKlS1FTU4O8vDyEw2HTAHMbN25EZ2cn6urq0NPTg1OnZvqQL1u2DNXV1ejp6UFdXR0OHDgwq4xNmzaho6MDjY2NCIVCOHNm5sKm2tpaVFVVobe3FzU1NTh48OCM47oHytGjR7Fq1Sp0dnbi7NmzM86pr69HaWkp+vv7UV1djdj83Zf+6m/AXdOh3cd6zuD/3bANhd/ZOUteFxgw/pFM29bW1uLYsy8isq8Nfa+9BUzEeNowMPJBEO33fBWl3/oqZpYw3bahUAiNjY2etu3ChQvR1dVl2rZEhM2bN6fVtoFAABs3bkR7ezvWrl2Ljo4O9PUlDsPvxAgFmr29XoxU2o055XP5GR45GUQhLKbfLw3h/ffft9XOPDIKDpt4m0WjCA2bZx1gZoQnU48c4SSUTshm0wItcspDs9k9Ci0UsukYsaWlhWMfIicZHh5GSUmJa+WnS7ryjX58Gq82mIcVyb9sEbZ8/MZhsRYhZVJtX2PbDn8YROh//xjD73dhtPccRrvi5IE3UHxVI2565xfpiO8qXvcvIrLVvob8Rkdi9pu1cQszt+mpvJn5CbMyc+0ZHvnpk8DQgPnBQB6K//Ibtsr75P+8hPbtXzU9tvCPNuPan++Z1cbVlzfz5x+ZVtLf/i+laT/nqeL4CMUspzyAfWIRTYXT97NDT08PmpqavBQhLunKF3rqp5bHJk6ftTxmh3Tbt/upZ9HxX78FROx/UV3qlNsZSfb+ZUSEUeoXv2eEUTJrYyIKCmXSAsCzORTZ6ti/aBkiVgql3H5w55HO7pSORW14eblJxkxewvZ6W6buZ4bsC8/Sla973786JIl9kmnf4Q+D6PjqN1OPPC/HM2OJ7P0rhqBuCksmjJJh1NnuqlQJkK2O89ZuRuT4MdNjBc032S4vHGch48SFeCYvOWKvZC6tmASY2UxlIl35OJSZ2EGpcvQ/7kxLKXAqK5kziOz9K4Z+InpchF1xPh+yS8hWx/4FS+BfsWbWft/i5fDXrbJd3sW33rU8Fh4YMt3PzAiHo1Obl2R6Ul6Rwwwcfi+9AnIiJ1ZmEG7/UsVqy1YKbtmGyIo1mHzvAC70ncfCG7YgUH9VSutaLgU/tj5oEVKYGWqEoshBoml+PVVZeb4q7EJEtYbtLq/lyWaICIHlV6Dozi+h8/IW5K24GpRC9kcAKFiyyPqg36JMYfLSNy9RCkWRMUqvviL1iwko+Mo9zgmjeABAM4BrAGzwWBaFYNmXYx3spglYfFBp+VCiU5uXKJOXImNERuKE+k6Ab14RAjc2OyhNbkJEa5n5CDPvFH/XQgvBoZCAE0//s+Wx8DnzZF7MjMikWdbIzJNTCmXTpk1eixAX2eVLl0vBk4lPsqDy2rXYIHn9ZEn7rSeiKmZ+VZi65kNzlciKJFuy13G68o18YBHGJR7Ky8sbOjqss6vJgOzypQVzWnMoq779P6SvH9nlM1BBROUA1oucKIe9FihZZK/jtOVLYe5Fm5QPT21eklMjlMZGuRNapS3fvALg0rgzwjhNKpFcdfw+lH6qAY3jkv7fBLL3LwNVYmsQ2Vdj01NIi+x1nK588xqWYbAvTp56E7R1KHKYvHJqhBIKyb3SOl35AvOKHZJELvyFBQDmfvtliDYAIWjBIncAuB9ZFLRV9jpOV76aL3zW8li+hQcYgxGNRKY2L8kphRIb6E020pWv5MoVDkkiF3mVmnfLXG+/TCCSafXpv0VK4KzJhSJ7HacrX9Fl1Zaj+aobrzG/SIxQZDB55ZRCmetc98s4IZaKCjIniAWla+zHYKK8AGr+Qi2TcAoRw+seAPcQ0X/yWh7FTObffB18hbOfVd+8ItT82WdNr+EoEJkIT21eohTKHMJfVITKLZ82PXZb9+yQ4ZmmZd93QQX5yV/g96Ps6iaseOQ+94TKPYLMvFO4DcttP8pB8spKcPWev4GvqBCUnwcQwV9chMV/0opFd2w2vUabQ5mc2rwkpyblc4EbfvV9nH31AI584b8hPHQJ82+6Fi0vfBf+fBsvcpeYV1uDLb0H0f3dn+CTF14CfIT8qgpEJyZQvKIW8zetx0jwYwy8eQQFi+ZjyfY/wsLbNqa86lhhSj0RvS1+yxVpUQEAWHr3H6PyunU4/dwvEb44hEV33ozKG5qtQ7nYXIci8tcERfZGR3E8H0o6ENE5AMklx0iNBQDOu1h+urgt33JmXuhi+ZY41La53n6JSNi+wl14FzTPrh3M3O2kAOoZzvwzTES/EffVKQQwZvh7tzFts0hDUG+RiiItpFIobkNEh7xKPJMMssvnNbLXj+zyxUJEZcw86LUcdpC9jmWXD3BXoSiTl0IxxyGipzB7rQlBM3mtz7xEirmKUigKxdznebO88kS0zgthFJ7TCmA+EbWJxHiOkWsKxbPUpUkiu3xeI3v9SCmfmTIR+7MxH4qUdWxAdvnAzE+4VXZOzaEoFAqFwj1ywh+TiOqJqJmIHiGiCq/lsYKIdnktQ7Yga11lS1/LNrKlXmXtl5kiJxQKgGZmbocWx2i718KYITwvKryWIxuQvK6k72tZivT1Knm/zAg5oVAM7nGt0DqkrAx4LUAWMeC1AGZkUV/LKrKoXge8FsBLcmZSnohaAewD0O+1LLEQ0VYAQWirmOuZOYUsO3MPUS9G2qC9UKSoKzP5mHlA5r6Wzchcr+oZ1sgJhSI64g5oDf4ytE4pDcy8T9iFKzwWRSosFl5JU1dm8sne17IV2etVPcMaystLoVAoFI6QE3MoCoVCoXAfpVAUcwYiaiWipx0us5mIjsfOl8TuF+6sh4mo3vB3KxHdJ8w1CsWcRymUDGH0o/dalrmKCMdd5XCZ7dBCfe9LsH+f+DsowoPvE/K0Icft6nMF9QwnJucVihtftRbUi5cQZF6YpXCEfgC7iKhCePvI7Oaa9ahnWB5ywssrHszcRkT3Z+g+9dC+Ygfcvl+uIx747RCunMy8W9S/0fx0SH9BpHGfrdDWHtTr+4THTz2Aw0Q0AODWdO6hiI96huUh50comUKsot0F4Db1dZMRdgHYK8xODXoOCHGsH9pLISVlos+TAJryMJi29OMVzPwEMzcAeAySruxW2EM9w4nJ+RGKEae+akXHexQAmHkbEelhI7a5I7nCBLO5lH5obduvf2GK2EtPi7mPZnFdvTHDnRHRHyoS3Hs7pqPOtgG4z7b0ipRQz7C3KIUyk13Q0qIOENEuwwsG0F5GA0l+1VaJTlgRU4bCRfRRiHip7ACwnYiCAI4zc7t4sewCECSit8WE+tuGIu5m5h1EtFV/gRjK1L28HgWwzbhflLNV/K17eenn1yMLQprPIdQz7CFKoczEka9aYQKBHobDzfwDimnEi+Ia8ecAZr/ItwK4V7TLfUbTlaDCoswGwy6jt1eD4bwnAOjtrBSId6hn2ENyfg7F4qu2FeKrFtqLaReARw1fnbFftW0A+kVZseRkTB9JCQJoMbRTP7QUuPrfT4u2r0p3sl6ROdQzLA85P0Jx46tWIScxa0l0hbHDcFwpkSxEPcPykPMKJQn0r1o9wqn+VasfM37Vzlj8JjquekkpFN6inuEMoYJDKhQKhcIRcn4ORaFQKBTOoBSKQqFQKBxBKRSFQqFQOIJSKAqFQqFwBKVQFAqFQuEI/x9Nvzfig/PWtwAAAABJRU5ErkJggg==\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "TICK_PADDING = 2\n",
    "LABELPAD = 1\n",
    "cmap = \"coolwarm\"\n",
    "\n",
    "fig = plt.figure(figsize=figsizes.neurips2022(nrows=1, ncols=2)['figure.figsize'])\n",
    "\n",
    "ax = fig.add_subplot(131)\n",
    "ax.grid(True, which=\"both\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "im = ax.scatter(np.log10(df_rhs_lhs_gamma_sq.gamma_square), np.log10(df_rhs_lhs_gamma_sq.lhs), c=np.log10(df_rhs_lhs_gamma_sq.gamma_square), cmap=cmap)\n",
    "# ax.plot(np.linspace(.85, 6), -np.linspace(.85, 6), c=\"black\", label='$y=x^{-2}$')\n",
    "ax.set_ylabel(r\"$%s{{\\sigma}}^{%s}_k(%s)^2$\" % (log10, phi, x), labelpad=LABELPAD)\n",
    "ax.set_xlabel(\"$%s%s$\" % (log10, gsq), labelpad=LABELPAD)\n",
    "# plt.legend()\n",
    "ax.tick_params(axis='both', which='major', pad=TICK_PADDING)\n",
    "\n",
    "ax = fig.add_subplot(132)\n",
    "ax.grid(True, which=\"both\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "ax.scatter(np.log10(df_rhs_lhs_gamma_sq.lhs), np.log10(df_rhs_lhs_gamma_sq.rhs), c=np.log10(df_rhs_lhs_gamma_sq.gamma_square), cmap=cmap)\n",
    "# ax.plot(np.linspace(-6, 0.), np.linspace(-6, 0.), c=\"black\", label='$y=x$')\n",
    "ax.set_ylabel(\"$%s \\mathrm{RHS}$\" % log10, labelpad=LABELPAD)\n",
    "ax.set_xlabel(\"$%s \\mathrm{LHS}$\" % log10, labelpad=LABELPAD)\n",
    "# plt.legend()\n",
    "ax.tick_params(axis='both', which='major', pad=TICK_PADDING)\n",
    "\n",
    "\n",
    "ax = fig.add_subplot(133)\n",
    "ax.grid(True, which=\"both\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "ax.scatter(np.log10(df_mse_gamma_sq.gamma_square), np.log10((df_mse_gamma_sq.mse_obs_decoded_mean_latents)), c=np.log10(df_mse_gamma_sq.gamma_square), cmap=cmap)\n",
    "# ax.plot(np.linspace(.85, 6), -np.linspace(.85, 6), c=\"black\", label='$y=x$')\n",
    "\n",
    "ax.set_ylabel(\n",
    "    r\"${%s} \\Vert  {\\boldsymbol{f}}^{{\\boldsymbol{\\theta}}} ( {\\boldsymbol{\\mu}}^{%s} (%s) ) - %s \\Vert^2_2$\" % (\n",
    "        log10, phi, x, x), labelpad=LABELPAD)\n",
    "\n",
    "ax.set_xlabel(\"$%s%s$\" % (log10, gsq), labelpad=LABELPAD)\n",
    "# plt.legend()\n",
    "ax.tick_params(axis='both', which='major', pad=TICK_PADDING)\n",
    "\n",
    "cbar = fig.colorbar(im)\n",
    "# cbar.ax.set_yticklabels(['0','1','2','>3'])\n",
    "cbar.set_label('$%s%s$' % (log10, gsq), rotation=270)\n",
    "cbar.ax.get_yaxis().labelpad = 13\n",
    "plt.savefig(\"self_cons_mlp_gauss.svg\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}