{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 371,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 372,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test_res.csv                                  100%   53KB 743.1KB/s   00:00    \n"
     ]
    }
   ],
   "source": [
    "!scp gpu6:bulatov/TXL/_git/test_res.csv ./test_res_lm_results.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 374,
   "metadata": {},
   "outputs": [],
   "source": [
    "res_df = pd.read_csv('test_res_lm_results.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 375,
   "metadata": {},
   "outputs": [],
   "source": [
    "# drop_masks = []\n",
    "# drop_masks += [(res_df.num_mem_tokens == 50) & (res_df.mem_backprop_depth == 2)]\n",
    "# drop_masks += [res_df['test loss'] < 0.1]\n",
    "# drop_masks += [res_df['test ppl'] > 41]\n",
    "# drop_masks += [(res_df.num_mem_tokens == 75) & (res_df.mem_backprop_depth == 1)]\n",
    "\n",
    "# res_df = res_df[sum(drop_masks) == 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 376,
   "metadata": {},
   "outputs": [],
   "source": [
    "# res_df.seed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 377,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((134, 73), (126, 73))"
      ]
     },
     "execution_count": 377,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_df.shape, res_df.drop_duplicates().shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 378,
   "metadata": {},
   "outputs": [],
   "source": [
    "# res_df = res_df[res_df.dataset =='wt103']\n",
    "res_df['effective context'] = (res_df.mem_backprop_depth.fillna(0) + 1) * res_df.tgt_len\n",
    "res_df['mem_backprop_depth'] = res_df['mem_backprop_depth'].fillna(0)\n",
    "res_df = res_df.drop_duplicates()\n",
    "res_df = res_df[res_df.mem_recursion_depth.isna()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 379,
   "metadata": {},
   "outputs": [],
   "source": [
    "res_df.loc[res_df.mem_len > 0, ['effective context']] = res_df[res_df.mem_len > 0]['effective context'] + res_df[res_df.mem_len > 0].mem_len"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 380,
   "metadata": {},
   "outputs": [],
   "source": [
    "enwik8 = res_df[res_df.dataset == 'enwik8']\n",
    "res_df = res_df[res_df.dataset =='wt103']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 381,
   "metadata": {},
   "outputs": [],
   "source": [
    "mt = res_df[(res_df.mem_len == 0) & (res_df.num_mem_tokens != 0)].dropna(subset=['test ppl'])\n",
    "xl = res_df[(res_df.mem_len > 0) & (res_df.num_mem_tokens == 0)].dropna(subset=['test ppl'])\n",
    "\n",
    "mt_base = mt[mt.n_layer == 16]\n",
    "mt_large = mt[mt.n_layer == 18]\n",
    "\n",
    "xl_base = xl[xl.n_layer == 16]\n",
    "xl_large = xl[xl.n_layer == 18]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 382,
   "metadata": {},
   "outputs": [],
   "source": [
    "target_cols = ['dataset', 'n_layer', 'scheduler', 'max_step', 'tgt_len', 'effective context',\n",
    "        'mem_len', 'num_mem_tokens',\n",
    "       'lr', 'patience', 'device_ids', 'mem_backprop_depth','test loss', 'test ppl']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 383,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## PPl (num mem tokens)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 384,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_ = mt_base\n",
    "# context_sizes = np.unique(df_.tgt_len)\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# fig, axs = plt.subplots(len(context_sizes), figsize=(10, 18))\n",
    "\n",
    "# for i, context_size in enumerate(context_sizes):\n",
    "#     axs[i].set_ylabel('ppl')\n",
    "#     for j, bpd in enumerate(bpds):\n",
    "#         df = df_[(df_.tgt_len == context_size) & (df_.mem_backprop_depth == bpd)].sort_values('num_mem_tokens')\n",
    "#         axs[i].plot(df.num_mem_tokens, df['test ppl'])\n",
    "#         axs[i].set_title(f'Wt-103, Memory Transformer, tgt {context_size}')\n",
    "#     axs[i].legend([f'bpd-{b}' for b in bpds])\n",
    "    \n",
    "\n",
    "#     axs[i].set_xlabel('num mem')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ppl (effective context)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 385,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base#[mt_base.mem_backprop_depth > 0]\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens']).mean()['test ppl'].reset_index()\n",
    "\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# plt.title('Wt-103: base. Memory transformer. Marker size ~ memory size')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 5 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend([f'bpd-{int(b)}' for b in bpds])\n",
    "\n",
    "# for i in range(len(bpds)):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "w trxl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 386,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_base\n",
    "# xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 10, edgecolor='k', c='r')\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 10 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend(['Transformer-XL'] + [f'RMT bpd-{int(b)}' for b in bpds])\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "\n",
    "\n",
    "# for tgt_len in [50, 150]:\n",
    "#     for m in np.unique(df_.num_mem_tokens):\n",
    "#         slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#         plt.plot(slice['effective context'], slice['test ppl'], c=None)\n",
    "\n",
    "#     slice = xl_[xl_.tgt_len == tgt_len]\n",
    "#     plt.plot(slice['effective context'], slice['test ppl'], c='r')\n",
    "\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 387,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens']).mean()['test ppl'].reset_index()\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# # plt.title('Wt-103: base. Marker size ~ memory size')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_base\n",
    "# xl_ = xl_.groupby(['effective context', 'mem_len']).mean()['test ppl'].reset_index()\n",
    "# plt.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 10, edgecolor='k', c='r')\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 10 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend(['Transformer-XL'] + [f'RMT bpd-{int(b)}' for b in bpds])\n",
    "\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 388,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base[mt_base.tgt_len == 50]\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_base[xl_base.tgt_len == 50]\n",
    "# xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 15, edgecolor='k', c='r')\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 15 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds])\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "\n",
    "\n",
    "# for tgt_len in [50]:\n",
    "#     for m in np.unique(df_.num_mem_tokens):\n",
    "#         slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#         plt.plot(slice['effective context'], slice['test ppl'], c=None, zorder=0)\n",
    "#     # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "#         plt.annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.1, 0.2, 0.6))\n",
    "\n",
    "#     slice = xl_[xl_.tgt_len == tgt_len]\n",
    "#     plt.plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "#     # plt.annotate(slice.mem_len.values[-1], (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.2, 0.1, 0.1))\n",
    "#     # print(slice.mem_len.values)\n",
    "#     for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "#         plt.annotate(v, (x, y), size=15, c=(0.2, 0.1, 0.1))\n",
    "\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 389,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base[mt_base.tgt_len == 150]\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_base[xl_base.tgt_len == 150]\n",
    "# xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "# plt.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 15, edgecolor='k', c='r')\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 15 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds])\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "\n",
    "\n",
    "# for tgt_len in [150]:\n",
    "#     for m in np.unique(df_.num_mem_tokens):\n",
    "#         slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#         plt.plot(slice['effective context'], slice['test ppl'], c=None, zorder=0)\n",
    "#     # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "#         plt.annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.1, 0.2, 0.6))\n",
    "\n",
    "#     slice = xl_[xl_.tgt_len == tgt_len]\n",
    "#     plt.plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "#     # plt.annotate(slice.mem_len.values[-1], (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.2, 0.1, 0.1))\n",
    "#     # print(slice.mem_len.values)\n",
    "#     for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "#         plt.annotate(v, (x, y), size=15, c=(0.2, 0.1, 0.1))\n",
    "\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 390,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# fig, axs = plt.subplots(1, 2, figsize=(25, 10))\n",
    "\n",
    "# letter_arr = ['(a)', '(b)']\n",
    "# for i, tgt_len in enumerate([50, 150]):\n",
    "#     df_ = mt_base[mt_base.tgt_len == tgt_len]\n",
    "#     xl_ = xl_base[xl_base.tgt_len == tgt_len]\n",
    "\n",
    "#     df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "#     bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "#     xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "#     axs[i].scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 15, edgecolor='k', c='r')\n",
    "\n",
    "#     for bpd in bpds:\n",
    "#         slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#         axs[i].scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 15 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "#     axs[i].set_xlabel(f'visible context while training\\ncontext={tgt_len}')\n",
    "#     axs[i].set_ylabel('ppl')\n",
    "#     lgnd = axs[i].legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds])\n",
    "#     for j in range(len(bpds) + 1):\n",
    "#         lgnd.legendHandles[j]._sizes = [60]\n",
    "\n",
    "\n",
    "#     for m in np.unique(df_.num_mem_tokens):\n",
    "#         slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#         axs[i].plot(slice['effective context'], slice['test ppl'], c=None, zorder=0)\n",
    "#     # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "#         axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.1, 0.2, 0.6))\n",
    "\n",
    "#     slice = xl_[xl_.tgt_len == tgt_len]\n",
    "#     axs[i].plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "#     # plt.annotate(slice.mem_len.values[-1], (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=15, c=(0.2, 0.1, 0.1))\n",
    "#     # print(slice.mem_len.values)\n",
    "#     for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "#         axs[i].annotate(v, (x, y), size=15, c=(0.2, 0.1, 0.1))\n",
    "\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 391,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='Reds', font_scale=1.7, font='monospace')\n",
    "\n",
    "# fontsize = 22\n",
    "# legsize=20\n",
    "\n",
    "# fig, axs = plt.subplots(2, 1, figsize=(12, 15))\n",
    "\n",
    "# letter_arr = ['(a)', '(b)']\n",
    "# for i, tgt_len in enumerate([50, 150]):\n",
    "#     df_ = mt_base[mt_base.tgt_len == tgt_len]\n",
    "#     xl_ = xl_base[xl_base.tgt_len == tgt_len]\n",
    "\n",
    "#     df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "#     bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "#     xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "#     axs[i].scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 15, edgecolor='k', c='lightblue')\n",
    "\n",
    "#     for bpd in bpds:\n",
    "#         slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#         axs[i].scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 15 + 15, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "\n",
    "#     axs[i].set_xlabel(f'visible context while training\\ncontext={tgt_len}', size=fontsize)\n",
    "#     axs[i].set_ylabel('ppl', size=fontsize)\n",
    "#     lgnd = axs[i].legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds], fontsize=legsize)\n",
    "#     for j in range(len(bpds) + 1):\n",
    "#         lgnd.legendHandles[j]._sizes = [80]\n",
    "\n",
    "\n",
    "#     for m in np.unique(df_.num_mem_tokens):\n",
    "#         slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#         axs[i].plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "#     # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "#         # axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.1, 0.2, 0.6))\n",
    "#         axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.6, 0.2, 0.2))\n",
    "\n",
    "#     slice = xl_[xl_.tgt_len == tgt_len]\n",
    "#     axs[i].plot(slice['effective context'], slice['test ppl'], c='c', zorder=0)\n",
    "#     for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "#         # axs[i].annotate(v, (x, y), size=22, c=(0.2, 0.1, 0.1))\n",
    "#         axs[i].annotate(v, (x, y), size=22, c=(0.1, 0.1, 0.2))\n",
    "\n",
    "#     axs[i].grid()\n",
    "#     # plt.yticks(fontsize=20)\n",
    "\n",
    "# plt.tight_layout()\n",
    "# plt.savefig('../../Memory transformer/_figures_paper/effective_context_v.png', format='png')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 393,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAz4AAAIiCAYAAAAJqB2MAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3iN5xvA8e/JTgiSyBIitlSMlBK7BNGEEq3VVqwatTq0hNavaAlVq1EUtbWqJRRFKkVRpGZFY8/Enk2srPP745FUmiHrjMT9uS5XnPd9znvu8xY993nu5340Wq1WixBCCCGEEEIUYSaGDkAIIYQQQgghdE0SHyGEEEIIIUSRJ4mPEEIIIYQQosiTxEcIIYQQQghR5EniI4QQQgghhCjyzAwdgKE8evSIqKgoHB0dMTU1NXQ4QgghhBBCiBxKTk7mxo0beHl5YWVllaPnPLeJT1RUFG+++aahwxBCCCGEEELk0YoVK6hXr16Oxj63iY+joyOgbpaLi4uBo1GJmJeXl6HDKFLknuqG3FfdkPuqG3JfC57cU92Q+6obcl91wxju69WrV3nzzTfTPtPnxHOb+KSWt7m4uFC2bFkDRwPXrl0zijiKErmnuiH3VTfkvuqG3NeCJ/dUN+S+6obcV90wpvuamyUr0txACCGEEEIIUeRJ4iOEEEIIIYQo8p7bUrfC4saNW4SH/87Bg0c5eDCKU6fOodVqmTbtU7p2bW/o8IQQQgghhCgUJPExcr/99gcjRkxIe6zRaAwYjRBCCCGEEIWTlLoZOVdXR/r06crXX3/O3r0/07y5j6FDEkIIIYQQotCRGR8j16yZD82aSbIjhBBCCCFEfsiMjxBCCCGEEKLIkxkfIYQQQhRJjx8/5vbt28TFxZGcnGzocLJlZmZGdHS0ocMocuS+6oYu7qupqSm2trbY29tjaWlZoNdOJYmPEEIIIYqcx48fc/HiRezs7PDw8MDc3NyoGwTdv3+fYsWKGTqMIkfuq24U9H3VarUkJibyzz//cPHiRdzd3XWS/EipmxBCCCGKnNu3b2NnZ0fp0qWxsLAw6qRHiOedRqPBwsKC0qVLY2dnx+3bt3XyOpL4CCGEEKLIiYuLo0SJEoYOQwiRSyVKlCAuLk4n15bERwghhBBFTnJyMubm5oYOQwiRS+bm5jpbkyeJjxBCCCGKJClvE6Lw0eXfW0l8hBBCCCGEEEWeJD5CCCGEEEKIIk8SHyPy/fcrqV+/IU2aNGfbtm2GDkcIIYQQolC6du0aw4cPp02bNlSrVo1q1aqxZs0aQ4clDEz28TEShw4d4pNPPmXUqEXEx9/j9de78Oef+yhWrAR9+36YNu7MmfMAzJy5gGXLVgNQs2Z1QkKCDRG2EEIIIYxQaGgos2bNytHYwMBAJk2apOOI9GvUqFH88ccftG3blooVK6LRaPD09DR0WIVCUlISnTp14sSJEyxZsgQfH5905x8/fkyHDh2IjY3lu+++w9vbG4CWLVsSGxtLREQEZcuWNUTozySJj5E4dOgQrVu/RYMGbQDYtm0l+/fvp2HDJhw6FJVh/IULsVy4EAuAlZWFXmMVQgghhHGrX78+Q4YMSXdsyZIlxMXFERQUlK7Vd1FLCBISEtizZw+NGjViwoQJsoFpLpmZmfH555/TrVs3xo8fz7p169J1SJw7dy6XLl2iT58+aUlPYSGJj5EoX748Cxd+x927H/HgQRxRUXupUuUTypUrQ2zsfkOHJ4QQQohCpEGDBjRo0CDdsbCwMOLi4ujZs6fRfiNfEG7evElKSgpOTk6GDqXQqlWrFj169GDx4sUsWrSI/v37A3Du3DkWLFhA+fLlee+99wwbZB7IGh8j0bJlS9q1a0P7DmXp+pYXH388qtBl0UIIIYQo3EJDQ6lWrRr79u3j999/54033sDb25u6devSrVs3zp8/nzZ2zZo1DB06FF9fX2rVqpU25qeffkKr1aa7bkxMDNWqVSM4OJgjR44QFBSEt7c3L730EiNHjiQ+Pj7TeLZu3UqPHj1o1KgRNWvW5OWXX2bo0KHs378/0+tXq1aNFi1aACrRe/HFF7Nd47Np0ya6deuGt7c3tWvXJjAwkO+//z5D/Lm9Py1btuSNN95g1KhR1K5dm44dO3L27FlGjRpFnTp1ePXVVzl16lSG60dFRTFs2DAaNmyIl5cXbdq0ITQ0lISEhHz/98qtd999Fzc3N+bMmcPly5cBGDt2LElJSYwdOxZLS8s8X9tQZMbHSGg0Gr788gtMB/RjakwMg19+2dAhCSGEEOIZ4uLiCAsL4+rVq7i4uBAYGIitra2hw8q37du3s3TpUpo2bcpbb73FzZs32bt3L9euXcPDwwOATz/9FCcnJ2rVqkWZMmV48OABu3bt4uOPP+b48eN88sknGa579uxZevfuTdOmTenatSu7d+9m7dq1JCUlMXXq1HRjV61axZgxY3BwcKBVq1aUKFGCK1eusG/fPsqWLUu9evXSxpYoUSKttO+ff/5h6dKlVK9enWbNmmFhoZYE/Lekb+HChUyePBl7e3sCAwMxNzfn119/ZezYsZw5cybT+HNzfw4ePEjx4sXx8/Nj3bp1dO/eHScnJ15//XVWrlzJ2LFjWbFiRdo1N2/ezIcffoiJiQlt2rTB0dGRQ4cOMWvWLI4ePco333yT5R43OYknt2xsbBg/fjx9+/Zl4sSJtGrVir1799K7d29q166dp2samiQ+RqactTXJGg03EhNxtpC1O0IIIYQx0mq1fPnlVCZOnEjt2k1xc6vCL7/s5t1332P06NF8+OHwQr2B6rJly5g3bx6NGzdOO5aQkMDDhw/THi9cuJB69eqle5+JiYl06tSJZcuW0bNnT8qVK5fuukeOHGHWrFm0bt067Zpt27Zl8+bNjBs3juLFi6eN/eGHH9JiqVSpUtrxpKQkrl69mu66JUqUYOjQoYCa/Vm6dCmenp4MHDgw0zU+N2/eZNq0aRQvXpywsDBcXFwAGDJkCB06dGDZsmV06tSJF154Ic/3x87Ojrlz52JiYsKZM2eIiopi6dKlVKtWjTt37rBlyxZSUlIwMTHh1q1bjBo1CisrK3744Yd073fMmDGsWrWKX375hYCAgDzHkxdNmjShY8eOrF27lt27d+Ph4cF7771HcnJyvq5rKFLqZmTcnkwbxj5+bOBIhBBCCJGVL7+cyvz5S1i48CCTJq1j6NAvmTRpHQsXHmT+/CV8+eXUZ1/EiLVp0ybdh2gACwsLSpYsmfb4pZdeypDcmZub06RJEwBOnDiR4bpVqlRJS3pSr9msWTOSkpK4cOFCurGpH64t/vNFsJmZWb7XKEVERJCYmEjHjh3Tkh4AW1tb3nrrLQC2bNmS5fNzcn/c3NwwMVEftVPjdXd3B8DFxYXExETu3r0LqLK8Bw8e0Lt373RJD0Dfvn0BVZaXn3jy6v3330ej0fDgwQPeffddrKys8n1NQ5EZHyOTmvhcfvyYF4vAVLkQQghR1MTFxTFx4kQWLjyIq6tHunOurh5MnryePn3q8s47A9PNYBQmjRo1euaYmJgY5s2bx969e7l69SqP//Ol7f379zM8p2LFihmO2dvbZzq+bdu2REdH06NHD9q1a8eLL75IjRo1cHZ2zs1bydTp06cBMp3RSS2JSx2TmZzcn6cThNT1MKnHUh+n3rO//voLUM0DQkND010nKSkJINv1OjmJB2Dfvn1ERkamO+bp6UmrVq2yfM6SJUvS1jx9//33+Pv75+i1jJEkPkamzJNvNWKzWMQmhBBCCMMKCwujdu2mGZKeVK6uHtSp04SwsDB69Oih3+AKiKura7bnL126xOuvv869e/d46aWXaNasWdrsQmRkJJGRkZmWQ9nY2GQ4ljpr9N+GAgMGDMDe3p6ffvqJhQsXMn/+fADq1q3LhAkTqFChQp7eG8CDBw8AKFWqVIZzdnZ2QOaJW6pn3R8g3WxY6sxP6rHUn6n3KC4uDoD169c/M+a8xgPqv81/93cKDAzMMvE5cuQIS5YsoUaNGjRo0ICFCxfy008/8corr+To9YyNJD5GxsXCAhOk1E0IIYQwVlevXsXNrUq2Y8qUqcKVK1f0FFHBMzPL/iPiokWLuHv3Lp9//jmdO3dOd+7TTz/NMKuQFxqNhi5dutClSxfu37/PwYMHWbFiBdu2bWPYsGHZJgnPkpqApZaaPe3OnTsA2e7/86z7k1upDTFWrlyZp66+OY1n6NChaWuhniUhIYHRo0cD8Pnnn+Ph4cHGjRuZMmUKDRo0KJT7I8kaHyNjZmKCs4WFJD5CCCGEkXJxcSE2NmMr4qddvnwqx9/CF0ap63Ey++b/6NGjBf56xYoVo2nTpsyZM4cKFSpw8uRJbt++nefrVa5cGYDo6OgM51KPpY7RBy8vL0DNsBiLWbNmcfr0aXr16sULL7yAjY0NI0eO5O7duxk68BUWkvgYoTIWFlyWUjchhBDCKAUGBnLkyE6uXDmf6fkrV85z+PAuAgMD9RuYHrm5uQEZP6gvX76cY8eOFchr7NmzJ0P52927d7lz5w4WFhaZls3lVMuWLTE3N2ft2rVcunQp7fjt27fTWkz7+fnl+fq51bFjR6ysrJgzZw5nzpzJcP7y5cscP35cb/EcO3aMb7/9lnLlyqWbIQoICKB+/fps2rSJnTt36i2egiKlbkbIzdKSc48eGToMIYQQQmTC1taW0aNHM3JkeyZPXp9urc+VK+cZObI9o0ePKrSNDXLijTfeYM2aNQwePJhXXnmFUqVKERUVxaFDh2jSpAm7du3K92sMHToUGxsbvL29cXNz48GDB0RERHD37l369euXr+5ijo6OvP/++3zxxRe8/vrr+Pr6Ym5uzvbt27l69So9evTIspW1Ljg5ORESEsKIESPo0KEDzZs3x8PDg8ePHxMVFcWRI0cYOXIk1atX13ksiYmJjBo1iqSkJMaNG4e1tXW682PGjCEwMJCxY8eyYcOGDOe/+OKLLJPSESNGpDWzMARJfIyQm6Ulu+7dM3QYQgghhMjChx8OB6BPnxepU6cpZcpU4fLlUxw+vDNtH5+irHr16ixdupQZM2awdetWkpOTqVmzJkuXLmX37t0Fkvh88MEH/P777/z111/89ttv2NraUrFiRUaNGlUgncX69u2Lq6srS5cu5ZdffiElJYWKFSsyYMAAunfvnu/r55a/vz8eHh58++23REZGsmPHDkqWLEn58uV5//339dZQYO7cuZw4cYKOHTtmaJENULVqVTp37sz333/PV199xciRI9Odz64N+JAhQwya+Gi0/51DfE7ExMTg6+tLREREvnvBF4QDBw5Qt25dACZcuMAn587xsGlTrExNDRxZ4fX0PRUFR+6rbsh91Q25rwWvsNzT6OjotLbEuhQXF8fatWu5cuUKrq6uBAYG5mmm5/79+4Vysbixk/uqG7q+rzn5+5uXz/Iy42OEUltaX05IoOJ/pg+FEEIIYTxsbW0LbctqIZ43Bk98zp49y4IFCzh69ChXrlwhOTkZd3d32rVrR48ePdLqNx88eMCGDRvYvHkzZ86c4datW5QuXZpmzZoxZMgQnJycDPxOCk7qJqaxjx9L4iOEEEIIIUQBMHhXt5MnTxIeHo6bmxsdO3akW7duFC9enC+//JKgoKC03WoPHz7MmDFjOHv2LI0aNaJXr15UqlSJH374gddee42rV68a+J0UnKcTHyGEEEIIIUT+GXzGp1mzZuzduzfDxkvjxo3ju+++Izw8HH9/fxwcHJg5cyZt2rRJ2/0WYPbs2cycOZOvv/6azz77TN/h68TTpW5CCCGEEEKI/DP4jI+NjU2mu802bdoUIK2XebVq1Wjbtm26pAegW7duABw8eFDHkepPKTMzrE1MZMZHCCGEEEKIAmLwxCcr27dvB6BcuXLZjjN90vXM8kl5WFGg0Whws7SUxEcIIYQQQogCYvBSt1TR0dFs3bqV+/fvc/DgQY4cOYK3t/cz+7SHh4cD/84QFRVuFhZS6iaEEEIIIUQBMZp9fNasWcOoUaPSHvv7+xMSEpLtrry3bt2iQ4cOJCcns2nTJkqVKpXj10vt/T1z5kwcHR3zE7oQQgghjIyZmRmVK1c2dBhCiDw4ffp0WoOzrNy4cYN33323cO7j06lTJzp16sS9e/eIjIxkwoQJ9OvXjzlz5mS6EVhCQgLvvfced+7cYcGCBblKep7m5eVldBuYAnx05gyhMTE8bNYMjUZjwMgKr8KyyV5hI/dVN+S+6obc14JXWO5pdHR0odq4Ujba1A25r7qh6/tqYWFB7dq1sx0TExOT6+sa3RqfkiVL0rp1a6ZNm0ZkZCTz5s3LMCYlJYWRI0cSGRnJuHHjaNiwoQEi1S03Cwsea7Xcfka2K4QQQgghhHg2o0t8Unl7e2Ntbc2uXbsynJswYQK//PILw4cP5/XXXzdAdLpX5kmzhsvS4EAIIYQQQoh8M9rE5/79+zx69IiE/yzwnzVrFsuXL6dPnz7079/fQNHpnmxiKoQQQgghRMExeOKzf/9+EhMT0x3TarWEhoai1Wp58cUX044vWbKE0NBQunTpwsiRI/Udql65PdnENFY6uwkhhBBCCJFvBm9uMHPmTE6dOkW9evUoW7YsiYmJ7N+/n+PHj+Ps7MzgwYMB2LNnDyEhIRQvXpzSpUsTGhqa7jq2trb06tXLAO9AN1yl1E0IIYQQQogCY/DE580332Tz5s1ER0fzxx9/kJCQgKurKz169OCdd97BwcEBgCtXrqDVaomPj2f27NkZruPm5lakEh9LExNKm5tLqZsQQggh8iQ4OJiwsLC0xyYmJpQoUQIvLy+6detG69at086lbvMB0LBhQxYvXpzuWqNHj2b16tUALF26lMjISGbNmpWjOAIDA5k0aVKu4//vViegun2VKVOGpk2b0r9/f5ycnDJ9D6nMzMwoXbo03t7e9OnTh1q1agEQGhqaq/jd3Nx0/n5T/fHHH8yZM4djx44BUKNGDQYPHoyPj0+erykUgyc+bdu2pW3bts8cl9ru+nniZmEhpW5CCCGEyBdfX188PT1JTEzk3LlzREREsGvXLgYPHsywYcPSjTU3NycyMpIbN26k7XOYkJBAeHg45ubmacsT6tevz5AhQ9I9d8mSJcTFxREUFESJEiXSjnt6euYr/urVq9OqVSsA4uPjiYqKYtmyZWzZsoWwsDBKly6dbryzszOdO3cG4N69e5w4cYJNmzYRHh5OaGgovr6+uY7f1tZWL+/3119/ZejQoRQvXpwOHTqg1WpZv349vXv35uuvv6Zly5Z5vrYwgsRHZM3N0lJmfIQQQgiRL61atUr35fGePXvo3bs3c+fOpWvXrjg7O6ed8/Ly4ty5c2zatImgoCAAtm/fzsOHD2ncuDE7duwAoEGDBjRo0CDd64SFhREXF0fPnj0LdI9ET09Phg4dmu7YiBEjWLduHatWrWLQoEHpzrm4uKSNT91vZsWKFYwfP56QkBB8fX3zFL+u3+/jx48ZN24cpqamLF26lBdeeAGA1157ja5duzJ27FiaNGmCxZN14CL3DN7cQGStjKWlrPERQgghRIFq2LAhFStWJDk5mSNHjqQ7Z25ujp+fHxs2bEg7tn79enx8fLC3t9d3qFlK3dzy+vXrORrfvXt3rK2tuXTpErdv39ZlaHm2c+dObty4wcsvv5yW9ADUrFmTZs2ace3aNXbv3m3ACAs/SXyMmJuFBdcTE0lMSTF0KEIIIYTITFwcLF0KX3yhfsbFGTqiHDExUR8BzcwyFv+0a9eOI0eOcOnSJeLj49mxYwcBAQH6DjFbe/bsAVQZXG5pNJqCDqdAHDx4EICXXnopw7n69esDcODAAb3GVNRIqZsRc7O0RAtcSUjA3crK0OEIIYQQIpVWC1OnwsSJ0LQpVKkCu3fDe+/B6NEwfDgY6Qfso0ePcvbsWWxsbNJmTp5Wr149nJ2d2bhxI46Ojmi1Wlq3bk1kZKQBooXo6Oi0br5xcXEcOnSIv/76Cz8/vxyv/16+fDkPHz6kfPny2NnZ6TLcPIuJiQGgbNmyxMfHM3z4cOzs7JgwYUJaKd3FixcNGWKhJ4mPEXN7qqW1JD5CCCGEEZk6FZYsgYMHwcPj3+Pnz0P79ur3H35oiMgy2Lp1K7GxsSQlJREbG0t4eDiWlpZMnDgxrXvu00xMTPD392fjxo04ODjQvHlzbG1tDRC5cvz4cY4fP57umI+PDz179sx0vcvVq1fTEqXU5gaRkZGYmpoSHBysl5jzIj4+HoBixYqxa9cutm/fDqgOyMWLFwfUmiWRd5L4GLEysompEEIIYXzi4tRMz3+THlCP16+HunVh4EB48oHVkCIiIoiIiEh7XK5cOWbPnk3VqlWzfE67du1YtGgRGo2GadOm6SPMLD3dHvru3bscO3aMkJAQgoKCmDVrFi1atEg3/tq1a2mtp1PbWfv7+9O7d++0dtb6tG/fvgyzZZ6enmmd6jJTp04d3NzcsLe3p3Llyhw6dEjXYT4XJPExYqkzPtLZTQghhDAiYWGqvO2/SU8qDw9o0kSN69FDn5FlKiQkhE6dOvHo0SN27txJcHAwffv2zbQVdCovLy88PDy4fv26UbVQLlWqFI0bN2bGjBkEBAQwefLkDIlP7dq1WbVqFfBvVzdDymzPo8DAwAyJz9OzOi4uLvz2229p51Jnegz9Xgo7SXyMWGlzc8w1Gkl8hBBCCGNy9apa05OdKlXgyhX9xJNDVlZWtG7dmvv37zNy5EhCQkKYOnVqluM3bdqEVqvF1NRUj1HmTOXKlSlZsiTnzp0jPj4+LWkwRkOHDs3Qjjszqet4Utf6PO3SpUsAuLu7F2xwzxnp6mbENBoNZSwsuCylbkIIIYTxcHGBU6eyH3PqFLi66ieeXOrQoQPVqlVj48aNREdHZznOxMTEKJMegJSUFB49egSoDVaLghdffBGAP//8M8O51FK51DEibyTxMXKyiakQQghhZAIDYedO1cggM+fPw65dapwR0mg0DBw4EK1Wy8yZMw0dTp5s2LCBx48f4+7ublT7C+VHkyZNKF26NDt27ODvv/9OOx4VFcXOnTtxcnKiSZMmBoyw8JNSNyPnZmnJkSddPoQQQghhBGxtVcvq9u1VI4PMurqNGmUUjQ2y0rZtW2bOnMm2bds4fPhwlmt9jMHT7azj4+M5ffo0u3fvxtTUlFGjRhk4uoJjZWXFmDFjeO+99wgKCqL9k+6AP//8MykpKXz66aeZdrETOSeJj5Fzs7Rkk5HuMCyEEEI8t4YPVz9ffPHffXxOnVIzQan7+BgxExMT+vfvz+jRo5k+fToTJkwwdEhZerqdtbm5OU5OTgQEBNCrVy9q1qxp4OgKVtu2bfn222+ZM2cOa9euBVSjiUGDBtGwYUPDBlcEaLRardbQQRhCTEwMvr6+REREpC0mM6QDBw5Qt27dDMenXLzIiLNnudekCSUy2V1ZZC2reyryR+6rbsh91Q25rwWvsNzT6OhoPD09df9CcXGwdq1qZODqqsrb8jDTYwzdx4oiua+6oev7mpO/v3n5LC+fpI3c0y2tJfERQgghjIytrVG0rBZCPJs0NzByspePEEIIIYQQ+SeJj5Er82QRm7S0FkIIIYQQIu8k8TFyMuMjhBBCCCFE/kniY+RsTE0pZWYmiY8QQgghhBD5IIlPIeBmYSGlbkIIIYQQQuSDJD6FQBlLS5nxEUIIIYQQIh8k8SkE3CTxEUIIIYQQIl8k8SkE3CwsuJqQQPLzudesEEIIIYQQ+SaJTyFQxtKSZOC6rPMRQgghhBAiTyTxKQSkpbUQQgghhBD5I4lPIeD2ZBPTWJnxEUIIIYQQIk8k8SkEUmd8LsuMjxBCCCGEEHkiiY8hXboEw4dDmzaUmzFDPc6Ek4UFpkipmxBCCCGEEHllZugAnluXLoGPD7zxBrz/PqW3blWP9+6FcuXSDTXVaHCxsJBSNyGEEELkWHBwMGFhYWmPTUxMKFGiBF5eXnTr1o3WrVunnYuJicHX1xeAhg0bsnjx4nTXGj16NKtXrwZg6dKlREZGMmvWrBzFERgYyKRJk3Id/5o1axg1alS6YxYWFpQpU4amTZvSv39/nJycMn0PqczMzChdujTe3t706dOHWrVqARAaGpqr+N3c3HT+fgH2799PREQEUVFRHDt2jPv37+freiI9SXwMZcYMlfRMmQKAySuvgImJOj51aobhbpaWUuomhBBCiFzz9fXF09OTxMREzp07R0REBLt27WLw4MEMGzYs3Vhzc3MiIyO5ceMGjo6OACQkJBAeHo65uTmJiYkA1K9fnyFDhqR77pIlS4iLiyMoKIgSJUqkHff09MxX/NWrV6dVq1YAxMfHExUVxbJly9iyZQthYWGULl063XhnZ2c6d+4MwL179zhx4gSbNm0iPDyc0NBQfH19cx2/ra2tXt7vTz/9RFhYGDY2Nri4uHD27Nk8X0tkJImPoRw9Cu+/n/6Yry9Mm5bp8DKWlpx68EAPgQkhhBCiKGnVqhWdOnVKe7xnzx569+7N3Llz6dq1K87OzmnnvLy8OHfuHJs2bSIoKAiA7du38/DhQxo3bsyOHTsAaNCgAQ0aNEj3OmFhYcTFxdGzZ0/Kli1bYPF7enoydOjQdMdGjBjBunXrWLVqFYMGDUp3zsXFJW38/fv3KVasGCtWrGD8+PGEhITg6+ubp/j18X7feOMN+vTpQ+XKldm1axf9+vUrkOsKRdb4GErNmvDbb+mPbd4M1aplOtxNSt2EEEIIUQAaNmxIxYoVSU5O5siRI+nOmZub4+fnx4YNG9KOrV+/Hh8fH+zt7fUdapZq164NwPXr13M0vnv37lhbW3Pp0iVu376ty9DypVatWlStWhUTE/mIrgsy42Mo772n1vQA+PqS8uuvmMybB+XLQ2wsuLmlG+5macndpCQeJCdjY2qq/3iFEEIIkVFcHISFwdWr4OICgYFga2voqJ4p9YO1mVnGj4Lt2rXjhx9+4NKlS9jZ2bFjxw7Gjh1LZGSkvsPM0p49ewBVBpdbGo2moMMRhYSkk4ZSrpxqZJCSAtOmcfP6dZg/XyU9Pj6qFO4p0tJaCCGEMCJaLdopU9C6u6NdthjtySj1090d7ZQpoNUaOsIsHT16lLNnz2JjY5M2c/K0evXq4ezszMaNG9myZQtarTZdIwR9i46OJjQ0lNDQUCZOnEjnzp359ddf8fPzS1fCl53ly5fz8OFDypcvj52dnY4jFsZKZnwMqVy5tEYGlw4cwKluXVUC5+8PTZrAmjVq3Q9Q5qlNTCvb2BgsZCGEEEKA9ssv4dv5ELYUypb590TMZRg4HC2g+egjg8X3tK1btxIbG0tSUhKxsbGEh4djaWnJxIkTcXBwyDDexMQEf39/Nm7ciIODA82bN8fWgLNYx48f5/jx4+mO+fj40LNnTyyefD562tWrVwkNDQX+bW4QGRmJqakpwcHBeolZGCdJfIxNrVpqJsjfH9q2hW+/haCgtBkf2ctHCCGEMLC4OJg4MWPSA+rx3KnQqSe88w4UL26YGJ8SERFBRERE2uNy5coxe/ZsqlatmuVz2rVrx6JFi9BoNEzLovGSvjzdzvnu3bscO3aMkJAQgoKCmDVrFi1atEg3/tq1a2mtp1PbWfv7+9O7d++0dtb6tG/fvgxlgp6enmmd6oT+SOJjjMqWhZ074bXXoGdPuHgRt5EjASl1E0IIIQwuLAzqeWdMelKVLQN166hxPXroNbTMhISE0KlTJx49esTOnTsJDg6mb9++mbaCTuXl5YWHhwfXr1+nZcuWeo44a6VKlaJx48bMmDGDgIAAJk+enCHxqV27NqtWrQL+7epmSJnteRQYGCiJjwFI4mOsSpaEX36Bfv1gzBhsz5+nWFCQdHYTQgghDO3qVSj/jPbF5cvClSv6iSeHrKysaN26Nffv32fkyJGEhIQwNZO9A1Nt2rQJrVaLqRE2VapcuTIlS5bk3LlzxMfHU9wIZtayMnTo0AztuIVhSHMDY2ZhAYsXw//+h+bbb3G7cYPY+/cNHZUQQgjxfHNxgQsx2Y+5EAOurvqJJ5c6dOhAtWrV2LhxI9HR0VmOMzExMcqkByAlJYVHjx4BaoNVIXJCEh9jp9HAuHGwYAFuFy8Se/AgXL5s6KiEEEKI51dgIOw/pBoZZCbmMhw4rMYZIY1Gw8CBA9FqtcycOdPQ4eTJhg0bePz4Me7u7ka1v5AwblLqVlj07YtbRAS7bt5U7a43bYIaNQwdlRBCCPH8sbWF0aNh4HDVyCCTrm6MGmUUjQ2y0rZtW2bOnMm2bds4fPhwlmt9jEFqO2uA+Ph4Tp8+ze7duzE1NWXUqFEGjq5g7d+/n59++glQTRoADhw4kNaNrm7dunTu3Nlg8RV2kvgUImU8PLhsaoo2KQlN48Zq0eR/FvQJIYQQQvc0H36IFiAwSDU6KF9WlbftPwSjR6P58ENDh5gtExMT+vfvz+jRo5k+fToTJkwwdEhZerqdtbm5OU5OTgQEBNCrVy9q1qxp4OgK1sWLFwkLC8tw7OLFi2mPJfHJO41Wa8Q7bOlQTEwMvr6+REREULbsMxYo6sGBAweoW7dutmO+ionh3dOnuV6+PI7t28PJk7BoEbz5pp6iLFxyck9F7sl91Q25r7oh97XgFZZ7Gh0djaenp+5fKC4O1q5VjQxcXVV5Wx5meoyh+1hRJPdVN3R9X3Py9zcvn+UNPuNz9uxZFixYwNGjR7ly5QrJycm4u7vTrl07evTogZWVVdrY48ePs2HDBo4cOcLRo0d5+PAhY8eOpXv37gZ8B/qTupfPZUdHHHftgk6d4K234MIFNaWu0Rg4QiGEEOI5Y2trFC2rhRDPZvDmBidPniQ8PBw3Nzc6duxIt27dKF68OF9++SVBQUEkJSWljf3111+ZP38+x44dw8nJyYBRG0aZJ7sTxz5+DKVKwebNKvH5+GMYOBCeuldCCCGEEEKIfxl8xqdZs2bs3bsXM7P0oYwbN47vvvuO8PBw/P39AWjTpg2tW7ematWqrF27tsgtaHuW1Bmf2NRNTC0sYOlSKF8eJkyAmBj44QejXkwphBBCCCGEIRh8xsfGxiZD0gPQtGlTAM6cOZN2rFq1alSvXh0TE4OHbRCuFhZoeCrxAVXe9vnn8M03sGULNG9udBumCSGEEEIIYWhGm0Fs374dgHLlyhk2ECNibmKCk7k5lzPbqKt/f/j5ZzhxAho2hL//1n+AQgghhBBCGCmDl7qlio6OZuvWrdy/f5+DBw9y5MgRvL2908rchFLG0jL9jM/T/P3h998hIAAaN1ZdZpo312t8QgghhBBCGCOjSnxmzZqV9tjf35+QkBAsnizo15WoqKi0DaIM7cCBA88cM1+jgcTE7Mdu2PD0RQsgssIrJ/dU5J7cV92Q+6obcl8LXmG4p2ZmZty/f9/QYeRKYYu3sJD7qhu6vK8JCQnP/Hfmxo0bub6u0SQ+nTp1olOnTty7d4/IyEgmTJhAv379mDNnDsV1uFjfy8ur0OzjAzDwxAnW3LzJ9caNsx94547aS2DHDpg0CUaMeO7aXReWvSYKG7mvuiH3VTfkvha8wnJPo6OjC9X+LbLfjG7IfdUNXd9XCwsLateune2YmJiYXF/X6Nb4lCxZktatWzNt2jQiIyOZN2+eoUMyKmUsLbmRmMjjlJTsB9rZqWYH3bpBcDAMHiztroUQQgghxHPL6BKfVN7e3lhbW7Nr1y5Dh2JUUltaX8lqnc/TLC1hxQoYORLmzFEzQDLdK4QQQgghnkNGm/jcv3+fR48ekZBZB7PnmFvqJqY5vS8mJqrUbc4c+OUXePllMJI1TUIIIYQQQuiLwROf/fv3k5iYmO6YVqslNDQUrVbLiy++aKDIjFPqjM/lnMz4PG3gQFi3TrW59vGB48d1EJ0QQgghhBDGyeDNDWbOnMmpU6eoV68eZcuWJTExkf3793P8+HGcnZ0ZPHhw2tgzZ84wf/58AC5cuADA2rVrOXLkCAD9+vWjUqVK+n8TelTmSeKTZUvr7LRrp5odBARAo0Zq358mTQo4QiGEEEIIIYyPwROfN998k82bNxMdHc0ff/xBQkICrq6u9OjRg3feeQcHB4e0sTdv3iQsLCzd8w8fPszhw4cBCAwMLPKJj72ZGZYaTc5L3f6rXj3YuxdeeQVatYKlS6FLl4INUgghhBBCCCNj8MSnbdu2tG3bNkdjGzRowIkTJ3QckXHTaDS4WVrmvtTtaRUqwB9/QIcO0LUrXLwIw4c/d+2uhRBCiKIsODg43RfGJiYmlChRAi8vL7p160br1q3TzsXExODr6wtAw4YNWbx4cbprjR49mtWrVwOwdOlSIiMj0+2/mJ3AwEAmTZqU6/jXrFnDqFGj0h2zsLCgTJkyNG3alP79++Pk5JTpe0hlZmZG6dKl8fb2pk+fPtSqVQuA0NDQXMXv5uam8/d79+5dNm7cyNatWzl//jw3btygRIkSvPjii/Tr1++Z7Z3Fsxk88RG5V8bSMm+lbk+zt4dff4WePeGjj+D8eZg5E0xNCyRGIYQQQhgHX19fPD09SUxM5Ny5c0RERLBr1y4GDx7MsGHD0o01NzcnMjKSGzdu4OjoCKjNJMPDwzE3N09bl12/fn2GDBmS7rlLliwhLi6OoKAgSpQokXbc09MzX/FXr16dVq1aARAfH09UVBTLli1jy5YthIWFUbp06XTjnZ2d6dy5MwD37t3jxIkTbNq0ifDwcEJDQ/H19c11/La2tjp/v7/99hvjx4/H1dUVHx8fHB0duXjxIlu3biUiIoKpU6fi7++fp2sLRRKfQsjNwoID8fH5v5CVFXz/PZQvD1OmwKVL6rGNTf6vLYQQQgij0KpVKzp16pT2eM+ePfTu3Zu5c+fStWtXnJ2d0855eXlx7tw5Nm3aRFBQEADbt2/n4cOHNG7cmB07dgCqCqdBgwbpXicsLIy4uDh69uxZoJvDe3p6MnTo0HTHRowYwbp161i1ahWDBg1Kd87FxSVtfOpGmytWrGD8+PGEhITg6+ubp/h1/X7d3d355ptvaN68OZqnqnBS/3uNHTuWVq1aYfGkw6/IPYN3dXtuJSTADz9A797w+utUGD9ePc7B2p3UUjetVpv/OExM4IsvYNYs2LABWrSA69fzf10hhBBCGKWGDRtSsWJFkpOT0xpEpTI3N8fPz48NGzakHVu/fj0+Pj7Y29vrO9QspZZ9Xc/hZ5bu3btjbW3NpUuXuH37ti5Dy7N69erx8ssvp0t6QP33qlSpEvfu3eO4dOXNF0l89E2rha+/VrMs33yjWkt37Yq9v7967O6uzmeT1LhZWvIgJYV7SUkFF9fgwbBmDRw9Cg0bwsmTBXdtIYQQoqiKi1ONgr74Qv2MizN0RDliYqI+ApqZZSz+adeuHUeOHOHSpUvEx8ezY8cOAgIC9B1itvbs2QOoMrjc+m9iURik/veytrY2cCSFm5S66dsnn6j9dLZuhRo10p8bMACioqBbN7h8GSZMyPQSZZ7axLSUuXnBxdahA2zbBu3bq+Tn55+hceOCu74QQghRVGi1aKdMgYkT4IXKaJ3t0Vy7DcOGwuiP0Xz0kdE2DTp69Chnz57FxsYm0wXz9erVw9nZmY0bN+Lo6IhWq6V169ZERkYaIFqIjo4mNDQUgLi4OA4dOsRff/2Fn59fuhK+7CxfvpyHDx9Svnx57OzsdBlugTt9+jSnTp3C3d2dypUrGzqcQk0SH31avRp++kl1VHuqTXc6Xl5qr51GjeDFF+G11zIMcXtqL58axYoVbIwNGsCePardta8vrFiRaQxCCCHE80w7ZQrM/ZqULz4AJ/X/dC3A9VuYTPoaLaAZMcKQIabZunUrsbGxJCUlERsbS3h4OJaWlkycODHdtiGpTExM8Pf3Z+PGjTg4ONC8eXNsbW0NELly/PjxDCVePj4+9OzZM9P1LlevXk1LlFKbG0RGRmJqakpwcLBeYi4oCQkJfPzxx2i1WoKDgwvlbJUxkcRHn6ZOVVPhWSU9qRwcYPJk1XAgm8QnXy2ts1Opkkp+Xn0VOndWcb//vm5eSwghhChs4uJg4oR0SU8aJwdSgvtgMnIiDBoExYsbJsanREREEBERkfa4XLlyzJ49m6pVq2b5nHbt2rFo0SI0Gg3Tpk3TR5hZero99N27dzl27BghISEEBQUxa9YsWrRokW78tWvX0lpPp7az9vf3p3fv3mntrPVp3759GWbLPD090zrVZUWr1TJmzBgOHz7MO++8k6FVt8g9SXz05cgRiImBnNbItmsHQ4eq5/1nGtr1qVI3nXFwUOV4QUHwwQeq3fW0adLuWgghhAgLgxcqZ0x6Ujk5gGclNa5HD/3GlomQkBA6derEo0eP2LlzJ8HBwfTt2zfTVtCpvLy88PDw4Pr167Rs2VLPEWetVKlSNG7cmBkzZhAQEMDkyZMzJD61a9dm1apVwL9d3Qwpsz2PAgMDn5n4jBs3jrVr19K1a1fee+89HUb4/JDER18OHlQd0zJZRJgpMzM1/tChDImPtakp9mZm+d/L51msrVWnuY8+UknPpUuwfLm0uxZCCPF8u3oVrXP2Hc60zvZorlzRU0A5Y2VlRevWrbl//z4jR44kJCSEqVOnZjl+06ZNaLVaTI3wS8/KlStTsmRJzp07R3x8PMWNYGYtK0OHDs3QjvtZQkJC+P777+nUqRPjxo3TUWTPH+nqpi+PH8OTErUcs7JSz8tEaktrnTMxUaVuM2fC2rVq3c+NG7p/XSGEEMJYubioRgbZ0Fy7Da6uegoodzp06EC1atXYuHEj0dHRWY4zMTExyqQHICUlhUePHgFqHUxR8uWXX7J48WI6dOjAhAkTZF1PAZLER1+cneHcudw959w5cHLK9JSbpaVuS93+a9gw1Zzh8GHV8e3UKf29thBCCGFMAgPh79Nw/Vbm56/fgugzapwR0mg0DBw4EK1Wy8yZMw0dTp5s2LCBx48f4+7ublT7C+XXjBkzmD9/Pu3bt2fSpElpbaxFwZBSN33x84N+/dRaGQ+PZ48/d06Vufn5ZXq6jIUFR+LjCzTEZwoM/LfddaNGqt11w4b6jUEIIYQwNFtbGP0xJpO+JiW4T/q1PtdvYTJpIYwabRSNDbLStm1bZs6cybZt2zh8+HCWa32MwdPtrOPj4zl9+jS7d+/G1NSUUaNGGTi6grNmzRrmzJmDra0tZcuW5euvv84wplWrVnh6ehoguqJBEh99sbFRjQKmToUnf3mzNWUK9OyZ5XoaN0tLriUkkJSSgpk+vw3w8fm33XXLlvDdd0b7jZYQQgihK5qPPkILmIz4zz4+f5/+dx8fI2ZiYkL//v0ZPXo006dPZ0IWewcag6fbWZubm+Pk5ERAQAC9evWiZs2aBo6u4MTGxgJqr6I5c+ZkOsbNzU0Sn3zQaLVaraGDMISYmBh8fX2JiIigbNmy+nnRGzdU4vDuu6p0LCvTpsGYMTBvHrz5ZqZDvrl8mYEnTxLTsGFae2u9unFDtbvetw9mzMj+/RjIgQMHqFu3rqHDKHLkvuqG3FfdkPta8ArLPY2OjtbPB8S4OLUG9soVtaYnMDBPMz3G0H2sKJL7qhu6vq85+fubl8/yMuOjT46OqkV027bq55Ah0KqVaiCQkqKOzZoF0dFQsaKa8UlJybQVZpnUltaPHxsm8XF0hIgIeOstlcidPw9ffqneixBCCPG8sLU1ipbVQohnk0+p+lahgmpt3b49jBihEohKlUgpXVo9btdONRD44w9o3lyVx02fnuEyqcmOzltaZ8fGBn78USU+06dDly7w8KHh4hFCCCGEECILMuNjCMWKqUYHb78N16/DP/9w9Nw5arduDU+3LPzlF1Xq9sEHqrRswoS086mJz2VDt3A0NVWlbh4eKs4rV2DdOjDiRZJCCCGEEOL5IzM+hqTRqDbXVaqQ5OCQPukBte/PDz9A//4QEgIDBkByMgCO5uaYaTSGnfF52nvvqdmfgwdVx7czZwwdkRBCCCGEEGkk8TF2pqYwdy6MHg3z56tyskePMNFocLWwMJ7EB+C119S6n9u3VZvrffsMHZEQQgghhBCAJD6Fg0ajytymT4c1a8DfH/75R21iakyJD6jZnj/+UIs9W7RQZW9CCCGEEEIYmCQ+hcl778HSpfD779CyJW5areHX+GSmalW110/Nmqqt56xZho5ICCGEEEI85yTxKWx69FCzKH//TZl164g11i5qTk6wbZva62foUPjoI9WaWwghhBBCCAOQxKcwCgiAX3/FLSaGf7Ra4qOiDB1R5mxsYPVqGDxY7fHTvTs8emToqIQQQgghxHNIEp/CqnFj3AYNAuBy166qtMwYmZpCaKhKfFatgtatVfMDIYQQQggh9EgSH0PTauHBA/Uzl9wqVQIgtkIFaNUKNm8u6OgKhkYDw4er1tyRkaoBwrlzho5KCCGEEEI8RyTxMZSTJ2HgQChRAhwc8H75ZfX45MkcX6LMk01MY6dNg2rVoH17+O47HQVcALp0ga1b1aatPj6wf7+hIxJCCCGEEM8JSXwMYccOaNwYXF1VovPwISanTqnHTZqo8zngZmEBQKyVlWok0LgxvPmmKi0zVk2bqnbXxYpB8+awfr2hIxJCCCGEEM8BSXz0LS4OOneGlSvh009VsgPq56efwvffq/Nxcc+8VHEzM0qYmnL58WMoWVKVunXoAMOGwf/+l6fyOb2oXl2tSXrhBejYEebMMXREQgghhBCiiDMzdADPneXLoVkz8PXN/Lyvr5oVWb4c3nnnmZcr8/QmplZW8NNPMGAAfPYZ3LypZn9MTQvwDRQQZ2fYvh26dYNBg+D8eQgJARPJxYUQQoiCEBwcTFhYWNpjExMTSpQogZeXF926daN169Zp52JiYvB98tmkYcOGLF68ON21Ro8ezerVqwFYunQpkZGRzMrhPn2BgYFMmjQp1/GvWbOGUaNGpTtmYWFBmTJlaNq0Kf3798fJySnT95DKzMyM0qVL4+3tTZ8+fahVqxYAoaGhuYrfzc1N5+/39u3bfPXVVxw7dozY2Fji4uJwcnKiRo0a9O/fHy8vr1xfU6QniY++bdoEQUHZj+nWDZYty1Hi42ZhQezTm5iamfH6XVP2lKkL6yJhXYMMz5ky5RPeeKNjLgPXgWLFICxMzVB98QVcvAiLF8OTtUtCCCGEyD9fX188PT1JTEzk3LlzREREsGvXLgYPHsywYcPSjTU3NycyMpIbN27g6OgIQEJCAuHh4Zibm5OYmAhA/fr1GTJkSLrnLlmyhLi4OIKCgihRokTacU9Pz3zFX716dVq1agVAfHw8UVFRLFu2jC1bthAWFkbp0qXTjXd2dqZz584A3Lt3jxMnTrBp0ybCw8MJDQ3F19c31/Hb2trq/P1eu3aN1atX4+3tja+vL6VKleLGjRuEh4cTHh7OpEmT6NixY56uLRRJfPTt8WMoXjz7McWLq3E54GZpyfa7d9Mf1KgfL5d3wTE6ClzLQMsWYGYOQMWK7rkMWofMzODrr8HDA0aOhMuXYe1asLMzdGRCCCFEkdCqVSs6deqU9njPnj307t2buXPn0rVrV5ydndPOeXl5ce7cOTZt2kTQky9qt2/fzsOHD2ncuDE7nqxDbtCgAQ0apP9yNSwsjLi4OHr27EnZsmULLH5PT0+GDh2a7tiIESNYt24dq1atYtCT7T1Subi4pI2/f/8+xYoVY8WKFYwfP56QkBB8fX3zFL+u32+lSpX4888/sbKySnd80KBBvPrqq0ycOJGAgADMzc3z/VrPK6kr0rcXXoBdu7Ifs3u3GpcDbpaWXE5IICWT9TyDvxzLjOljmXEykhmRvzLjkyHMmDEWH58X8xK57mg0MGKE6ki3d69q0nD+vKGjEkIIIYqkhg0bUrFiRZKTkzly5Ei6c+bm5vj5+bFhw4a0Y+vXr8fHxwd7e3t9h5ql2rVrA3D9+vUcje/evTvW1tZcunSJ20a6n6CFhUWGpAfA3d2dChUqcO/evRy/X5E5SXz0rX9/WLAA7tzJ/PydO+r8gAE5ulwZCwuStFpuPJl6zqBXL1izBo4eVWuHLl7MW9z60L07hIfDlSvQsCEcOGDoiIQQQojsxcXB0qWqZHvp0hw1JzIGJk/W1JqZZSz+adeuHUeOHOHSpUvEx8ezY8cOAgIC9B1itvY82bi9evXquX6uRqMp6HB06uzZs5w9exYbG5u08kORN1Lqpm+envDGG/DKK6qzm4fHv+fOn1d78VSooDqf5YBb6l4+jx/j/KS9dQavvgpbtqhrN26skot81tvqTPPmqt31K6+o369aBf7+ho5KCCGESE+rRTvlC/j8c/BwRVvSGs29hzBkMHzyCZqPRqiKBiN09OjRtA/SqTMnT6tXrx7Ozs5s3LgRR0dHtFotrVu3JjIy0gDRQnR0NKFPtuqIi4vj0KFD/PXXX/j5+aUr4cvO8uXLefjwIeXLl8fOyMvp4+PjWbRoEUlJScTExPDbb7+RlJTEuHHjsMjqs57IEUl8DOHLL1UHs3r14KWXoEIFkk+fxvTAAahaVZV7zZgB7733zEulJj6XHz/mRVvbdOe2bNnBpk3bSExMomxZV1ot+Y7qA/uqmZ9ffoH69XXw5gqAp6dqd92unUraZs9WM2VCCCGEkdBO+QK+mk5K37Zgp/7/qwW4E4fJV9PRApoRIw0ZYpqtW7cSGxtLUlISsbGxhIeHY2lpycSJE3FwcMgw3sTEBH9/fzZu3IiDgwPNmzfH9j+fMfTp+PHjHD9+PN0xHx8fevbsmWkicPXq1bREKbW5QWRkJKampgQHB+sl5vyIj49P10HO3t6eWbNm0bhxYwNGVTRI4mMIJibw8ccqsdm4Ea5f54K7OxXXrlUdzbp2hfffB0dHtSFpNsqkbmL6dGe3JxYs+D7d4xCg+6s9mPjraixatlQd1Z5qZWlUXF3VRq5du6qyvwsX1LdqRvrtmRBCiOdIXBx8/nm6pCeNnS0pnZtiMmECDBr87IZGehAREUFERETa43LlyjF79myqVq2a5XPatWvHokWL0Gg0TJs2TR9hZunp9tB3797l2LFjhISEEBQUxKxZs2jRokW68deuXUtLHFLbWfv7+9O7d++0dtb6tG/fvgyzZZ6enmmd6v7LxcWFEydOkJCQwIULF1i4cCH9+/fnk08+oXv37voIuciSxMeQihWDLl0AuHPgANjYqOMrVsDt22p9jr29KvvKgouFBSbw714+QMOGdQkK6oy3dw0cHR24fPka4eE7mDZtPt9v3IZVlyA+/y0MAgLUfkFPYjA6xYvDunUweDBMnKiSn2+/lXbXQgghDCssDDxcMyY9qexsobyLGtejh35jy0RISAidOnXi0aNH7Ny5k+DgYPr27ZtpK+hUXl5eeHh4cP36dVq2bKnniLNWqlQpGjduzIwZMwgICGDy5MkZEp/atWuzatUq4N+uboaU2Z5HgYGBWSY+qSwsLKhSpQohISHcvHmTzz77jHr16lGlShVdhlukSXMDY2RpqVo616wJr78O+/ZlOdTMxARnCwsuP5X4DB8+gFdfbU25cmWwsrKkYkV3Bg7swdKlMwBYunoTsd+vggYN1J5Bc+bo+A3lg5kZzJ2rEp8VK6BtW/hv+24hhBBCn65eRVvSOtsh2pI2qlmPEbGysqJ169aMGTOG69evExISku34TZs2sX///kw7jRla5cqVKVmyJOfOnSM+Pt7Q4WRr6NChnDhxIt2v3G5w2rRpU5KTk9n1rM7AIluS+BirEiXUZqeurmpxf3R0lkPL/HcT0yz4+LyIt3cN9Rfn6EnV8CAgAAYNgvHjIZOW2EZBo4FRo9Ts1O7dqkGDMXenE0IIUbS5uKhGBtnQ3Hug/h9uhDp06EC1atXYuHEj0dl8vjAxMcHU1FSPkeVcSkoKjx49AtQGq0XdrVu3ANLes8gbSXyMmbOz6sBmbg5+fnDpUqbD3Cwt05W6Zcfd3Q2A69dvqtK6NWsgKAg+/RSGDYOUlAILv8C9+aZK1mJjwccHDh0ydERCCCGeR4GBcP4K3MmidfWdOLhwVY0zQhqNhoEDB6LVapk5c6ahw8mTDRs28PjxY9zd3Y1qf6H8OHToUKazVxcuXGDlypUAvPTSS/oOq0iRNT7GrmJF2LxZtXb284OdO+GpDixRUVFcnPIlF0+dpbtHed56qztt27bN8huaq1dvAGBj82SK3twcFi1SjRSmToVbt2DxYjDWdoktWqhZn1degWbN4McfVfmbEEIIoS+2tvDJJ5h8NZ2Uzk3Tr/W5E4fJjztVEyMjaGyQlbZt2zJz5ky2bdvG4cOHs1zrYwyebmcdHx/P6dOn2b17N6ampowaNcrA0RWcH374gU2bNlGvXj3Kli1L8eLFuXTpEr/99huJiYl06dKFevXqGTrMQk0Sn8KgTh21yL9tW9XieetWtDY2jBw5isWLl9CufT/e6PQ6N27EMmLEp3z++UR++WVDhj71N27cIirqBAC1a7/w7wkTE5gyRSU/wcGqscLq1ar5gjGqUUO1/A4IUPfjm2+gb19DRyWEEOI5ovloBFrAJG0fHxtV3nb+yr/7+BgxExMT+vfvz+jRo5k+fToTJkwwdEhZerqdtbm5OU5OTgQEBNCrVy9q1qxp4OgKTocOHTAxMeHo0aNERUURHx9P8eLFqVevHp07dza6TWQLI41Wa6wLO3QrJiYGX19fIiIiKFu2rKHD4cCBA9StWzf7QWFhqtmBnx/ftGvP9K++YebMCEqW/HcG6MiRfaxePQszs7v88sv6tOPXr99k2LD/sXNnJN7eNdiwYUnmr/Htt2rPnPr1VattY54+jouDzp1V+duYMTBuXLp21zm6pyLX5L7qhtxX3ZD7WvAKyz2Njo7GUx+bdcfFqYZEV66oNT2BgXma6TGG7mNFkdxX3dD1fc3J39+8fJY3+IzP2bNnWbBgAUePHuXKlSskJyfj7u5Ou3bt6NGjR4ZOIkeOHGHq1KkcPXoUCwsLGjVqRHBwMM7OzgZ6B3oUGAhz55LSvz9T9u3no4lh6ZIegEuXznDsWDRabTIdO/ahbNkyXLlynaNHj3P//gPKl3djzpxsurj07auSnW7d1Ean4eHg5qbjN5ZHtrawfj288w589hmcPw8LFhhvmZ4QQoiix9bWKFpWCyGezeCJz8mTJwkPD6devXo0aNAAc3Nz/vrrL7788kt+/fVXvvvuO8zMVJh///03PXr0wNramtdee434+HjWr1/PkSNHCAsLo2TJkgZ+N3rQrx/noqO5v2AxtWo1ynD6hRdepGXL9uzZs5Vjx05w+PDfmJubU6lSefz8Xubtt7tha/uMb6ICA9W6og4doFEj+PVXyGaTM4MyN4f588HDQ836XL6syvSehz8LQgghhBAixwye+DRr1oy9e/emJTepxo0bx3fffUd4eDj+/v4ATJ48mZSUFJYsWUL16tUBqFu3Lp988gkLFy7k/fff13v8hpDUvz+W3/+E5qmyrlQVK1Zn8OBPSU6+h7e3Kx999FHeXqRFC9i+Xa0ratxYJULGWtqg0cAnn4C7u5qxatIEfvnF0FEJIYQQQggjYvB21jY2NhmSHlAbNQGcOXMGgJs3b7Jv3z6aNGmSlvQAdOrUCXt7ezZs2KCfgI2AR4UK3E96zMWLJzM9r9Vq2bdvEw0aNMjfC734IuzapZocvPwy/PZb/q6na0FBKkG7eFG1uxZCCCGEEOIJgyc+Wdm+fTsA5cqVA9TaHq1Wy4svvphunKmpKXXq1CEmJobbt2/rO0yDsLS05O2332bu3GCSk5MznF+/fiE2NhZpyWO+VK2q2keXL69aSK9enf9r6pKvr0rWTJ780Q4PN2w8QgghhBDCKBhN4pPao33SpEl06dKFH374AW9v77Qyt9jYWADc3NyIi4vj7bffZtKkSWnHQHV3KFRSUuDmTbh8GdO7d3O1eeinn45Bo4njvfd82bNnE3fu3ODUqSN88eUgFi36H6tWrcy0FC5P3Nzg99+hXj3o0kWtqTFmNWuqdtegWl4vWmTYeIQQQgghhMEZfI1PqujoaGbNmpX22N/fn5CQECyedOi6f/8+AMWKFWPXrl3s3LmTnTt30r9//7R2eqljciMqKopr164VwDvIGavTpyn9yy/YRkdjFR0N5uZoLSyolZBASmIij6pXJ87Tk5sBATyqXDnba02Y8BkbN27k22+DiYm5hK2tLW3atGbx4oU8ePCAAwcOFGzwX3317+8L+to6ciA1ASok8RYWBf5nSwByX3VF7mvBKwz31MzMLE+fCwypsMVbWMh91Q1d3teEhIRn/jtz48aNXF/XaBKfTp060alTJ+7du0dkZCQTJkygX79+zJkzh+L/6Ydfp04dXF1dqVSpUoZNOnPLy8tLP/v4bNkCEybAmTPQuze89ZZaQ+PwVDvqW7ewOXAAm99/x/mDD6BSJbXzs59flpf18fHhsyetnN9avpwNNWsyv1o1TDw8dPM+EhNV/CtWwHvvwdSp/5aVGZkDBw5Qt1YtGDBAzfr06gXz5qlOcCLPCsseHoWN3FfdkPta8ArLPY2Oji5U+7fIfjO6IfdVN3R9Xy0sLKhdu3a2Y/JS6WU0iU+qkiVL0rp1axwcHOjevTvz5s3jgw8+SDer4+rqmrYGKPUYYJx/sO/ehfffVx3SpkxRLaKz+uDt4ABt2qhfn36qNkQbOFA1Fpg+HUqVyvp1PDxo07YtK+LjOfL223h//z04Ohb428HcHJYuhdKlYcYMVaq3cKHxJhPm5mpT1vLlYexYiI2Fn36CEiUMHZkQQgghhNAj4/yqHvD29sba2ppdu3YB/67jSV3r87TUY3qZucmN06fVrI6VFfz1F7z+es4TBHNz6NxZPc/aWl3n9Olsn9KmZk0AtpQpo9a2xMfn9x1kzsREJWKffw7Ll6t9fx480M1rFQSNRiWSixbBtm1qY9ZM/hwJIYQQQoiiy2gTn/v37/Po0SMSEhIAqFWrFhqNhoMHD6Ybl5yczOHDhylbtiz29vaGCDVz586pvXBGjoQ5c9TOznlhawuzZ6vrtGihrpsFF0tLahcrRnhQEBw8CJ06wZP7V+A0GlWGN2eO2jOnTRu4c0c3r1VQevWCjRvVPfTxgaNHDR2REEIIIYTQE4MnPvv37ycxMTHdMa1WS2hoaLr21Y6Ojrz00kvs2rWL48ePp41ds2YNt2/fJiAgQK9xZ+vxY2jfHkaMUOtLCsKAAep67dur62ehjb09u8zNiV+wAH79VX3Yz0W3uFwbOBB++AEiI6F5c7h8WXevVRDatIGdO9U9adIEIiIMHZEQQgghhNADg6/xmTlzJqdOnaJevXqULVuWxMRE9u/fz/Hjx3F2dmbw4MFpY0eOHEn37t3p2bMnr776KvHx8fz888+4ubnRp08fA76L/xg3Tu1/M2RIwV53yBBVqjVuHEycmOkQP3t7ply6xPZ27Wg3aRIEB6v1ODNnqlkaXejcGezsoGNHaNxYJVzP6EhnULVrq3bX/v7Qtq1aAxQUZOiohBBCCCGEDhl8xufNN9/Ex8eHU6dOsWrVKn744QcePHhAjx49CAsLw9nZOW2sl5cXy5Yto2rVqvz4449s3bqV1q1bs2LFCkplt/Bfn44dUx+k58wp+ERDo1HX/fZbiIrKdEjjEiWwNjEh/M4dNUP0wQcQGpplolRgWrVSSVl8vEp+Dh3S7evlV7lyaqPT5s2hZ0/47DPQag0dlRBCCCGE0BGDz/i0bduWtm3b5nh8nTp1WLZsmQ4jyqfQUDUz81TCVqCcndX1Z82CuXMznLYyNeXlUqXYcvu2SpSmTIHr1+GTT8DJCfr1001cAC+9pMrI2rRRneh+/lklFsaqZEm1PqlfP/jf/+DCBZVYGmuHOiGEECIXgoODCQsLS3tsYmJCiRIl8PLyolu3brRu3TrtXExMDL6+vgA0bNiQxYsXp7vW6NGjWb16NQBLly4lMjIy3f6L2QkMDEzbdD431qxZw6hRo9Ids7CwoEyZMjRt2pT+/fvj5OSU6XtIZWZmRunSpfH29qZPnz7UqlULgNDQ0FzF7+bmpvP3m5kvvviCb7/9FoC//voLS0vLArnu88rgiU+Rcu+eWu/y99+6fZ2334YXXoDJk9WH9//ws7fnvdOnOf/wIR7W1qrd9K1baj1O6dKqC5uuVK8Of/yhkh8/P1i5UpXAGSsLC1i8GDw8YPx4iImBH3/MezMKIYQQwsj4+vri6elJYmIi586dIyIigl27djF48GCGDRuWbqy5uTmRkZHcuHEDxyfbYiQkJBAeHo65uXnauuz69esz5D8l/UuWLCEuLo6goCBKPLVthKenZ77ir169Oq1atQIgPj6eqKgoli1bxpYtWwgLC6N06dLpxjs7O9O5c2cA7t27x4kTJ9i0aRPh4eGEhobi6+ub6/htbW319n5THT58mMWLF6e77yJ/JPEpSFu3QsOG4Oqq29dxdVWvs3UrvPZahtNtnmzqGn7nDv2trdUMxo8/qnK07t3VZqq6nIkpW1bN/AQEqPjmzwdjWoP1XxqNWjfl7q6aSDRrprq/lSlj6MiEEEKIfGvVqhWdOnVKe7xnzx569+7N3Llz6dq1a4ZlBefOnWPTpk0EPVn/un37dh4+fEjjxo3ZsWMHAA0aNKBBgwbpXicsLIy4uDh69uxZoFuMeHp6MnTo0HTHRowYwbp161i1ahWDBg1Kd87FxSVtfOpGmytWrGD8+PGEhITg6+ubp/j19X4BHj9+THBwMB06dGDfvn2Zbucics/ga3yKlP374T9/KXSmfn04cCDTU9VtbChnaanK3VIVKwYbNkDFivDqq3DkiG7jc3BQiVmrVtC3L3zxhW5fryD07asSntOnVbvrY8cMHZEQQghR4Bo2bEjFihVJTk7myH8+D5ibm+Pn58eGDRvSjq1fvx4fHx+j2jakdu3aAFy/fj1H47t37461tTWXLl3i9tOfj4zUjBkzuHfvHiNHjjR0KEWKJD4F6eBBqFtXP69Vt26WiY9Go6GNnR0Rd+6Q9HQrawcHNdtTooQqQzt7VrcxFi8O69dD165qH6KPPjL+BgJ+fvD775CUpJo0bNtm6IiEEEIYs7g4WLpUfcG3dKl6XAiYmKiPgGZmGYt/2rVrx5EjR7h06RLx8fHs2LHDuLYNQc1agSqDyy2NrrrcFpCDBw+yePFiRo0aZTzNu4oIKXUrSNev6688qkwZ9XpZ8LO359urV4mMi6PR0+uAypWD8HC1h02bNrB7t+4aMYBaQ7NihUq6vvwSbt5UpW+Z/ENrNLy9/2137ecHixbBm28aOiohhBDGRKtFO3kyTPic5NKl0FqYoElIwXTwIPj4EzQjR+puG4l8Onr0KGfPnsXGxiZt5uRp9erVw9nZmY0bN+Lo6IhWq6V169ZERkYaIFqIjo4mNDQUgLi4OA4dOsRff/2Fn59fuhK+7CxfvpyHDx9Svnx57J4sCTBGjx49YtSoUTRq1IhXX33V0OEUOUb86bMQSk4GU1P9vJaZmZqVyIKvnR0mQPjt2+kTHwBPT1XS5esLr7wC27erWSBdMTVVXeicnGDsWLh9WzU9sLbW3Wvml7u7ancdGAhvvaU6vo0aZbT/ExNCCKFf2smT0U6bwqOGVdHaWKUd1zxwwmraFPX74GBDhZfO1q1biY2NJSkpidjYWMLDw7G0tGTixIk4ODhkGG9iYoK/vz8bN27EwcGB5s2bY2vApj/Hjx9Pt3k9gI+PDz179sTCwiLD+KtXr6YlSqnNDSIjIzE1NSXYSP6bZGX69Olcu3aNBQsWGDqUIkkSn4JUrJj+prjj4lQpWRbszc15ydaWLXfuMLZChYwDfHzgp5/Uep/AQNXWWZctEjUa+PRT1VVu6FC1cejPP2falc5olCoFmzertT8ffwznz8Ps2cY9WyWEEEL34uJgwucZkh4ArY0Vj+qUx3rCBLX9RDb/r9aXiIgIIiIi0h6XK1eO2bNnU7Vq1Syf065dOxYtWoRGo2HatGn6CDNLT7eHvnv3LseOHSMkJISgoCBmzZpFixYt0o2/du1aWuvp1HbW/v7+9O7dO62dtT7t27cvw2yZp6dnWqe6VPv372fp0qV88MEHlCtXTp8hPjdkjU9BeuEFOHpUP6919CjUqJHtED97eyL/+Yc7WbVAfOUVVcb1229qViM5WQeB/sfgwfDdd7Bnj+osd/Wq7l8zPywtYdkyGD1alei9+qrapFUIIcTzKyxMlbf9J+lJpbWxIrl0SXhqDx1DCgkJ4cSJExw5coRZs2Zx584d+vbty82bN7N8jpeXFx4eHlhbW9OyZUs9Rpu9UqVK0bhxY2bMmEFSUhKTJ0/OMKZ27dqcOHEibaZnx44dTJ8+3SBJD5C259HTv7Zu3ZpuTFJSEqNHj6Zq1ar07t3bIHE+D+Sr64KUTcOBAnfgwDMbKbSxt2f8hQtE3LnD609t8JXOW2/BjRvwwQfqm6nZs3VfztWtG9jbq5mmJk3UmqOKFXX7mvmh0cCECVC+PAwapBK2DRt037ZcCCGEcbp6Fa1F9t8day1N4MoVPQWUM1ZWVrRu3Zr79+8zcuRIQkJCmDp1apbjN23ahFarxVRfZfy5ULlyZUqWLMm5c+eIj4+nuBHMrGVl6NChGdpx/9eDBw+4cOECADWy+GI7NXH7888/0+0bJHJOEp+C1LQpTJqk1t7oshwqKUklC++9l+2wBra2lDQ1ZUt2iQ/A++/DtWtqQ1RnZ7UOR9fatFEzTf7+qnvali1goG9icqx/f7VHUZcuah+lX35Rs3xCCCGeLy4uaBJSsh2ieZxitF+QdejQgYULF7Jx40befvvtLDfcTO38ZoxSUlJ49OgRoDZYLewsLCx4M4tGSmvXruX+/ft069YNU1PTTNc1iZyRxKcg1awJbm7qA7EuO3Fs3Kg+gHt5ZTvMzMQEXzs7tty+jVarzb59Y0iI6hI3bpxKft55p4CDzkSDBmqjUz8/tWnohg1qBsiY+furdtcBASphW7tWt5vBCiGEMD6BgZgOHoTmgVOm5W6aB48wvXlPVTYYIY1Gw8CBA3n//feZOXMmc+fONXRIubZhwwYeP36Mu7u7Ue0vlFdWVlb873//y/Tc9u3buX//PqNHj8ZSl+uxnwPGm8oXVoMGwbRputuvRqtV189hYtLG3p5Ljx9z4sGD7AdqNDBvHrRvr9bh/PhjAQSbAy+8oFpqu7hA69Yq+TF2L76o1ii5uqqZq++/N3REQggh9MnWFj7+BKvDF9A8eJTulObBI6wOX1BNcYy4/Kpt27Z4eHiwbds2Dh8+bOhwspXazjo0NJSQkBD69u3LiBEjMDU1ZdSoUYYOTxQikvgUtG7dVLeXhQt1c/1vv1WL67t1y9HwNk961W+5c+fZg83MVJvpRo3U2p/ffstPpDnn7q5mfry8oGNHtQGcsfPwUAlbw4bwxhuqTNDYN2cVQghRYDQjR6L54COs95zE8shFLI7HYHnkItZ7TqL54CO1j48RMzExoX///oBqoWzMjh8/ntYUYMWKFZw7d46AgAB++OEHo2q8IIyfRqt9Pj+txcTE4OvrS0REBGXLli3Yix89Ci1bQmQkZNZKOq/OnYP69VVCUrNmjp9Wdd8+qlhbszGna2ju3FGlZ+fPqz1+ntFEocDExamygIgImDpVNVzIhwMHDlBX17E/fgy9eqmE8Z134Kuviny7a73c1+eQ3FfdkPta8ArLPY2Ojs5y7UqBiotTZc9XrqhKgMDAPM303L9/n2LFihV8fM85ua+6oev7mpO/v3n5LF+0P6EZSs2aqkGAnx/s2FEwixuvXFHXGzs2V0kPqLbWC69c4XFKCpY5WahoZ6f2r2ncWLW83r0bqlTJW9y5YWur1i+99RYMH666zU2caNybhlpawooVquPb5Mlw6ZJKguQfWSGEeD7Y2kKPHoaOQgiRA1LqpiuDB0OfPmqxfn739omKUutKHBzUGqJc8rOz40FKCrvu3cv5k9zcVOc4rVatY9FXS05LS5U4DBigOuT176+62BkzExMV6+zZqrHFyy+rLnlCCCGEEMJoSOKjS8HB8Omnquzt888hq41Es5KYqJ7XtKna6HPvXvjyy1yH8XKpUphrNITfvp27J1atqj7I37gBbdvC3bu5fu08MTWFOXPgk09gwQLVPvrRo2c/z9DeeQfWrYO//wYfHzh+3NARCSGEEEKIJyTx0bWgIDh4UJWLVa78b9vo7Fy/rsZVrqyed+QI9O2rzo0YAatW5SqE4mZmNC5Zki25TXwAXnpJ7TwdHQ0dOsDDh7m/Rl5oNPDZZzBzpnp9f3/45x/9vHZ+tGun1kU9eKCaROzcaeiIhBBCCCEEkvjoR7lysGkTrFkDZ86ohOaFF1RN8Pjxam3I+PHq8QsvqPNnzqjxmzaprmdff60aG5iYqDUwu3fnKgQ/OzuO3L/P1cePcx9/69aq09rOnaqDmT5Lz4YNg+XL1Wu3aPHspNEYvPSSmp1zcoJWreCHHwwdkRBCCCHEc08SH32qW1eVbt26Bd99p9aCJCTArVtcuXBBPf7uO3V+wYL03dQsLdXMR+nS6nG7dnDyZI5fus2Tzb1+zUlb68x066ZmX9auhYED9du6+c034eef1axTkyaq25yxq1AB/vhDJavduqkSxeezgaIQQgghhFGQrm6GYG4OdeqoX09cPnAA12e1By1TRiU/L78M9++rjmt794Kj4zNfsk7x4jiam7Pl9m16uLjkLe6hQ9WMy+efg7MzTJiQt+vkxSuvwNatEBCgus1t2aL2/TFm9vbw66/Qsyd89JFK2GbOVGuYhBBCCCGEXsmMT2HTqBHMmqUaH1y4AK++mqN1NyYaDa3t7Pj1zh1S8jPzMH686rQ2caLas0afGjWC339XMyfNmqkZFWNnZQXff68Sn6+/hk6d1PofIYQQOvecblUoRKGmy7+3kvgURv37q3bPyclqxqdHD0hJeebT/OztuZ6YyJH4+Ly/tkaj2jYHBsK776oP9fpUs6ZKeBwc1PqZTZv0+/p5YWICX3yhEtYNGwrPWiUhhCjETE1NScxtN1UhhMElJiZiqqPqGEl8CquvvlIzIBYWsHq16vb2DK3t7ADy1t3taaamai1S8+aqa92WLfm7Xm55eKjmDtWrqxmvFSv0+/p5NXiwalhx9Cg0bJirNVpCCCFyx9bWln8KQzdQIUQ6//zzD7a2tjq5tiQ+hZWFBfz0k2p2UKIETJ2qSqmy4WppSa1ixQjPa4ODp1lZqT1ratSA116DyMj8XzM3nJxU2+gmTVSXO32X3eVVhw6wbRvExankJ5fd+YQQQuSMvb09d+7c4ebNmyQkJEjZmxBGTKvVkpCQwM2bN7lz5w72T5pyFTRpblCYubqq2Z7mzVWDg6FDVevr9u2zfIqfvT0zYmKIT0qiuFk+//OXLAmbN6tmA/7+sGuXmoXRlxIlVKnbG2+osrsbN9QaJI1GfzHkRYMGsGePatjg66vadb/+uqGjEkKIIsXS0hJ3d3du377N+fPnSU5ONnRI2UpISMDCwsLQYRQ5cl91Qxf31dTUFFtbW9zd3bG0tCzQa6eSxKew8/FRa27efhtcXFTr5B07oF69TIe3sbNjyqVLbL97l3aprbHzw8UFwsNV2Z2fn5rBKFs2/9fNKSsrtaHrwIGq29yNG2rmy9g7p1WqpNYqdegAXbqodtfvv2/8SZsQQhQilpaWuLq64urqauhQnunAgQPUrl3b0GEUOXJfdaOw3lcpdSsK+vaFQYPg6lWwsVF7/GSx102TkiWxNjEpmHK3VJUqqZmfO3egbVvI7xqi3DIzg/nzITgYvvlGJX952ahV30qXVi26O3WC4cPhvfdUwwohhBBCCFHgJPEpKqZPV+td4uNVu2R/f5WI/IeVqSkvlyqV/wYH/+Xtrdb8nDqlSu303bJZo4GQELXW6aefVPJXGFhbqxmrDz5Q65Q6d5Z210IIIYQQOiCJT1GR2uzAwQGKFVMJSKdOmc58tLGz4+TDh5zPwf4/udKiher2tmePKt8yRBvRDz6AJUtUAwGAmzf1H0NumZiohG3mTFi7Vq37uXHD0FEJIYQQQhQpkvgUJc7OEBamZnqqVVNdz95+W234+RS/J50yCrTcLdVrr8GcObBxI/Trl+G19SIoSN0HULNgFy/qP4a8GDZMNas4fFh1fDt1ytARCSGEEEIUGZL4FDUvvQRz58KxY6rb2vLl8Omn6YZUt7GhrKVlwZe7pRowAMaNUzMvI0fq5jWeJbWz3dWr6j5ERxsmjtwKDFSzVffuqYYRe/YYOiIhhBBCiCJBEp+iqFcv1dp69254+WX47DNYuDDttEajwc/Ojog7d0hKSdFNDGPGqA07p0xRZVyGsmMHJCWpmZ99+wwXR274+KiEp1QpaNny39krIYQQQgiRZ5L4FFVTp6r9ffbuVfvGDBgAv/6adtrP3p57yclExsXp5vU1GrVmpXNn+PBDWLpUN6/zLLVrqwSwVCm1diY83DBx5FblyqrddZ06qnywsGzQKoQQQghhpCTxKarMzVW3MEdHuHwZqlRRH6CPHgXA184OEyA8i3K3GzdusWJFGMOHj6dFiy6ULfsSbm71+OGH9Vm+pFarZcmSn2jT5g0qVWqMV+029LYuw1+NmkOfPmrdjyFUrKiSn8qVVbe3H34wTBy55egIERHQsaPaoPWDD0BXM3RCCCGEEEWcJD5FmZOTKpO6cQPs7KB4cdXmOjYWe3NzXrK1ZUsWDQ5+++0PRoyYwMqVP3Py5NkcvdyHH37G6NGTuHgxlpYtG1OtWiXCt+7i1dhH7PSso2Z//vijAN9gLri4qGYPPj7Qvbva9LUwsLGBH39UjQ+mT1fd8gq6G58QQgghxHNAEp+irm5dmDdPJRwtW8LduxAQAHFxtLG3J/Kff7iTSdtpV1dH+vTpytdff87evT/TvLlPti8THv47K1f+jKurM9u2/cj8+V+wevU8pk4dQ2JiEu+ZOfDIrayacTl2TEdv9hlKlYItW1Tjg8GDVQMGQ3Sdyy1TU1U2OG0arFkDrVoVjjbdQgghhBBGRBKf50GPHvDee7BiBQwcCFFR0KULfiVKkAJEZDLr06yZD5999hEdO7alXLkyz3yJb79dCcD777+Nq6tT2vFu3Trg7V2Dq9dvsXH4x2BpCX5+hmsxbW2tWkb36gVjx6qZlMJSPvb++6p88cAB1fHtzBlDRySEEEIIUWhI4vO8mDJFbTAaGqpaTG/eTIPRoylhappluVtOPXjwkH37DgLg59c8w/m2bVsAsC3qlJpxiY9XyY+hZi3MzFSXuw8/hFmz4M03ISHBMLHk1uuvq3U/t2+rvX4KS6c6IYQQQggDk8TneWFmphb1u7ioDmvDhmE2bx6+N26w5fZttPko+Tpz5gKJiUk4OTlQurR9hvMvvFAFgOPHz0CtWrB+PZw/r0ru4uPz/Lr5otGoZHDyZFi5El59Fe7fN0wsudW4sSpdtLVVyey6dYaOSAghhBDC6Eni8zxxdFTNDm7dgsOHoWtX/BYv5tLjx5x48CDPl71y5RoAzs6OAJw8eZbAwLcJDg4hJSUl7XjqOJo2VUnY/v1qBsOQsy0jRsC336pW376+6t4UBlWrqr1+atZUm57OmmXoiIQQQgghjJokPs8bb29YsAB+/x3s7Wnz5PCW/fvzfMn791WXMWtrKwCWLv2JyMjDLFu2mmPHTmJjY/1k3FPJ1auvqqYLW7ZA796GXWfTp49a93P4sErKYmIMF0tuODnBtm3qXg4dCh99VHjWKwkhhBBC6JmZoQMAuHr1KmFhYfz2229cunSJ+/fvU65cOdq3b0/fvn2xsLBIG/vw4UO+/vprNm3axLVr1yhZsiRNmjThgw8+wNnZ2YDvohB54w04eBCmTqVCaCiVr15l1R9/UO6vv7CoUIE6depQtmzZPF++bdsWhIVtoWrVClSu7MHVqzcyH9i3L1y/DqNHqw/x06apEjRD6NgRNm9WSUTjxmqj02rVDBNLbtjYqKTt3Xfhyy9V04glS8DKytCRCSGEEEIYFaNIfL7//nvmzp2Lp6cnAQEBmJubs3v3bmbMmMGePXtYtGgRpqampKSkMGDAAPbt20edOnVo06YN586dY+3atfz555+sXr0aOzs7Q7+dwmHSJBIPHmT2Bx9wz6UM/5hYEOr4N0mW5kQdi6Rp02YEB39Eo0aNnnmpYsXUjM7Dh48AaNLkJY4di0g7/+DBwyfjbDI+OTgYrl2DGTPA2Vk9NpSXX4YdO6BtW2jSBDZtgnr1DBdPTpmaqqYVFSqohg2XL6t1P/YZ11sJIYQQQjyvjCLxqVWrFj/++CO1atVKO5acnEz//v3ZtWsXv/zyC+3bt2fnzp3s27ePVq1aMWvWLDRPZgcWLFjAlClTWLhwIcOHDzfU2yhUHiYm8qpWwz/VX+KzwZOpVatx2v188CCeLVtW0KFDJ6ZMmUyvXj2zvZarq5ppu3Yt85md1OOp49LRaNRMz40bMGqUWofUt28+3lk+eXvDrl3Qpo1qHLB2rVr7Y+w0Ghg+HMqVU+3LGzWCX36BihUNHZkQQgghhFEwijU+vr6+6ZIeAFNTUzp37gzAwYOqVfK+J617u3btmvYhHSAoKAgzMzM2b96sp4gLv7ffHoDGvDRTZ++gdu0m6e6njU1xAgMHMGvWDkaMCGbbtm3ZXqtSpfKYm5tx/fotbt68neH833+fAqB69UqZX8DEBBYtUi2u+/c3fJeyKlVg927w8AB/f/jpJ8PGkxtdusDWraqEsGFD+PNPQ0ckhBBCCGEUjCLxyYqpqSkAlpaWANy7dw8AJyendOMsLCywt7fn4sWLxMXF6TfIQuj06dNs3ryJ0aMXY2aW9aRf+fLVGDz4S8aPn5Dt9WxsrKlf3xuA8PDfM5zfvHk7AC1aZFM2Z2GhEox69aBbN9i589lvRJfKlFENIOrVU8nEvHmGjSc3mjZV7a5tbFT53vr1ho5ICCGEEMLgjDrxCQ8PB6Bp06YAlCxZEoAbN9KXVCUkJHD7tpppiI2N1WOEhdPs2XPx9++NlZX1M8e2aPE6R48e5f4z9rh5++1uAEybNp8rV66nHV+5ch2HDkXh7FyagIBnlIwVLw4bN0L58tC+Pfz117PfjC7Z2ak216+8AgMGwIQJkI/9jvSqenXYuxdeeEE1bpgzx9ARCSGEEEIYlEabn50rs/Hjjz9y8OBBQkJC8vT8ffv20bNnT3x8fFi8eDEA27dvZ8CAAbRt25YZM2aklWfNnz+fL7/8ElCNEl588cVnXj8mJgZfX19mzpyJo6NjnmIsrHr37segQTOpU6dplmPu3LnJ5MkfAhAbe5qkpCQSEpJwcSlNiRK2AFSq5M4777yR9pwZMxbz2297KFbMmtq1Pfnnn3iiok5iZmbKmDFD8PZ+QbdvTAghhBBCPBdu3LjBu+++S0RERI67EeusucHBgwdZu3ZtnhKfy5cvM3z4cBwdHZkyZUra8WbNmlG3bl02b95M9+7d8fb25ty5c+zcuZN69eqxf//+dGtVcsLLyytfrZsLyoEDB6hbt65eXkujASurTDqsPSUxMYFTp6IyHL969SZXr94EwMHBLl3MS5e+yJIlP7J8eRgHDx7DysqSVq2a8sEH/ahdO5dJz7FjqmTLwUGtt/lPeWNOFOg9TUlRzQNmzIC33oKFC8HcvGCurWtJSTBsmJr16dYNFi+GJ+WjeaHPP6vPE7mvuiH3teDJPdUNua+6IfdVN4zhvsbkYd9FnSU+KXncSPHOnTv07duXhw8fsnz58nSzMSYmJsybN48ZM2YQHh5OVFQUFStWZPbs2WzevJn9+/dTokSJgnoLRZazszOXL5+jevWs/8A6OZVh9Wq1qekH/Rry4aAgOr3zTrbX1Wg09OrVhV69uuQ/yBo1YMMGaNVKNRjYtg1sbfN/3bwyMVHd5xwd4eOP4fZt+PFHtY7G2JmZwddfq2YNI0eqdtdr16pSPiGEEEKI54RO1vikpKTw999/U6xYsVw978GDBwwYMIDY2FjmzJmDp6dnhjHFixfnk08+4ffffycqKoqff/6Z5s2bc/LkSczNzXF3dy+ot1FkvfVWd3755dscjb1y5TzHTx2h7fTp6sO+PjVqpJKLw4chMBAeP9bv6/+XRqM2W/3mG7XZaevWcOeOYWPKKY0GRoyA775Ta38aN4bz5w0dlRBCCCGE3jxzxmft2rW5uuDdu3f59ddfOX36NC1btszx8xISEhg6dCjHjh3jq6++on79+jl+7sWLFzl27BgNGjTAvLCUHxlQly5d+OCDDzl2bB81ajTIduzSRZ8R9Oqr2KwLU8lHeHi+yqRyLSBAlZX17AlBQeqD+5NufwbTv78qwXvjDWjWDLZsUV3gCoPu3VWsHTuqdtcbNoCUAAghhBDiOfDMxCc4ODjX62a0Wi1ubm6MHDkyR+OTk5P58MMP2b17N5MmTcI3mw0j4+LisH2q5OnRo0f873//Q6vV0qNHj1zF+byysrLi22/n069fR774YkOmJW9arZb588YQ/etKFoathsAO6oN+nz6wbJkq/dKXoCC1L81HH6lSs9BQNYNhSK+9Bps2QYcOavYkPFzt/1MYNG+u2l2/8or6/apVqpxQCCGEEKIIy9EaH3d39xx1SgOws7OjSpUqBAQEYGFhkaPnzJo1iy1btlC1alUuXbpEaGhouvOenp60atUKgPHjx3Pt2jU8PT1JTk7mt99+IzY2lk6dOqWNEc/WoUMHUlJS6Nu3DfXq+dKuXX/KlatCUlIC+/Zt4fs1X/OPjTn7KlXArndvOHAAJk5UpV4eHqq1sz59+CFcuwZffqkaHfzvf/p9/cy0bKnWHr3yCjRposrfvL0NHVXOeHrCnj3Qrh28+irMnq1msoQQQgghiqgcJT4vvvhinttS58SVK1cAOHnyJCdPnsxwPjAwMC2pady4MYsWLWLVqlVotVoqVarEwIED6dy5s87iK6oCAwPx9fVl2bLlLFr0MVeuXMbc3IK6devy2dfT6G9tzWRLS5a0aQOdOsH27XDunEqAPDygXz/9Bjx5Mty4AZ9+qpKfgQP1+/qZqVcPdu2CNm3U7MnPP6tNQwsDV1fYsQO6dlX7FJ0/D59/rt/ZPCGEEEIIPdFZV7fcmDRpEpMmTcrR2I4dO9KxY0fdBvQcKVGiBIMHD2Lw4EEZzp05e5aJFy/SY8UKWnXoAEOGqJmBixfhnXfA3R38/PQXrIkJzJ8PN2/CoEGq7O211/T3+lmpVk213Pbzg7ZtYeVKtYamMCheHNatU/czJAQuXFBrqvS5jksIIYQQQg+e+dVu9erVKVNYFm6LAjWmfHmqWFszwMmJB//7H3z7rfr144/g5QWvvw5Hjug3KHNztSalYUO15mjbNv2+flbKloXff1elbq+9pu5TYWFmpjrVTZigmke0bQt37xo6KiGEEEKIAvXMxGft2rUMHTpUH7EII2Nlaso3Vaty9tEjPgsKUh3Whg1T7aU3boSSJdWxPGwglS82NrB+vWom0KEDHDqk39fPioMDbN2q2ly//bYqzdNqDR1VzqS26l6+XM1eNW6sZvaEEEIIIYoIKeYX2WphZ0dvFxemXLrEX/PnQ8WKaqZHq4VffoF//lHJzz//6Dcwe3vVTKBUKTVDcfq0fl8/K8WKqXU+3btDcLDqRJfHzXwN4s03VXvu2Fjw8TGepFIIIYQQIp/ynfgkJydz+/Ztbt26RVJSUkHEJIzMlEqVsDc35+3Ll0kOC4OHD1Wzg6pV4aef4Ngx6NwZEhP1G1jZsqqNdHKyWl9z9ap+Xz8rFhZq5mTIEJg6VbUAL0x/N1q0ULM+ZmZqn6LNmw0dkRBCCCFEvuU58fnxxx/p1q0bderUoXHjxjRp0oQ6derw+uuvs3LlSrSFpcRHPJODuTkzK1fmz7g4vi5RQu3j8+efqsFB69Ywb55KQN55R/+lXdWrq5mna9fUzM+9e/p9/ayYmMBXX8G4cbBkiUoUHz40dFQ5V6MG7N0LlSurltfffgu3bsGiRTj8/LNqMCGEEEIIUYjkOvF5/Pgxffv25X//+x+HDx8mMTERjUaDRqMhKSmJqKgoxo0bR69evXj8+LEuYhYG0M3Jibb29ow+e5aLfn6qpfTixfD112pG45NP1IfjiRP1H1z9+rBmjZp56tABHj3SfwyZ0WjUfkOzZ8OGDWpWqjA1DShTRjVsaNUK3n4brUd5tD+tpOyfe9BWqaI2cBVCCCGEKCRynfjMnTuX3bt3U758eaZOncru3bv5+++/+fvvv9m9ezdTp06lfPnyREZGMmfOHF3ELAxAo9Ewu0oVtMDgU6fQjhmjNr58/321F8z48Wp9yCefwIoV+g+wTRs1s7Jjh+r2lpys/xiy8s47qsX13r1qjx9jKcnLCVtbWL0ara0tfDMdZk7E9KsQmPsl2l69QL7cEEIIIUQhkevEZ/369djZ2bFy5UoCAgJwcHBIO+fg4EBAQAArV66kZMmSbNiwoUCDFYZVwdqa8RUqsOHWLVbfuqVK3ipXVut7Ll1SMz4vv6xmgHbs0H+Ab7wBM2ZAWJhKNoxJly6qE97p06pj2pkzho4o5/7+G8qWgfov/nusbh0oZg2BgTBiBEybphLeiAiIilKlcIWpqYMQQgghirxcb2B67do1fH19KVWqVJZjSpUqhY+PD7/99lt+YhNG6F03N767do2hp0/j+9JL2K1dq0rNOnWCnTtVyVnjxmoDzz/+AE9PPQf4Lly/rkruBgzQ72s/S+vWKjHw91f3aMsWqF3b0FE9m50d3LoNiUlg/uSfjKQkuHNXtTaPiICEhIzPMzMDJydwdgYXl+x/2tmp0kAhhBBCCB3JdeLj6upKfHz8M8fFx8fj7Oycp6CE8TIzMWF+tWq8dOAAwWfP8k21auqb/ldfVYnGkiWq2UCDBuoD/t696oOtPn3+uUp+AEJDwZj2oWrQAHbtUqV5zZur/YiaNjV0VNmrXBlq1oKJU+H9QSpBmTEX6nirDWS1WtVU4upV1WQiq59//aV+Ztbhztxc/TnJSZJUsqQkSUIIIYTItVwnPp07d2bmzJkcOnQIb2/vTMccOHCAvXv3ysanRdSLtra8X7YsU2NieMvZmabt2qnuZf/7H9Stq2ZdNmxQZW/t2sH27Wp/G33RaGDOHDhyRMXi5ARdu+rv9Z/F01O1i27TRv1atQratzd0VNnSrFqFdsgQaPyKSnQ6dkTz009PTmrUfkqlSqkue9lJSYE7d1QClFWSdPkyHDyoktfM1mpZWmafGD39e1tbSZKEEIXOg1u3uPD771w/epTrUVHcOXcOtFqaf/op1Yz8/xdCGLNcJz41a9bEy8uLoKAg2rdvT4MGDXBycgJUGdy+ffvYsGEDNWrUoHbt2vz555/pnv/SSy8VTOTCoMZVqMBPN27Q/+RJDterh+XHH6sPq8OHQ61aai+Y779Xa0DeeEOVwJma6i9Asyd/tJs0gR491IanrVvr7/Wfxd1dzfz4+6t79O230LOnoaPKmr09mu++g6QkDhw4QN0GDfJ2HRMTcHBQv154IfuxKSmqhXZ2s0gXL0JkJNy4kfmaImvrnM0iOTtD8eJ5e09CCFHALv3xBzsnTPj3gHyBI0SByHXi06tXLzQaDVqtlrCwMMLCwjKM0Wq1/PXXX/Tu3TvdcY1Gw99//533aIXRKGZqypyqVfE/epRJFy/yqYcHLF0KPj5qIf/+/ar8beZMVWr2/vvq9/r+x/vnn1VJWWCgKssypsS7dGm1PqZTJ+jVSzUEGD7c0FFlz8zs36RS10xMwNFR/fLyyn5scrK6f9klSWfOqHVnN29mvt9UsWI5T5JsbHTznoUQAijm6EiNrl1xrlkT51q12BkSQsyePYYOS4hCL9efYGTGRqR6xcGB7k5OTLxwgS6Ojnja2sLatSq5CAxUMxpDhsDZszB9OlSooBIgfSpVCjZvhkaN1OzKrl1QrZp+Y8iOra0qC+zRAz78UM1chITIt3u5ZWr6b1JSq1b2Y5OS1H1OTYgyS5JOnFB7GN26lfk1bG1zVmrn7AxWVgX/foUQRVpZHx/K+vgYOgwhipxcJz7Lli3TRRyikJpRuTKbb9+m/8mT7KhTB5MqVeC779Tann79YPly+PJLuHBBzWaUL69mOPTJ1RXCw1UnNT8/9a1/mTL6jSE7lpaqLNDBASZPVjMSc+fqb2bleWNmpv5MuLo+e2xCQvokKbOfUVFq5u7OncyvUbLks2eRXFwK9j0KIYQQIgP5ZCXyxcnCgqmVKtHnxAkWXLlC/zJl1MzK55/Dxx+rZgcffKASoJYt1San27apkjh9qlIFNm1SDRf8/NS3+XZ2+o0hO6amMHu2asQwfryaafj+e5ktMDQLC3BzU7+e5fFj1ZAhuyTp8GH1859/Mj5//36V/GY1e/T0T0dH1QlPCCGEEDkmiY/It14uLiy9do0RZ87Q3sEBV0tLGDVKNTv46CNVetSqlVpv4+OjOpjt3QuVKuk30Lp1VSmev7+KITzcuNZqaDSqO17p0jBsGLzyCqxbByVKGDoykROWllCunPr1LA8fZiyzA+jW7d9j+/ern1ltH1C6dM662zk66rexiBBCCGGk8pz4nDt3jrCwMI4cOcLNmzfRarU4ODhQs2ZNAgMDqVKlSkHGKYyYRqPhm6pVqfXnn7x7+jSratRQH+IXL1ZrJbp2VR/iKlRQsy4NG6rk448/1Dfc+uTrq2afunZVv8LCjK+kbOhQdV969lQzVJs26X8vJKFb1tbg4aF+pTpwAL7+OuPY+/ezb/997Rrs2aN+PniQ8fkajUp+ctK4oXRp1VRCCCGEKILy9Ilv9uzZzJ49m+TkZLRPdUc6e/Ysf/75J0uWLGHAgAEMGzaswAIVxq2qjQ1jPDz45Nw51t+8SfvSpVV74LVroV491exg926oWlXNYrRqBR07wq+/6r+cq3NntY5m0CDo31+1kja2ZgJvvKFK8V57TbXkDg9XiaN4/hQrBhUrql/Z0WrV7NCzkqSTJ9XPR48yXsPUVCVJ2TVsSP1pby9JkhBCiEIl14nP2rVr+eqrr7C0tKRTp074+Pik7eNz/fp19u7dy7p165gzZw5ly5alk74XsguD+ahcOVZev86gU6d4uVQpbM3MVDnbypVqhqdvX7VupUkTWLJElfX06qWaIej7A9Q776gPf+PGqXU1kybp9/Vz4pVX1KL5gADVmCE8/NltncXzS6NR3eZsbaFy5ezHarVqnVFmidHTv//7b/UzISHjNczM1N+dnLT/trMzvi8XhBBCPHdynfgsXboUCwsLli9fTs2aNTOc9/f3p0uXLnTv3p3ly5dL4vMcsTAxYV7VqjQ+dIhPzp1jZmq5o58fTJwIwcFqnc1HH6kys/Pn1TEPD8MkHp9+qj7UTZ6sPpzpu9V2TjRsCDt3Qps20LQpbNyoWnMLkR8ajeo2V7KkmoXNjlYLd+9mP4t09Sr89Zf6fVJSxmtYWOQsSXJxUWva8pskXb2K9quZcOgQbi4uMGGicXVyFEIIYRC5TnzOnDlDw4YNM016Unl5edGoUSP27duXr+BE4dOwZEkGlSlDaGwsbzo7Uz91Yf6IEarZQXAw1K6tPsiPGAHnzqnEo0IFGDBAv8FqNDBrlip7++ADVeLz1lv6jSEnatRQZYJt2qgSwZ9+UjNoQuiDRqNmbOzsoHr17MempKi23tklSbGx6t+C69fVxrP/ZWmZs1I7FxdVTvvfJOnKFbT16qL1roa2TmUco06jrfsimj/3Q9myBXdfhBBCFDq5TnyKFy+OVQ7WZFhaWlKsWLE8BSUKt4kVK7L25k36nTjB/rp1MTcxUR9OFi6E6GhV4vbnn6oMbtYsuHQJBg8Gd3dV3qVPpqaq2cGtW9C7t2oqoO8YcsLDQ22++sor0KGDahzx5puGjkqI9ExM1N8hBwd44YXsx6akqL932ZXanT8P+/apJOmp9aRprK0zJETaY1Fo61RF+/ZrakyD2mhNwmBUMJpRo9XfeTOzf38+/fv/Hkv9t0sIXUpKgj17KB4drbqgSqt6IXQm14mPr68vmzdv5vbt29jb22c65tatW+zdu5c2bdrkO0BR+JQwM+PrqlXpGBXF1EuXCC5fXp0oVix9s4M//lDf2P7wAzRrppoO7NwJ3t76DdjSUsX18svw+utqXY0x7pjt5KT2QAoMVDNTN2/Cu+8aOioh8sbERM2yOjpCNhUEgJoZunkz+1K706fVlwMP4tG+3zPd07Xe1dFMWQjLV+Q+zpwkSLo4pu/Xy80xUImoJIX5d+QI2gB/MDehUkoK2rH/Q7N+oyoLF0IUuFwnPh999BEnT56ka9euDB48GB8fHxwdHYF/mxvMnj2bChUqMGLEiAIPWBQOHUqXplPp0oy7cIHXHR2pnLpfTsWKKtFp21bNsKxapZKfDRtUshEQoPb4cXfXb8AlSqi20Y0bqxh27QJPT/3GkBMlSqh1Pm++Ce+9BzduwGefyQcQUbSZmv5b8vYsw4ah+Tsabb1/G4Fojp2B5i9Dr97q2/XkZPXz6d/r8lhSkuqil5/rZFYWaCj796vEtbAmbrpORnM6U5iSgrZTR7QNKqOtXQkNkHLsPCYdXuXhgYOEjxyZNvTu+fMAHFywgOjVqwEoXb06TYKDdfAfWIiiK9eJT/369dN+P2rUqCzHxcTE0KBBg3THNBoNf//9d25fUhRSX1WpwtbISAaePMmvtWujSf0fQevWal3PRx+pn8HBauHxL7+kTzxKltRvwM7OqnNa48ZqPc0ff+RsM0p9s7JSCePAgTBhgvom/OuvZZNKIQDNhx9Cvbpgaoq2VlU4egrN9v1oIv8s3C3htVpVHmiIxO2/xwD+97+Cu96jR/m/jrHJSYKUnAz3bqOt9fK/z6vhAXuOk3zwINejojJcNi42lrjYWPUSFhb6eS9CFCG5Tny0mdVZ6+G5ovBxs7RkUsWKDDp1imXXrhHk4vLvyeHD1QLn0aNVs4NXXlGtmtesUbNBr7+uEiF91zpXrAibN6vSOz8/VXqn701Wc8LUFObNU2VCISFqrcTy5apsT4jnmbu7SnImT0KzKZKbZdxw3BdZuJMeUDMIpqbG8QXHgQNqKwBjkVlSaOjkMCfHbt2C37eBFtA89V6SkrF1caH//v2GvKtCFEm5TnyOHz+uizhEETWgTBmWX7vGB6dP84q9PY6p31BpNLBggWp28MYbqtlB5crg6wvz56syuP79VUMEfZdx1a4NP/+sEp+AALXmxxgbdWg0qk24o6PqSnfnDoSFqX1chHieeXigmTMXgIsHDuD4rM1fReFmTElhbmi1UKc2mj+OoW30AqBBsy8aSpSEOnUMHZ0QRZJsuy10ykSjYV61avyTnMwHZ86kP2ljoz6om5pCx44QF6eO9+qlyigWL4bPP9dzxE80b642W/3zT9V0ITHRMHHkxPvvqw1ht2+Hli3Vuh8hhBDGTaNBs+5nNLeTMflqLcxYjebKQzQbfpF1m0LoiCQ+QudqFCtGsLs7y69dI/z27fQnPTxUs4Pjx1XCk1oOOXYsBAWpBGjZMj1H/ERgIMydq5oe9OmjSimMVVCQ6kwXFaU2Or140dARCSGEeBYPDzT7D6A5cIi/lyxDc+iwqn4QQuiEJD5CL0a7u1PV2pqBJ0/y4L8LUX19YcoUtb5n4kR1TKNRJW8tWkDfvvDbb/oPGqBfPzXrtHy5asZgzOvU2rWDX39V7X0bNQJpJCKEEIVDhQoklC0rMz1C6JgkPkIvrExNmVetGucePWLck7ac6bz3nmrRPGaMatcMYGGhkqEqVaBTJzh2TJ8h/2v0aBg6FKZNUwmaMWvSBHbsULNTTZuq1uBCCCGEEEISH6E/zUuVoq+LC1MvXeJw6nqeVKkzPN7eqtnByZPqeKlSqrubtTX4+6uNCvVNo4EZM6BbNxg5EhYt0n8MuVGrFuzeDXZ2ajZtyxZDRySEEEIIYXCS+Ai9mlKpEqXNzel38iTJ/y0bs7ZWzQ4sLFSzg3/+UcfLl1cbnN68qcq54uP1HjcmJqqBQOvWqvxt/Xr9x5AbFSqo5KdKFWjfHlauNHREQgghhBAGJYmP0Cs7c3NmVqnC/rg4QmNiMg5wd4cff1QzPkFB/zYUqFtXNUE4dAi6d/93Ez19srCA1avhxRehSxe1yaoxc3ZWZW8NG6pZtK+/NnREQgghhBAGI4mP0Lsujo7429vzyblzXHj0KOOAl19W62nWrUvfzrpdOwgNVbM/775rmEYDtrZqDZK7u5pJOXpU/zHkRsmSakPW9u1hyBDVLc+YGzQIIYQQQuiIJD5C7zQaDbOrVkULDD55Em1mH8SHDoWePeHTT9VmoqkGDYIPP4TZs1VyZAiOjhAervYhatsWMmvWYEysrdVMVe/earf1IUOMuzW3EEIIIYQOSOIjDKK8lRWfV6jAxtu3+TGzDTc1GrWHTr168NZbap+fVJMnq01FP/wQfvpJf0E/rXx51TTgwQPw8zP+TUPNzODbb1VL7tmzVelbQoKhoxJCCCGE0BtJfITBDCtblnq2tgw7dYo7iYkZB1hZqXbW1tbQoQPcu6eOpzYaaNRIJUV//KHfwFN5eakmBxcvqo5z/+1UZ2w0GvjiC/Xrhx9U+ZshGkUIIYQQQhiAJD7CYEw1GuZVrcrNxERGnD2b+aBy5VSzg7NnVZKTWqJlba3WAJUrB6++CqdP6y/wpzVpAqtWqaYLnToVjlmUjz6ChQshIgJatYJbtwwdkRBCCCGEzkniIwzK29aWD8qVY8GVK+y4ezfzQc2aqX10NmxQa1RSlS4Nmzap37/yimp3bQjt28OCBbB1q1qXVBjWz/TurWbTDh9WG51eumToiIQQQgghdEoSH2FwYz08qGBlxYATJ3iUnJz5oEGDoE8fGD9e7fWTqnJl1fzg0iVVDvfwoX6C/q9evdTao5UrDddxLrdefVU1aYiNhcaN06+jEkIIIYQoYiTxEQZnY2rK3KpVOfHwISEXL2Y+SKNR+9DUr6/29/n773/PNWoEy5aptT6GnHH56CP44AOYNQsmTDBMDLnVrJna6+fxY1W29+efho5ICCGEEEInjCLxuXr1KnPmzKFz5874+PhQs2ZN/P39mTNnDgn/WTOh1WpZv349nTt35qWXXqJBgwZ0796d8PBwA0UvCkIbe3vecnYm5OJFjt2/n/mg1GYHxYpBx47wdGlc584wZYpaDxQcrI+QM9JoVAxvvQVjxsC8eYaJI7fq1IHdu6FECWjRQpXsCSGEEEIUMUaR+Hz//ffMmDGDxMREAgICePPNNzE1NWXGjBm8/fbbJD9V/jR9+nQ+/PBD7t27R2BgIO3atSMmJoahQ4eycOFCA74LkV/TKlXC1tSU/idOkJJVqZibm9qT5vx5ePNNeLo0bvhwVRI3ZQrMmaOXmDMwMVGNA155Bd55RyVqhUHlyir5qVhRdajLrE34lSuwZw/F/vpL/V4IIYQQohAxisSnVq1a/Pjjj6xdu5YxY8YQHBzM2rVradKkCfv27eOXX34B4OHDhyxatAg3NzfWrVvH6NGjGTNmDGFhYRQrVowFCxYY+J2I/HC0sGBa5cr88c8/zLt8OeuBjRvDV1/BL7+oDU5TaTQwcya0a6c26TQUc3M181S/vtovZ8cOw8WSG66uKtb69aFLF/jmG7VWacsWtAEBaF/wRDt4IJWnT0Vb4wW0Af6weXPhWM8khBBCiOeeUSQ+vr6+1KpVK90xU1NTOnfuDMDBgwcBuHXrFgkJCdSsWRNra+u0saVLl6ZChQr8888/pBSGjloiS0HOzviWKsXIs2e5/Phx1gMHDIB+/dRamtWr/z1uZgbff6/KtwAOHNBpvFkqVkx1oatYUTUROHzYMHHklp2danjg7w8DB6Jt0gTtOwOhSV34fSOsWojpmiWwYwM0qYd28CC0Q4cUjk52QgghhHiuGUXikxVTU1MALC0tAXB2dqZYsWJERUXx+KkPxbdv3+b8+fPUq1cPExOjfkviGTQaDXOrViVBq2XYqVPZDYTQUGjYUDU0iIr691zx4irpADX7c+GCboPOioMDbNmi1s60bQtnzhgmjtyysYGwMLS1a8Ot6/DTIujcAayt/h1jbaWO/bQI9v6BdvQow8UrhBBCCJEDRp0lpDYsaNq0KQDm5uaMHDmS2NhYOnbsSEhICJ9//jmBgYG4u7szobB00hLZqmxjw6fly7P65k3WZbc3j6WlWotia6uaHdy58+85V1f18+FDNXuR1R5BulaunJpBSUwEPz+4ds0wceTW9etw/hwsmQMlbLMeZ1scZn+pyuJkLyAhhBBCGDGNVmucBfr79u2jZ8+e+Pj4sHjx4nTnNm3axOjRo3nw4AEApUqVYtiwYbzxxhtoNJocXT8mJgZfX19mzpyJo6NjQYcvRKFW5ptvcLp/F5NxI3M0PmXcF1y3KsHlgQN1HJkQQgghBNy4cYN3332XiIgIypYtm6PnmOk4pjy5fPkyw4cPx9HRkSlTpqQ7t2zZMqZNm8bo0aNp3bo1SUlJrF69mvHjx3P8+HE+++yzXL2Wl5dXjm+WLh04cIC6desaOgyjsu+ff2h48CCD3dwIrVIl+8Hz50P//qqVdUgI8NQ9XbpUlcMFBcHixapMzhA2b4b27aFpU9WYwcrq2c8xEO2unfBZztuCm7zWHpfgz3CdP1+HURVt8m+Absh9LXhyT3VD7qtuyH3VDWO4rzExMbl+jtGVut25c4e+ffvy8OFD5s2bl2425uzZs4SEhPDGG2/QuXNnSpUqRenSpRkwYAB+fn78+OOPXMxqA0xR6DQoUYIhbm58HRvL3nv3sh/crx8MHAiTJsGqVenPBQXBuHEqARo3TncBP0vbtirx2rZN7fXzdCtuY3P7Njg75Xy8k6N6jhBCCCGEkTKqxOfBgwcMGDCA2NhY5syZg6enZ7rze/bsITk5OUMHOIDatWuj1Wo5ceKEvsIVejChQgXcLC3pd/Ikic/qHDZzpmp13bs3/PVX+nNjxkCvXirx+U/ppF69+SZMm6Y60Q0ebLytoK2t4dGjnI9/+Eg9RwghhBDCSBlN4pOQkMDQoUM5duwY06dPp379+hnG3L9/H4B7mXz7n3pM2lkXLbZmZsyuUoWo+/eZ8qzF8xYWqtlBqVKq2cHTNBq1AN/XV80Obd2qq5Cf7f33YeRIFc/YsYaLIzs+DWHbrpyP37ZTbYJqrImcEEIIIZ57RpH4JCcn8+GHH7J7924mTJiAr69vpuNq1KgBwMqVK9O1s7579y5r167F1NSU2rVr6yVmoT/tS5fmdUdHxp8/z6knDS2y5OICa9ZAbKx6nJT07zkLCzXTUr06vPZa+hbY+hYSomamxo+H2bMNF0cWNEOGwMo1OdufR6uFb5ej+W2b2j9pyRLIbg8mIYQQQggDMIrEZ9asWWzZsoUqVapw6dIlQkND0/3a+uTb+UaNGtGkSROOHTtGu3bt+Pzzzxk7dizt2rXj2rVr9O7dGxcXFwO/G6ELX1WujJWJCQNOnuSZjQgbNIA5c9TvR49Of65kSdVYoFgx1eb68mXdBPwsGg3Mm6c2Nx0yJOO6JENr1AhcykBoDpoVhM4Hd3f49luVKPXqBR4eanPZ7NqRCyGEEELokVF0dbty5QoAJ0+e5OTJkxnOBwYG0qpVKzQaDXPmzGH+/Pls3LiRH374ARMTEypXrsx7773H66+/ru/QhZ64WloyuVIlBp48yZKrV+mVuk9PVvr0gQMHYMoU8PaG7t3/PVeuHGzcqLqrtWsHv/+uNj3VNzMzWLkS2rRRzQ7s7aFVK/3HkRmNBk1YGNpmTSEuHgb1BftS6cfcuQtzFsLuP9Hs+F3NtvXurcoIp02DTz5RyU/PnvDee1CtmgHeiBBCCCGEYhSJz6RJk5g0aVKOxlpYWDB48GAGDx6s46iEsenn6srya9cYfuYM/g4OOFlYPPtJTZtC377g6anKsFJ5e6tZlldfha5dYd06lYjom7X1/9m777Aqji6Aw7+999JBEAREFDuIYsFeMPYu9hZbTOxRE1uiSUw1MRqNvcZEo5+JiQ171Bg11liw996wIVjodb8/VlCkK93zPs99gN3Z3dllWe65M3MG1q+Ht96C9u21jG9Vq2Z9PZLi4ICy/wDqyJHQtCM08AL30lpr1blLsGMPtG2Lsv8A2Nlp2ygKNGmivc6cgenTYfFimD9fCzJHjIAGDbIvpbgQQggh3lg5oqubEGmhUxR+cnUlKCaGEZcvp22jlSuJsrVjR5vOjB76GXXrdqBkyTqULFmH+j8sZkL7dwj8aysMG5ZgYP6PPy7A2blqsq9hwz7PuBPLnx+2btWCh5Yt4dKljNv367K1Rfn1V5QrV6BBUwiJxf/aPajXGOXyZZQlS54HPS8rV06bX+nmTS2b3qFDWnIJT08ttXhkZNaeixBCCCHeaDmixUeItHK3sOBTFxe+vnGDXo6ONE/uTXccR0cOfzORXp9PA5+tFCtamIYNaxMdHcPRo6eZc+kaa0rWYOXCxRQvXhw+/jjB5mXLulKunGui3Vatmjil+mspVAi2bdPScTdtCvv2actyCjs7lA8+AOCWry8O6Zm0zMEBvvhCu7a//651g3vnHW2y2aFDYeDA5IMnIYQQQogMIoGPyHU+KVqUP/39GXzpEqdtbLDQ61MsryvrTtsKpXl/+zo8utWDHycDEBwcQr9+H7FnzyGGl67KujFjoGhRrevbM82b12PUqIGZej7xXF3hr7+0rmDNm2tjj2xssubYWcHUVBt79e678PffWgD02Wfw7bdaQoThw7VrIIQQQgiRCaSrm8h1THQ6fnJ15Xp4OF9dv55q+Zo1KzP3r+V4vN9fe7O9bBkAlpYWfP75cACOPA3nVo3aWkvE3nTMX5PRqlYFHx84f14bfxQWln11ySyKorVqbdkCp05B9+6waJGW/KBNG9i1S+YDEkIIIUSGk8BH5Ep1bWwY4OTE1Fu3OBoUlLaNpkyBevW0CUyPHgWgRAmX+NUPJkzSWnzatoWAgMyodto0bgz/+58WgL39dsK5iPIaDw/4+We4cQO+/BL++09r8apSRbsGMg5ICCGEEBlEAh+Ra00qUQIHY2P6X7hAdGwsqqryzz//MHToB3Tt2p2PPhrLO++8xw8/TObBgwdgZAQrV2pjTtq3B39/bt++G78/57Ju2hw/Oh0s+w2A06cv8N13M/n44++YNGkuu3cfzJqT69oVZs7Uss0NHJj3W0AcHeGrr7QAaOFCCA+H3r21+YC+/x4CA7O7hkIIIYTI5STwEbmWjZERM0uV4ui9e3T65htcXd0ZPHg4quqMu3tLGjceiLNzbfbuPUfp0m68/XZP9l+6pHUle/AAunRh6a/axKE1a1amYEF7KFkSNmyAYK0Vadu23cydu5TffvNh5sxFvP32ENq0eY979/wz/wSHDtXmwlm0SBsL8yYwM4N+/bRU2H/9BeXLa5PQFikCQ4bkrIx3QgghhMhVJLmByNXK3L+PVf9BPCxXk1GjFlKxohfKS3PEtGnTjyFDprB58xK6dOlO584d+XHBAnz7vc/SS8Ho9XrGjfvg+QY1a1JsYD++njWH+vVq4LziDx4/Debw4RN8//1sfH1P0rv3h2zevBRDZs/98803WpD2/fdaq8iHH2bu8XIKRdESPDRvro0Dmj5d6xI3bx54e8PIkdrcRzIfkBBCCCHSSFp8RK51/PhxGjZszKhBE5ny7SoqVaqbKOiJY21ty9tvj+CXX46yZ88R3t60lfeLViRaVfmsWS08PT0SlO/4/Rf0Gz+WUps3YPbF5zg5OdCmTRM2bVpCgQK2nDlzkfXr/878k1QUmDsXOnTQsp79/nvmHzOnKV8efvlFmw/o889h/36oX19LBPHbbzIOSAghhBBpIoGPyJX8/Pxo1cqbESPm0KxZzzRvZ21tyzffrOLAgQvcCY2gt40xA/83H44cSVx4+HCtu9nUqTB7NgC2tjZ06dIaIOvG++j12hv8+vW1rHNbtmTNcXMaR0dtItSbN+GnnyA0FHr2hBIlYNIkePQou2sohBBCiBxMAh+RK33//SQaNOhGw4ad0rVdVFQk06ePIyYGoqKCGbp8PhQsqCU7uH8/YWFF0bpYtWmjdTFbvx4AFxdnAB48eJgRp5I2pqawdi2UKwcdO8LBLAq6ciIzMy0z35kzWjIKd3dtMtTChWHYMLh8ObtrKIQQQogcSAIfkesEBwfz22/L6Nz5g9QLvyAmJoapUz/lzBlfKleuQ506b/HL2nVaQBEQAJ07Q1RUwo30eq17WeXKWmrpI0fiExuYm5tl0BmlkbW11tpTsCC0aqXN9fMm0+mgRQttMtQTJ7RMeD/9pE2C2q6dNgFsXs+GJ4QQQog0k8BH5Dq//fY7np71cHQskuZtVFVl3rxvOXRoFx4eVfnoox/o0GEI8+cvINrDQxtDsmcPjBiReGMLC9i4ERwcUFu35t9tuwCoWLFsBp1ROhQsCNu2gcGgTQJ6+3bW1yEnqlBBy35344aWCW/vXm3OpmrVtMD15YBWCCGEEG8cCXxErrNkyf9o3bp/urb59dep7Ny5ATe3CowdOxVjYxNKl66IvX1hdu7cqbXmjB4Nc+Zwe+oM/vxzA2Fh4c934OhIxNp1jI+15NjZy1hamNOtW5sMPrM0KllSS/X8+DE0ayZz3LyoYEEtE97Nm7BgAQQHQ48eULw4/PCDjAMSQggh3mCSzlrkOn5+fri4uKW5/KFDu9i4cTmgJTf4+ecf4tfFxlowc+YSNm3aR/euXal+/DiPx33ByPyl+eyzSVSsWJaCBe15/PgpZ89e5IGRDeZqDPNsVOzzWWb4uaWZp6c2uWnz5tC6NWzfDubm2VefnMbcHAYM0OYE2rJFS1AxZowWFL33njZmq2TJ7K6lEEIIIbKQBD4i1wkODsLc3Cpd5eMcOrQr0frAwCccPXqeWrWqUP2PPyhUtTr9I4M5UsKVa9ducvz4GVRVxcnJkd69GzDQyYpiHw7V3lQvXZp9c8k0aKB14+rcWXutXQtGRtlTl5xKp4OWLbXXiRMwbRrMn69l6WvXTuva6OUl8wHlcbHR0dw+eJBrO3Zw79gxgp8lMrEqVIiib71FxV69MLWxSbDNkQULOLpwYbL7LNWiBQ3Hj8/MagshhMhgEviIXMfS0orQ0CBsbR3SVL5hQ28aNvROct348b3o0qUx77zzTvwy23U+fFWrFoQWgP92gLFx4g2DHmtjSYoVg+x889Oxozap56BBWiC2eLH2Zl8kVrEi/PqrNhnsnDnadfPx0eYDGjkSOnWSwDGPunf8OFueTf6br3BhitSujRoTw4PTpzmxZAmXt2yh9fz5WBdJPG7QztUVO1fXRMsdK1TI9HoLIYTIWBL4iFyncOHCXL9+jsKFX7+r0s2bFyhcuE/ChRUqaAFE165al6h58xJv+OmncO0afPutNn7kvfdeuy6vbOBAePAAvvgCHBxg8uTsq0tu4OSk/d4+/VRrsZs+Hbp3h48/hg8+0FJlv/Tpv8jdFJ2Okk2bUrF3bwqUKRO/PDIkhL8/+gi/Q4fY9eWXtF20KNG2RevVo+rAgVlZXSGEEJlEPhoWuc677/Zm48bku6Ck1YULx3j06B7169dPvLJLF21MyPz58PPPidcrihYQNW2qBR5///3a9Xkt48bBkCEwZYr2EqkzN9days6e1bL2ubpqwU/hwlrAe/VqdtdQZBCnypVpNGFCgqAHwNjCgprDhwNw/+RJgu7cyYbaCSGEyCoS+Ihc5+233+bkyb3cvXvjtfazdu1cBg0aiF6vT7rAd99pWdOGDIEDBxKvNzKClSu1CTQ7doSTJ1+rPq9FUWDGDC1g++gjWLIk++qS2+h02rxI//wDx4497z5YqpT2/b59Mh9QHmbt4hL/fWhAQDbWRAghRGaTwEfkOhYWFvTs2YuVK2e88j4CAu6x5Z+VNO/ZI/lCcZOXFimivQFO6tPgfPlg82awstIG0Pv5vXKdXpter3XdatQI+vbVWjFE+lSqpAWN16/DJ5/Azp1a8oOaNeHPPyE6OrtrKFISEIA6YwZq546oZVxRizjj0akDaqcOqNOng79/ok2C7t6N/96yYMHEu7xwgYMzZ7L7u+84PHcutw8ezMwzEEIIkYkk8BG50iefjGHPntVs27Y83duGhYUw8qNWKF060+jWLZbcu4ea3Cf6trZatrSnT7XB7xERicsULgybNsGTJ1rLQVBQ4jJZxcREG7BfqZLW+rN/f/bVJTcrVEhr8bt1C+bO1eb/6dZNS4H944/a71rkHE+fog4ehFqiOOqGP1ELmRM7sAOx4/pj+OBt1MKWqJtWopYqidq/X4Lf39lVqwCtO5yFvX2iXd/YvZsTS5dy3seHY4sWsXnIENa99x4hSQRRQgghcjYJfESu5OTkxObNG5k9ewSbNv2a5u0eP37IiBFN8KpVmdMzZ1DR0pI+58/T4cwZHkRGJr2Rh4eWDezAARg2LOkylSrBqlVw+rQWcERFpfeUMo6VldYKVbiwNsfPmTPZV5fczsICBg+G8+dh/XooUUKb6LZwYRg+XEtwIbLXkSOoZd1Rr50ldtanqEO7ozaoAcULg2MBKF4YtX511CFvEzvrM9Q7l1HLusPBg9w7cYKzq1ah6PXU+OCDBLu1LlKEWqNG0WXVKt7bu5cemzfT6PvvsXJ25v7Jk2z58ENipQVQCCFyFQl8RK5Vvnx5du/exf/+9w2ffdaBw4f/Sbbl5tEjf/73v0m8+64nzZvXZ+HCBZQwN2dnpUpMKVmSzQEBlD98mHUPHyZ9sE6dtCxgCxfCggVJl2nWTBsbsmWLNi4oO8eFODjAtm1gaqrV6+bN7KtLXqDTgbe31vXt6FFo315LiV2qlHZv7N8v44Cyg68varOmxPZsiTqoC6Q2qXA+C9T+nYjt402Id2v+GT0aNSaGGsOG4eDhkaBo6ZYtKf/229gUK4bB1BQLBwdKNmlC+yVLMLO1JeDiRa5kd1ITIYQQ6SKBj8jVypQpw+nTJ+nUqSnz5g2nRw93Fi/+lg0bFrF16++sXj2X8eN78fbbroSEXGDDBh8mTpyA7tlcN3pFYVSRIvhWqUIhExPanT7Ne+fP8zSpT3K/+QZatNBaffbtS7pC/ftrY0MWLoSJEzPxzNOgWDEtCAsO1rLPJRfUifTx9NTGUl2/rmX+27ED6tSBWrVgxQoZB5RVgoJQ27Ultl8HqFkxXZtGVnBjS7kyhDx6RNk2bajQs2eatzW1scG1dWsA/GS8jxBC5CoS+Ihcz9LSksGDB3HmzEmWLFmIhcVjbt3aw/79y3j69BRNmlTl6tUr/PrrIqpWrZrkPjwsLTlYuTKfubiw5N49Khw+zK5HjxIWikt2UKyYluwguUQG334Lb7+ttRAtT/8YpAxVoQJs2AA3bmjJF4KDs7c+eYmzM0yYoI0DmjMHAgK0uZ9KloSpU2UcUCZTx3yMWrY41KqUru1iomPYvmIHAUFhFDfRU/tm+rNDWjk7AxAqHyYIIUSuIoGPyDMURaFu3bpMnTqFpUsXM2HCeBYsmMfw4R9ia2ub6vbGOh3flijBPk9PjHU6Gpw4wcjLlwmPiXleyMZGS3YQEgIdOkB4eOId6XTaBKh160KfPrB7d0ad4qupW1fLSObrqwVsyY1lEq/GwgLefx8uXIB167QJbUeN0rIBjhyptQyJjBUYCMuWob7dMl2bxcbGstPnX+7euEfhUoWp378dysqVSWZ7S0nos/IGM7N0bSeEECJ7SeAjxEtqWltzrGpVhhQqxLTbt6ni64vvi5naypbVujodOpT8WB4TEy1AKl4c2rXTBsdnpzZt4KeftHE/ffpAbGz21icv0um067xrFxw5on0/a5bWAtS5c9JzQYlXs3w5alUPsLFK8yaqqrJ3435uXLiJU9GCNOpUH52NFWr18qjLlqVrP7ee/S7ty5ZNd9WFEEJkHwl8hEiChV7PbFdXtlaowJPoaGoePcr469eJjgsY2reHzz+HRYu0hAZJsbXVsqsZDFo3swcPsu4EktK3L3z/vdb9buRIGYyfmapUgWXLtKxvH30E27dD7draOKCVK2Uc0GtS9+yGsiXStc3Bvw9z6eRlHArb06RrIwwGg7aiXEnYuydB2aC7d7mwYQPRL7XoxkRGcnDGDPzPnMHIwgK3Nm1e6zyEEEJkLUN2V0CInKyprS2nqlVj6KVLfHH9OhsDAljq7o6buTl89RUcOwYffgjly2tdyl5WooQ2kWj9+s+zgpmbZ/VpPDdmDNy/D9Ong6OjlohBZJ7ChbUkF+PGaROjTpumpTsvWlS7b/r21SbBFelz6iTqe95pLn7jwk3OHDoLgJmFGQe2/Pd8ZXAYXLqO8tVXlGnXjoKVKhHx9Cn/fv01+yZNwr5sWczt7Yl4+pSAixcJCwjAYGZGowkTMLezy+gzE0IIkYmkxUeIVOQ3MuK3smX5s2xZLoeF4XnkCLNu3yZWUbRP9UuW1FIa37qV9A6qV9eSIhw+DD16wItjhrKaomgTcPbooSVf+Pnn7KvLm8TSUusWeeGC1gWyaFGt1a1wYW080I30D7B/o4WEgplpmotHhD+fePjGhZtcOnnl+evqHS4ZG3Nx40aePPsbtnR0pHz37uQvWZInN29yfdcu7vr6YmRuTtlOnei0fDkudepk+GkJIYTIXNLiI0QadXFwoK61Nf0uXOCDy5dZHxDAIjc3iqxdqwU3HTrAnj3a3Dkva9dO+7R/+HDtje706Vlb+RfpdFoXvYcPYeBAKFBAq5/IfHo9tG2rvY4c0e6JGTO0++HQITh4EGrUyO5a5nwW5hCWRGKRZLhWLI1rxdJJr7zuh27uSpSLl+MXmdrYUGvkyNetpRBCiBxGWnyESAcnExM2li/PT66uHHjyhPKHD7PMxkYbHH3kCAwalPzYmQ8/1F4zZmiv7GRsDKtWQdWq0K1b9meeexNVrQq//aaNAxo9WltWs6Y2J9Dq1dnbMpjTlfNAuZZMOvl0Uq7d1tK+CyGEyPMk8BEinRRFoX+hQpyoVg0PCwt6nT9P5xIlePjtt9o4jtmzk9/4xx+1xAgjRmhdnrKTpSVs2qRlnmvTBk6ezN76vKmKFIFJk7TvZ86Ee/e0rpOlS2stQU+fZmv1coyQEC0xRNeuKOvWw6EMul/PXAWvtzJmX0IIIXI0CXyEeEUlzcz419OTSSVKsCEgAI/69dk4fLgW1OzalfRGer02LqhaNejeXevelJ0KFICtW8HKCpo101ofRPYZNgwuXoQ1a7QJUkeM0AKj0aPh5s3srl3WCw7W5qDq3BkcHLTEEDt3QvfuKGevwuPXDAqfhqAcOonSs2fG1FcIIUSOJoGPEK9Bryh87OLC4SpVcDQ2xrttW/p/9RVBvXol/0bV3Bw2bICCBaF1a7h6NWsr/TIXFy34iYiApk2zP+32m06v11oF9+zRAuNWrbSWnxIltG6J2R0sZ7agIC3leseOYG+vnfOePdr8Uzt2wN272gTBffqg/Lb5tQ6l/L4Z3n5b+wBACCFEnieBjxAZoIKlJYeqVOETFxcWeXlRYcoUdo8aBWFhSW/g4AB//aXN59KypTYTfXYqW1br9ubnBy1aSPeqnKJaNS0j4NWrWha4LVu05AdeXlqrUF4ZB/T0qTbeqV07Ldjp3l2b8LVfP6311M8P5syBBg20wBBQJk5CuXgT9h17tWMePIFy+jLK5CkZdhpCCCFyNgl8hMggJjodE0qUYLenJ3p7e+oPHsxHCxcSntybUzc3bZzPtWvaJ/wREUmXyypxk2ueOJEz6iOec3GBH37QUqbPmAF37mgtIqVLa+OCgoKyu4bp9+QJ/O9/2vgye3vo2VNL+T5woNbCc/s2zJoF9erFBzsJWFqirF2HbvFa2J/O4OfgCXQ/rUbxWSvzKAkhxBtEAh8hMlgda2uOv/UWA+/fZ0qFClTdto1jyb0xfest+PVXLavau+9CbGyW1jWRVq20VNc7dkCvXnmnRSGvsLKCDz6AS5e0zG+FCmmZAosUgY8+yvnjgB490hKAtG6tBTu9e2uTAL//Puzb9zyw8/LS0q6nxtMTZdvf6P7YhjL3D3icSgD4NBhl/gp0/9uMsmWr1qImhBDijSGBjxCZwNJgYF7Xrmxet47AkBBqHDnChBs3iE4qsHn7bZgwQRvX8PnnWV/Zl/XuDVOmaK0/H3yQfHpukX30em3eqL174b//oHlzbU6gEiW0++nw4eyu4XOBgVow3bIlODpqY3VOndISORw4oE3eOm0a1K6dtmDnZZUro5w5i+JaEd2H36PMWIay/QBcuQl3HsCVWyj//Icy8zd0wyagFC+LcvacBD1CCPEGkglMhcgsOh0tvvmG0w0b8n67dnymKGwICGBpmTKUNjdPWHbsWK3L24QJUKwY9O+fLVWON2oU3L8Pkydr45HefRd1/nzYv48yISGojZugDBoERYtmbz2FNubnjz+01p5Zs+Cnn7Sfvby0cUFt2iTdVSwzPXyodeNctQr++Ucby1asmNY61bmzFnQoSsYdz8oKZfYcGP8tyvLlqHt2o+zcACGhROr1GFetitKhB6x8G+zsMu64QgghchVp8REiM1lZYfv77/wxeTLLly7lQkgIlY4cYa6fH+qLLSmKAnPnap/cDx6sDWLPbpMmwTvvoH7zNaqHB9y5Dn26YD70Pbh/C9WzEuqsWdldSxHHxUULVG/f1rLA3b6ttQq5umoBUXBw5h7f318Lupo21TIW9u+vdckbNUprgbp6Vatf9eoZG/S8KH9+eP99lOV/oJw5h3L9BqdXrET5cwUMHSpBjxBCvOFyRIvPvXv38PHxYceOHdy6dYuQkBCKFCmCt7c3ffv2xdjYGIBZs2YxO6XJIYFdu3bh5OSUFdUWIm1Kl4bly+nWqhV1dTr6DhvGkEuXWPfwIYvKlMHZxEQrZzDAihVQt672qfiePVCpUvbVW1HA2xs2bYQ/fwGXws/X1akBvbtC7/e1+WY6dMi+eoqErKy0lpUhQ2DdOpg6Veuy+PnnWuKAYcOgcOHU95MWDx5o2eVWrtSyr8XGQqlS8PHH2iSsnp6ZF+QIIYQQ6ZQjAp/ly5czf/583N3dadWqFUZGRuzbt4/p06dz4MABFi9ejF6vp3r16gwdOjTR9tHR0SxYsICiRYtK0CNyphYt4LvvcP70U/5yd2dBt26MunIFj8OHmVu6NN0cHFAURXvTumkT1KypJRo4eDDj3qS+AvX7CfDduIRBT5zCheCL0ajjv0Fp317e4OY0BoOW+a1jR20c0LRp2titqVO1iUBHjICqVdO/33v3ngc7u3drwY6rK3zyiRawV6gg94IQQogcKUcEPhUqVGDlypVUqFAhfllMTAwDBgxg7969bN68GW9vb2rUqEGNGjUSbb9t2zZUVaV9+/ZZWW0h0mfsWDh6FOXjjxlUoQKN69Sh9/nzdD93jrUPHzLX1RU7IyOtBWXTJm2MRqtWWstPdqTcvXRJmz+lXu3ky7xVG76aBBcuQJkyWVc3kT41a8Kff8L161q3t4ULtfmB3npLC4C8vVMeB3TnzvNgZ88eLeFFmTLw2WdasOPhIcGOEEKIHC9HBD6NGjVKtEyv19O5c2f27t3L0aNH8fb2Tnb7NWvWoCgKbdq0ycxqCvF6FEWbcf78eejWjVJHjrC7UiUm37rFl9evs/vJE35xc6OlnZ32qfmqVVomrE6dtEDIyChr6/vwITg5pvyGWKcDczOte56TkzaGwtb2+dcXv395WVwXP5F1ihWDH3+EL7+EX37RUke3bw8lS8Lw4VrGNUtLrezt28+DnX37tGCnXDn44gst2ClXLhtPRAghhEi/HBH4JEf/7A2XSQpvkPz9/dmzZw81atSgUKFCWVU1IV6NpaWW7apaNWjXDsP+/XxStCgtbG3pdf48rU6dYoCTEz+WLIll06baYPG+fbWEBwsXZu2n6o6OcPuOlpHLkMyjIjoaAh5B/QbanD8BAVpgFxiofR8Vlfz+zc1TDpCSWmdrC8/G/InXkC+f1tIzbBj4+Gjd34YN01pwqlaFp0/hyBGtbPny8NVXWrDj7p6t1RZCCCFeR44OfLZt2wZA3bp1ky3j4+NDdHS0dHMTuUfJktqcPS1bwnvvwR9/UMnKiiNVqvDFtWtMvnWL7Y8esdTdnTrvvaeluf72WyheXHtjmlVKlNAGqm//F5onbpUFYMceLXnD6tWJ16kqhIRoAVBg4PNgKKmvgYFw+vTz76Ojk6+XpWXqAdLLy/Lnz/oWs9zAYNCyrHXqBEFBcOaMNnktQMWKWkKEjh2zt45CCCFEBlFUNWfOTnjw4EHeeecdatasya+//ppsuRYtWnDv3j327duH+ctzo6Tg9u3bNGrUiBkzZmBvb58BNRYi77H67z9Kfv0VuiVzoXSJhCsvXyP2nfe5+tk4ntapkz0VFEIIIcQbyd/fnw8//JB//vmHwmlMBJUjW3zu3LnDqFGjsLe3Z/LkycmWO3r0KFevXqV9+/bpCnpe5OHhkeaLlZl8fX2pUqVKdlcjT8nx11RV4e23tRTWf/0FzZrFrwqKjmbUlSssvHuX8hYW/K9kSSp27KiNtdi2DerXz5o6VqmCam0Nb/eHRm9B/WcBzr/7Yfu/6GbMoPQ772RNXVITG6t10UqudSm5FqdHj7TfRXKsrdPXumRrCzY26Z40NNPv1ytXtHFjK1eCr6+2rEoVrQtbp05aS+SLnjx5Pg7o5k2t9W/ECHjnHbCwyLx6ZrAc/xzIheSaZg65rplDrmvmyAnX9fbt2+neJscFPo8ePaJv376EhYWxbNmyFFtj1qxZA0C7du2yqHZCZCBF0d5YnjsH3bppYyqevfm0Mhj4yc2NtgUK0Pf8eaqdOsU38+bxUceO6Nu3h/37s2y8hdKzJzRvjrpoEfyzj6CnT7Fq1hxl/i9QoECW1CFNdDot4LCx0brppVVsrPYmPy2BUmAgXL6sfX38OPmASVG0eqSnS15cXXQZOK/0pUvPg51jx7Rl1arBDz9owU7x4slva20NI0dqcwCtWaONAxoyBMaN0+YDGjpUy0AohBBC5BI5KvAJDQ1l4MCB+Pn58fPPP+Oewhu7sLAwNm/ejLOzc5IproXIFSwstGQHVatCu3Zw4MDzrFpAKzs7TlerxuBLl/jk3j02/PwzSwcNomTLltrcLI6OWVPPAgVQPv4YgEs54FOeDKXTaWOA8udP33YxMVrwk5bWpYcP4eJF7fsnT5Le35Ej2jik/PnT17pkZ6clK4hLfHHhghborFoFJ05oy2rW1Obw6dQJihZN33kaDNq8P126aPfn1Kla4DRlihawjxgBlSunb59CCCHyhA0DBnD36NFk1781bhxlclADRY4JfCIjIxk2bBhnzpxh5syZVK9ePcXyW7ZsISQkhN69e2sTPwqRWxUvrs2x0qwZvPuu1vXthXu6gLExK8qWZfmDBwy5dImKM2bw46xZDGjdGmXXrlzV7ShP0eu1oMPOTkvwkFbR0Vr3upcDJYBPP0247N49OHtWWxYUlPw+dTowNdX2HRmpLbO31+bpqVZNawGzs9OCr4cPnwdNVlbpyxRYq5YWVF27BjNnws8/w7JlWtfLkSO1eacyssXqVYWEwMaNcP8++YODwc0twQcKQgghMlbhWrUwt7NLtNzaxSUbapO8HBH4xMTEMHr0aPbt28fEiROTnNfnZdLNTeQpjRtrn6KPHg0TJ8InnyRYrSgK3R0decvamncvXGDQsGGsPXSIX/r1o9CyZekeTyKykcGgBSUvd+P19YXx45PfLipKC5jiAqNjx2D7dq3l7/59CA3Vuh7a2motR0FBcPQo7N6dcl3S27pka6vNBzRtmpbm+ueftXFAbdpoAeCIEdC7d/YE5KqK+u14rVXKtRiqgy0u9wNQf5gEH36I8uVXOSMwE0KIPKbSO+9QqGrV7K5GqnJE4DN79my2bt2Kq6srt27dYtasWQnWu7u707hx4/ifb968yeHDh/H09KRYsWJZXFshMsnIkdob1c8+01IJt2yZqEhhU1O2VqjAvDt3+Cg2Fo8yZZg3ZQpdP/44a+f4EVnPYNACnLhubOfOab/zunW1cTcdOkBSc5lFRCRuYUquS97Nm1pAFRioBVLJMTZOGBRVqqS1Kl24AO+/Dx99BE2bal3h3NyelzMzy9T7VB05ArZsJHbSCHDQPnlUgFj/QHQzfkP190eZOy/Tji+EECJnyxGBz927dwG4ePEiFy9eTLS+ffv2CQKfNWvWoKqqtPaIvEVRtElKz56F7t3h8OEku1DpFIUhzs40yZ+f3lu30q1GDdb5+DDb2xtbmasmb1FVbZxOXIKCixe1Fou33tKSC3ToAAULprwPExOtTGrlXhYenjg4Si54un5d+/rokbZtSIg2MaqPT+K6pHWy2heXmZmlXt8LF2DpUmJnjAXLl7J82tsS+0k/dMMnwZChUK5c+q6FEEKIPCFHBD4TJ05k4sSJaS4/fPhwhg8fnnkVEiK7mJtrbxbjkh389582DiMJrubm7G3Thkk//MBX1arx7549LKpUiWZxGcJE7qSqWqtLXLBz+bIW7DRooHUja98+a5JamJpqLUhJtSKlJCxMC4KOH4dFi2DzZi2IKlFCaxmysXkeMF26pAVQAQHPxyYlxcws1QBJXbcOtUG1xEFPHAsz1MY1YO4clDlz03dOQgghUnT933+5tnMnsdHRWDk54eLlhW2pUtldrURyROAjhHhBsWJagoOmTbU5U1atSnZcgkGv57Phw2nRsye92rShuU7H4EKFmFyyJBYy7if3iEuLPWaM9vu+elUbt9WwodZtrH37xGOCciozMy3NtbOzluzg8WOtJXPmTC0ttqvr83FAcfOvqarWtS4trUsBAXD+/PNlUVHaPsxNUUekPKeU6lYMZc4fcMRXa3168WVqmnhZRi6XrqgiKaGh8McfqLt2UjwwELVNW5QePSRpjch1Ti9fnuDnQ7Nn49a2LV5jx6LPQb1RJPARIidq2FBLFzxiBEyYoI3hSI6ZGZXnz8e3bl3GtWzJ1DZt+PvRI5aWKUMta+usq7NIH1XVujPGjdlZtUoblN+okZbcol27nDVP0quysdGCt+HDn5/j4MHaWLbBg7W5gZyctDd6FhZQpEja962qWre6gAB4pxdKeAQpTEULYRFaYJI/vzb2KW7biIjEr/DwlFuh0svYOHMDq/QsNzKSQCwn2LQJtWcPKGyPWsweG50Cc6agfvwRyq9LtGeAEDmcU5UqlO3cGYdy5TCzsyPk/n2u//svRxcu5MK6dRhMTKjzbDqMnEACHyFyqg8/1JIdfPGF1kWodevky9rbY7p+PVNq1cL74kXe+eQTvI4dY6yLC18WK4ZxJmWy6tRpAAcOJJ+/f/LkcXTv3i7BMlVVWbp0Nb/9toYrV25gZmZKtWoVGTGiPxUqZM2krNkmNhYOHXoe7Ny8qSUtaNJEW3///vPJTPMaIyN4+20t4cG+fVoANGGCls2we3ctyK9YMX37VBQtTbWlJbzdA+V/C1G9kp9jSjlwEsZ+qgVbaaGqWvDzckCUXKD0usufPEm5fHR0+q5PStctqSAprQFUnz5a4JpRgZjhDXwrsn8/as8exHbygiIO8YvVqm7g9xDde31QrH20Lq5C5GBVBw5M8LO1iwsVe/XCoVw5NgwYwNnVq6nYuzeW6R1nmknewKeNELmEosCCBVqygx49tDfMbm7Jl3d1hXXrqNe4MSfDwhg5cyYTbt5kU0AA/3N3p/wrzGMSERHBkSNH8PX15dixEzx69JgnT55QtKgLnp4VefLkKQD169fC3j5x/v4SJRLn7x89ejx//LEeKysLGjasQ2DgY7Zt283Onfv53/9mUrduynN45TqxsdpYrbhg5/ZtLQho2hS++UZLA50/v5bOOq8GPS9SFPDy0l5XrmipsBctgiVLtNaukSOhefN0p51WevRA/XwcHD8HlZIIoE9eQDl7BaVXr/TVNe7NeU4QG5s5AVdyy4ODk17ep4+Wdj82NmPOK24eqpzSIpYFKc/VT8aiNiifIOiJ51wAtXEl+GQsyn8HM70uQmQGp8qVsS9XDv8zZ/A7fBg3b+/srhIggY8QOZuZmTYuIi7ZwcGDkC9f8uW9vGDJEvJ168bP48fTZtYs+l+8SFVfX74tXpyRRYqgT0MXl2vXrjF37nwWL16Mo2MRypSpRqlS1XF11bpePXkSwJ49x7h48TIAOl04H3zQmxIlSqS4323bdvPHH+txcnJkw4bFODlp//T/+GMdo0aNZ/jwr9i3zwdT0xzyRvNVxcZqrRqrVsHq1eDnp3V1at5ca+Xw9ta6gL3pSpbUxv58/fXzcUCtWkGZMloLUK9eacvoBmBpibLGB13bNqiNa6I2qQUF8kPgE5S/96Ns3Y+yxiflv5+cTqfTrkdar0lm8fWFmBitBSqzgq6Xl4eFaePFUiqvptjRMe0MhswNrIKCwNcXdWSnZKuguhdD+dtHy+To6pox5yVERjh/Hu7dw/TBA6hcOcVus/mcnfE/c4bQhw+zsIIpk8BHiJzOxUVrLWjUSHsj6OOT8ieSXbvCjRswZgxtihWj1jffMPDiRT6+epX1AQEsKVOGEsm8cYqMjGT8+O+YM2cOLVq8w7x5+yhSJHFK7ThffDGAM2eOEhgYS9Wq1Xn//ff54otxGBsbJ1n+l1/+AGDEiH7xQQ9At25tWbZsDceOnWHTpn/o2DHxHEY5XkwM7N37PNi5e1d7k9OiBUyapAU7uflNd2bKnx8+/lgLdlatgh9/hIED4dNPn48DSks3CS8vlIOH4McpKCN+gPBwVGMjlJ49tU/O5Q1kxjIYtFdOGIivqlqii6wKxIKC4OHD5MunNj7MNh8YUkhAo9eBsU5r5dfpngdNcWPF0vo1s7fR62W82JtiwwbUT8aCnx+x+SxwexKE+sXn8O13KJ2SDuJD/P0BMMruD2teIIGPELlBvXowbRp88AGMHw9ffply+Y8+gmvXYNIk7IsXZ/WAASy7f5+hly5R8cgRppUsSV8nJ5QX/mFduXKF9u07Ym1dmF9/PYGDg3Oaq9e+/WAGDRrP5MkDqVKlGj4+qyn1UhrL0NAwDh7UxgM1a1Yv0T6aN2/AsWNn2Llzf+4JfGJiYPduLTBds0Ybo2Nqqk0+26mTNi4rmXTkIgkvjgPau1cbB/TddwnHAVWokPI+wsK0Frf8NhAURIyZGYbYWO3Nqci7FEV7M25snDP+5mJjE48Pi3tduAD93oNYFXTJBA2qCtGqFvjb2j4Ppl78+vKykBBtLq2kysZ9jcuCmFHiuoNmVaCVnm0MBgnKMoi6cCF8NJqIMoWIectdu66qit7/CcYD+oGfH8qHHybYJjQggIALFwCwL1s2O6qdJAl8hMgthg7Vkh189ZWW7KBt2+TLKgrMmqUNnn//fZQiRejVsiX1bGx49/x5+l+8yNqHD/nZzY2CJiZcuHCBBg0a0b37WDp2HJIgIEqLw4f/JTY2lpIla3P/fiHq1m3Ejh1bcHd/PtbiypUbREVF4+BgR4ECiceylC2rtSydP38lXcfOctHR8O+/WrDj4wMPHmhdj1q1gs6dtaDnFcZTiRcoCtStq70uX34+DujXX6FxY20cULNmCVs+w8JQe/eEXbu0rm4fvwNWFuiCQ1H3HYcmjaB2bZRlv+eMFgqRt8WNWzI1TbyubFkY9xlcvQOlkvmA6cZ9yG8Lc+Zk7Jv3FxN2pPfrq2wT9zUsTEvekVrZjBQXDO/bp00HkNXBWUrb5qbMivfvw4jhhNV0RbV8oeVGUfDLlw8qmlL8s09R2rfXeqgAoQ8fsvOLL4gKDcW+XDkcU/vAKgtJ4CNEbqEoMG8enDmjdXk7eBBeCCwSMRjgzz/hrbegSxfYswcXT0/+rliR2X5+jLl6FY/Dh5lka8tXzVrw3nvjad363Veq2saNyxP8rNPZ07hxJw4e3ErhwoUBuHv3PgCOjtp8NBcvXmXMmAm4uZVkwoQx8cvjyuUoUVGwa9fzYOfhQ20OmtattWCnRQt5M51ZSpXSgvgXxwG1bKnd+yNGQM+eYDCgerdCjQ5BnTtOe1MRx9oKtUsz1PaNUOavgJbNUf7+R3sDIkR2UBT44kt0I4YR65gfrF6adDc4DN1WX/huYsa/Oc5pCTteFNddMSMCrRe/B+05ndI2QUGp7y+jxbVQZkcXxZS2NTJK8KGS+tNPRDvZJQx6nnkcpeIbpMPU1Y0C/ftjWq0aIQ8e8PD8eaJCQ7Fydqbx999n/LV7DRL4CJGbmJpqXaqqVNGSHRw6BCnN1WNpCRs3Qs2aWovEf/+hc3Hhg8KFaZo/P73On2fI+0Np/1anVwp6ypWrQrNmnSlduhw2NnY8fHifw4f/ZcWKhYSHg7d3L44e3YGiKISEhAFgZqZ9Arp06SoOHTrOoUPH6dGjPZaWWuAQEhKa7npkiqgo2LFDC3bWrtXme7Gw0MbqdO6sJSowN091NyKD2NpqE7yOGKH9TqZOhQED4NNPUT09IfAB6mf9tTEHSTEyoL7fDeWHRahTf0QZ+0nW1l+IFyjduqFeuYJuymTUyiVRS2stP8rlOyhHL8PQYSh9Xu2DqFzrxe6KGdlq7usLc+e+3j5UVWvtz8hWsLSWDQlJeZuMTOwRx8joeSAUHkZMuaTnV3MwUShhriMwLJaHAQFEbt+OzsgIm6JFKVa/Ph7dumGcw3pASOAjRG5TuLA2ALxhQ+3T7nXrUk52UKgQbN4Mdepowc/evWBtTRkLC0ZducJHN+4w6OvNr1SVrl0HvnQoF9q27UWpUuX44osBPHjwlPnzf2bw4P6Jtm3evAE+PltxdS1OqVLFuHfP/5XqkKEiI2H7du36rl2r9Ze3snoe7DRrlv0Ztd50xsZaevfu3bXxVT/+CNu2Evv10OSDnjh6HbFdmqKbPgc++jj18kJkIuWzz7QuyzNnoPy7m8jwCIwbNED58Zf0z2klMpeiaMGAkVHObN1PKijLiCAtIgLWr0v2sLbGOmrZ6tDfD8IEa5QD/2XhSb8aCXyEyI3q1tXGPQwZoo35+eablMt7eGgtRc2bQ8eOsHkzqpER33w1ntHDZ2JikkQ/9NdQrlxlSpcux6VLZ5gyZRaDBvXDwkILGMLCtEHmXl7VOHPmn/htQkO1FiELiyxuRYmIgL//1oKddeu0lLn58mlvSDp10ubbSaqfvsheiqIl/VBVOHMSXIulbbuSLmBpBv/8o/1uhchOHh4oPy0E4LSvL1WqJD8BrxDJisuwmBm9EAoXxvDLXGIKJV9EHxgKnTtk/LEzQebP0iWEyByDB0PfvlqWtzVrUi/fqBH8/LP2hm/gQPbu2UN4eBTVqzfJlOrFZYWLjlbYvXs3Tk6OANy/n3TLTtzyuHKZKjwc1q/Xxko5OGgtOmvXasHOhg1awoKlS7XJRSXoydmuXkUtUThdYyHUIo5aa5GfX8YPqBZCiDxE6dcP/d0AlKdJd0NXgsMw+D1EGfx+Ftfs1UiLjxC5laJoGX9On4Z33tHmeyhXLuVt3nlHS3P99dcsOn0Wb+8B6c7gllaBgVog4+FRi0WLfmXevLkYGRl48CCAhw8DE2V2O3v2EgBlypTMlPoQFgZbt2rjQzZs0Aaz5s+vtYB17qwFhjLg/c0QHq6lyf7uO+3nfPm0rE8vvxwckl4u3R2FEG+KAgVg3nzMhg4hwrUgMU62Wvf6WBX9vUBMLt7Txlw6p30KjOwkgY8QuZmJiTZZZtWqz5Md5M+f8jZffgnXrvHfKh/GDq2fKdV6/DiAa9e0/P01azZh2bLPMTc3o3p1T/btO8y2bbvp3r1dgm22bNkFQIMGtTOuIqGhsGWLFuxs3AjBwdog+S5dtGCnYcOEGcBE7lOyJMq126iqmuZWH+VuAHzxhTb+zd8/4evGDThyRPs+OjrpHVhYpB4cvfiysMg9qWuFEOIlSq9e4OSEyaefwM7TqPksUZ8EoXN1Rfl9uZZpM5eQwEeI3M7ZWRuf0qCBNuh7w4aUB20rCiHTp3N9+R+UKOHxyoc9deowsbGxlC9fDd0LyRUePXrIzJlfEB4eSunS5WjQoA3ff9+b4OBg+vXrxr59h5k6dSENGtTGyckBgD/+WMexY6dxdCxAq1aNXrlOgJYBZ/Nm7Zps2qT9XKCANjFm585Qv74EO3lJ3boQq8CFa1CmROrlL92AyGgt8Enp70RVtXlHXg6M4l4PHmhf79yBEye075NLeWtmlnpw9GIQZWUlgZIQImdp3BilcWO4cQPl/n1O3btH+TZtsrtW6SaBjxB5QZ062lwngwZpb+jiuvAk49b9+xQs5IKR0at37bpx4xKLF08lX778lCzpjqVlPgICHnD16nnCw0NxdHRm5MjvMRiMcHJy4ebNmzRtWo/OnVuzcuVGGjbsgpdXdR49esyBA0cxMjIwffpXmJq+wvwSwcFakLNqlRb0hIZqbyB79tSCnXr1tIGfIu/R6eCDD9EtWUjsZwPAkEIwExODbsVWGDIs9YxuigI2NtqrdOnU66Gq2n2YVHD08uvcOe1raDKp242NUw+OXnzZ2EigJITIGkWLQtGiRPr6ZndNXom8ExAirxg4EI4ehQkTwNNTy0iWjMjISIxNXm+cQtmylWnY0JtLl85w5co5QkODMBiMKFSoKNWr16dVq26Ym2v5+42NTYh49mn4tGlfUqlSWZYt82HHjn2YmprQuHFdRo7sT8WKZdNegaAgrftaXLATHg6OjtCnj3bub70l6YrfEMrQoahb/kI3YxmxQ98GkyQC+sgolLl/gHUBlBEjMqESitZSY2UFJdLQ8gRaa2RyLUovBk+XL2vfBwcnvR+DQWvVTGv3O1vblFPgCyFEHiWBjxB5ycyZcOqU9ubfzQ3Kl0+ymLGxMZGR4a91qBIlyjBkyJdpKhsZGYHJs5nCFUWhT58u9OnTJf0HffpU68q3cqU2diciApycoF8/Ldjx8pJg501kMKCsXYfa9z10749HbVgDtY4nWJpDSBjK/mMo/xyERo1Rfl2Sc7o6Wlhor2LF0lY+PDzlbndxr7gxSk+eJL0fnQ7s7NI2PsnBQSsrf1dCiCSEBgRwY/duHpw6xYPTp3l07RqoKvW+/BI3b+8kt1FVlXOrV3NuzRoe37iBwdSUghUrUrl/f+zd3TO1vhL4CJGXxCU7qFJFS3Zw+LD26e5LXFxcuHfvNlFRkWnu7qZ/EoiJ/21QVSIdChNtbZem7aKjo7h79yYuLi7pOZPnnjzRUk+vXKllZYuM1AalDxyoBTt16sin1wJMTVF++x0uXIC5c1Bmr4CgIKJMjDHyboOyZypk8j/UTGdqCkWKaK+0iIyEhw9T73p38qT2NTAw6f0oivYciQuGpk3TutUm18JUoEDOCS6FEJnq1v797Hmxe30aut3uHj+eC+vXY2RhgUudOoQ/fsyN3bu5tX8/LWbOxLl69UyrrwQ+QuQ1Tk7avD716mkD+jdvTvRprbm5OcWKleDq1dO4uVVOdlem18/j5DMH273r0T8JJLaQNoOZ7u5dYvLlJ7CON3c7DCG8WPJvKK9ePYO9cxGM0jOx2qNHz4OdbdsgKgoKF4b339fG7NSsKcGOSJqbG8qMmTBjJgCn3uRJIY2NtQ8JCqUw8+CLoqIgICD1rnegfcASEKCNbUqKjU3aUoPHvUxeYWxfbqeqsG8f6vy5cPEi7qGhqOXLowx6X+uqK+O2RC5gYW9Pua5dcSxfHscKFdjz/ffcPnAg2fI3du/mwvr1WDg60m7xYiwctCRH59etY/f48ez66iu6+vhgyKRnggQ+QuRFNWtqc/z07w+ffQYTJyZRpAZHj/6bZOCjCw2m2NyPsNu5CqVLG5Sfp0DJYujjgo3YWAxXb2C/YSsFhr5FwFsduD5kCrEWVon2dfTYv9wvVRK7vXtpamtLazs7WtraUvDlh1pgoDaJ6KpVsH279ibMxQWGDdOCnerVJdgRIjMZGUHBgtorJb6+WhAUE6P93abW9e7KFfjvP631KSYm6X1aWaU9Pbi9febMUJ+VzpxB7dIZHgWgViiG6uGACaDeuwHdu4ClNcqKlVCxYnbXVIgUFa5Zk8I1a6a5/Ok//gCgcr9+8UEPQJm2bTm3Zg3+Z85w7Z9/KJ1JKbIl8BEir+rXT0t2MGmSluyga9cEq9999x3efXcg3boNTzCJqfG9m5Qb3hhD5TLotq0A63yJ963TQaniKCMGofTtgd1307F+z5Mz0/8h0qlofDFVVdm44Se+/HECNwsWZGNAAD4PHwJQzcqK1mZmtPb1xfO331D++UebN6VYMfjwQy3YqVZNPvUUIqfS658HImkRGwuPH6fc7c7fH27efB5cRUUlva8X51JKS/a7nDSX0qlTqPXrob5VDrVSjQT1UosVRK3hjnLqGjSoh7J9B1ROvlVeiNwkKiyMu0ePAlCsXr1E64s3aID/mTPc2r9fAh8hxCuYPl1LdvDee1CmTIJPD+vWrYuxsZ7Dh7dTvXoTAAxPAvD4oAGG7m1Q+vVM2zHyWaGb9DlGi5fjMaw+J38+TLRNAQB8fXei16uMbdMGRVGYq6qcvH2bjQcPsvH2bb4qVIgvixSh0MCBtOrRg9alS9OoalUsJPW0EHmPTqeNFbK11ZKvpCa1uZTiAqi7d5+PU0puLiVT07SnB7e3h3z5MidQiolB9W6N2qACaoVksv8pCmqFEqgGPTrvVijXb8qYKZEnPLlxg9joaMzs7DBLYvyx7bOpAwKvXMm0Osi7CyHyMmNjbZxM1apasoMjR7QMTWjZ1b755kvGjv2ARYuOYWJiSvFpQ9HXr572oOcFyrtvo/e7R4mpQ7j4zZ9ERIQzffowxo//AsXfH9asQVm5koq7dlExNpbPSpXiQY8e/NW8ORtLl+aPR49YGB6Oyb59NMyfn9Z2drSys6OoqWkGXxQhRK6QEXMpJde6dP586nMpxaUIT0v3OxubtHXF3bwZ9GryQc+LyhaFY1dg3boUpycQIrcIvn8f0MYFATy6epU9EyaQv2RJvMaMiV8e8qxcZpDAR4i8rmBBLdlB3brQrRv89Vf8ZJ6dOnVi+fI/+eWXLxlTqxU2Z/ahm7z8lQ+lGzUY69Y9yOe7k0mHtlIunxndFsyHnj20bi6urvDJJ1o3tgoVcFAU3gHeASJjY9nz5AkbAwLY8PAhQwIDGXLpEuUtLGhtZ0drOztq5MuHPqd0VxFC5CyvMpdSaGjqXe/ixik9eJD2uZSSeakTv0etWDTpfSRBrVgMZkxHkcBH5AHRYWEAGJ59oHl21SruHT/OvePHcW/fHiMLCwCikvtAIgNI4CPEm6B6dZg/X+vy9sknMHkyoLX6zJ8/lypVqjHu+C6Uvt3B7DVaWMxMUfq+jdH8Mfxz6TS+EWEoZcpoCRY6dwYPj2S7jxjrdDTKn59G+fMztWRJLoaFsTEggI0BAfxw8ybf37xJASMjWj5LkNDU1hZr6RInhHgd5ubxM9GnSXJzKb3cuhQ3RunluZSMDaiD26a5emoRR5RtW7QPr8zNtbFK5ubPX3E/m5pK8heR6xRr0IDLW7eSv3hxbIoVI8TfP9OPKe8ahHhTvPuuluxgyhQt2UH37gA4ODiwfeN6ilWritL2h9c+jNKmBUXHT2H7e+/h+MEHUK5c+vehKLiZm+Nmbs6oIkV4HBXF1keP4gOhpffvY1AU3rK2jm8NKp3bszwJIXK+151LqUun9AUoOgVCQqBjx9TLJhUQJfVzct+nVs7EJOckiBBZ7+pV1NmztK6XwcF4GBmhtm+PMuwDrTdHGhjMzACIDtcmUHeuVo13/vknfn1ci1C6pr9IJwl8hHiTTJ2qDQLu10+bzNHTEwC3yEhiSpYAK8vXP4alBXrXUpR5991XCnqSYmNkRFcHB7o6OBCjqvz39Gl8EDTyyhVGXrmCq5lZfBDkZW2NkXz6KYTIbi/PpVSsGDx8AjZpfNYGPIViRWHVGi0ACg19/nrx55TWBQbC7dsJl4eEJD8HU3IU5fWDp9TKGRtLcJXTREai9u8Ha9YQVdiOmMLWqMY2KFHRRP2zEaMlS6BFC5QlS7UPBlJg6egIkGzLTtxyi2flMoMEPkK8SYyMtGQHVapA+/ZasoMCBeDyZXQli2fYYXQli2t94tOR2z+t9IpCHWtr6lhb832JElwPC2NTYCAbAwKY7efH1Nu3yafX0/xZl7gWtrYUMDbO8HoIIUS69RuA7qcZxJZyTlNx5cQ1eH9oxs/no6paa1Rag6fUysUlinh5XXqDK50u41urAO7cef6z/D9Iu5gY1HZtiTl7goh65cDwfDJ0FYi1sSSqpCMmh/ehb9EcZdvfKe7OumhRdAYDYQEBhAUGJsrsFnjpEgC2JUtm+KnEkcBHiDeNgwP4+ICXlza3z9at2qSCLzzQXpten/xEhRmsmJkZQ5ydGeLsTHB0NP88fhzfGrTC3x8FqJUvX3xrkIeFRYJ5i4QQIqsovXqhfjIW7geCY+J0vgn4P0a5eAulT59MqIiidV0zMdHSi2cGVdXGRKW3hSq57+/fT7zuWdeoFB05As4vBJoGQ+Z2CTQ3j08glNup8+cTe8KXiColku+iqdcT4eGC6bHz6KZOTXF/RmZmFPT05M7hw9zYvZsy7dolWH991y4AitSunQG1T1re+M0IIdKnalX46Sd45x34+GNo3hwePEz3bjZ+/SN3z11MeuXMmbyVL1+iB5uqqpxbvZpza9bw+MYNDKamFKxYkcr9+2Pv7v4KJ/OcpcFA2wIFaFugALGqyrHgYDY8fMjGgAA+vXaNT69dw8XEJD4IamBjg6k+AwM+IYRIiZUVzJuP7sOhxHarD/Y2SZd7+ATdn//CjJmQP39W1jDjKAqYmWmvZ9MoZLjYWC24SimQAi25T1qCrMePE697Nh4lXYyMMjaQSurnzP7fparw4xQii9unPi5NpxBZwgHTGTOgQ4cUi3p068adw4fxXbiQIrVrY+HgAMD5det4cPo05gUKULxRo4w6i0Qk8BHiTdW7t5bsYNo0KFUKzpzX/om8/IBTVbjvD+cvQlCw1r6dzxLKuKL9AIUrlsXM2jpuA9i4DaV9e6xdXBIddvf48VxYvx4jCwtc6tQh/PFjbuzeza39+2kxcybO1atnyOnpFIUqVlZUsbLiq+LFuRMRweZnLUG/3rvH3Dt3MNfpaPzCnEGFTEwy5NhCCJEcpXt31KhIdMOGoZYrhupZEhyfBTf+j1GOXUE5dQ2m/Ijy3nvZW9mcTqdL2KUtKb6+MHDgqx8jNjb5oOpVWrICAhKXS27i3ZSYmGROa1Xc69gx1OCnxNoVTLEaYTEq/wZEAyboCtjx5PhxAI7+/DPnVq8GoECZMniNHQtAsXr1cG3dmosbN7KySxecq1cn/PFj7h49is5goP5XX2HIxP/FEvgI8SabPBlOnIBRo8DFBQ4chjo1tGDn+Gn4fSXsPah1WyvrBjbPgpvHT+DsBSjkDKamVCzrSqE2zbVP+A4chm07USZNSnS4G7t3c2H9eiwcHWm3eHGCT3p2jx/Prq++oquPT6Y89AqZmNCvUCH6FSpEeEwMu17oErc+IACAypaW8a1BVays0EmXOCFEJlDe6QNNmsKC+SgLFsBD7RmEbX7oPwDlz8FQuHC21lE8o9OBpaX2yizR0Vq3vVftEvhy4ooHDxIvj4pKd7VinWxTTTYRo0JA5LOxXMYm8S1kQX5+BPn5AaB/aVxVvS+/xL5sWc75+HBz3z4MJia41K1Llf79sS9bNt31TA8JfIR4kxkZwYoVWtc3f39Y8of2qc/Xk+DJU+jeCYYPhkIFEz/8VBXGfQ9XbsC8RbD4N/hyDCz9E94fkuThTv/xBwCV+/WLD3oAyrRty7k1a/A/c4Zr//xD6ZYtM+2UAUz1eprb2dHczo5ZqsqZkJD4IOjbGzf45sYNHI2MaPUsCGqSPz+WeaTPthAihyhUCOXrb+DrbyAykqO+vlSuVSu7ayWyg8HwfPLdzBIVpQVXaQ2s9u2DY/+lultLg0KPwlpgY3zOD6MPx8D776e4jaIolOvShXJdumTIqaWH/CcX4k1nbw8+Pii1aqEePgoDTsHno6FV05T79SqK9ukOwJTxcOMmDBoJej3KijWJikeFhXH36FFAa+p+WfEGDfA/c4Zb+/dneuDzIkVR8LC0xMPSkrFFi/IwMpItz7LErfb3Z9G9exgrCvVtbOJbg4o/m4tACCEyhLExqmQbE5nJyEh75cuXtvLVq6Pr2kn7kDONvR90IRFayvYcTAIfIQS4uaGWcQNzU5j+HdilL8vPDd+TXFdjie31NpaHj+LSti12mzcn6Brw5MYNYqOjMbOzS5TCEsC2dGkAAq9ceb1zeU0FjI3pWbAgPQsWJCo2ln1PnsS3Bn1w+TIfXL5MWXPz+CCoVr58GGTOICGEEHlJ3booBmN0j4KJtU29JUr3JARdZAw0bZoFlXt1EvgI8aaLjERt2xZKFYXvxr1SGs7Tf/2T4OfDROHWpAlef/+N/lnwE3z/PgAW9vYAPLp6lT0TJpC/ZEm8xoyJXx7yrFxOYKTTUT9/furnz8+UUqW4FBrKpmdB0NTbt/nh1i1sDQZaPJszqJmtLfmNjLK72kIIIcTr0elg+HCMZ/xIuI0l6FJo9VFVjK4+0Lq55/Bu4Tm7dkKITKd+9SXERsJ336X7geVU1hX3pvVwKFkMMxtrQgICuXHkBEdXb+RCeAT6nj3xWrsWgOhn8y0Yns3sfHbVKu4dP86948dxb98eIwsLAKLi0o/mQKXNzRlubs7wIkV4Eh3N38+6xG0KDOS3Bw/QA17W1vGtQW7m5jJnkBBCiFxJ+eBDdOvXY3LmGhHlCifd/T1WxfjcbfQOhVGeZW7LySTwEeJNduQILPwZ1i97pU9pqnT2TvCztZMjFbybYl+qGBu//pFzt25RacsWLJs3T7RtsQYNuLx1K/mLF8emWDFC/P1f+TSyg7XBQCcHBzo5OBCjqhx++jS+S9xHV6/y0dWrlDQ1jQ+C3rKxwVi6xAkhhMgtjI1RtmxF360r5nt2E+VsS3RBG1RjI5SoaAz3HmHk9wiqVkNZvQaefbCZk0ngI8QbTB06FMYMA/sCGbpfJ3dX7EsWw//KdfzGjcOteXMMzxICRD9LdelcrRrv/PO8i1xci5BRSvMx5FB6RaGmtTU1ra35tkQJboaHx88ZtODuXWb4+WGl19P02ZxBLe3scJCBzEIIIXI6c3OU9Rvg+HGMZkzHaPNmCA4m2sQEQ6tWKIuHa5lhcwkJfIR4Ux09CrdvgXfi1piMkM/RHv8r1wkNDoIjR7B0dARItmUnbrnFs3K5mYupKYOcnRnk7ExoTAw7Hj2Kbw1a/fAhClDdyiq+NahiZs4PIYQQQryuSpVQFv8a/+NJX1+qVKmSffV5RdLvQog3lDp3LnRrD3p9puw/JPARAAbPCqhz5mBdtCg6g4GwgADCAgMTlQ+8dAkA25IlM6U+2cVcr6d1gQLMd3PjVq1aHK1Sha+LFUMFPr9+HU9fX1z+0+ZK2PjwIaExMdlbYSGEECKPyhEtPvfu3cPHx4cdO3Zw69YtQkJCKFKkCN7e3vTt2xfjl7qEhISE8NNPP7Flyxbu3LmDhYUF7u7ujBw5kvLly2fTWQiRy/y9DRZOy5Rdhz5+SsD1WwDYN6kHX07EyMyMgp6e3Dl8mBu7d1OmXbsE21zftQuAIrVrZ0qdcgJFUfC0ssLTyorPixXjfmRkfJc4IiLwPn0aU52ORs/mDGplZ0eRXNBnWgghhMgNckSLz/Lly5k+fTpRUVG0atWKHj16oNfrmT59Ov369SPmhU9Ag4OD6dGjB/Pnz8fe3p7evXvTsmVLgoODOX/+fDaehRC5SEAAPHoMxVxeeRd+p8/jd+ocamxsguWhj5+wa84iosIjsC9ZDMe6NeFpEPj749GtGwC+CxcS8uBB/Dbn163jwenTmBcoQPFGjV65TrmNo7Ex7zo5sdrDA4BtFSowwMmJs6GhDL50CZf//qPS4cN8fu0aB58+JVZVs7nGQgghRO6VI1p8KlSowMqVK6lQoUL8spiYGAYMGMDevXvZvHkz3t5a9qjp06dz7tw5Pv/8c3r27JlgP1FRUVlabyFyrZMnwd016dSUaRR48zb/LV2JaT4rChR3wcTSgpDARwRcu0lUeARWDgVo9GF/bcbnsm5w4gTFGjfGtXVrLm7cyMouXXCuXp3wx4+5e/QoOoOB+l99hcHEJANPNHdpYmtLE1tbppcqxfnQ0PhxQd/fuMG3N25gb2REq2fjgprkz0++HD5fghBCCJGT5Ij/mo2S+IRXr9fTuXNn9u7dy9GjR/H29iYsLIzVq1fj6emZKOgBMJKJA4VImydPwDrfa+3Cyd0V1/q18b98nYfXbhIZEorOYMCmkCNFq1bCo0VDjM21TG5Y54OnTwGo9+WX2JctyzkfH27u24fBxASXunWp0r8/9mXLvu6Z5QmKouBuYYG7hQUfubgQGBXF1mdzBq17+JBf793DSFGo96xLXGs7O0o+y5onhBBCiKTliMAnOfpng65Nnn0CfPz4cUJDQ2natClBQUFs3bqVwMBAihYtSoMGDRKNBRJCJCMDJtUsUNyFeoPeSfcxFUWhXJculOvS5bXr8KawNTLibUdH3nZ0JDo2lgMvzBk0/PJlhl++TBlz8/ggqHa+fBjJnEFCCCFEAjk68Nm2bRsAdevWBeDatWsAqKpKixYt8H8hLa6LiwuLFi2iSJEiWV9RIXIbGxttjE9WefQYrK2z7nh5mEGno66NDXVtbJhUsiRXw8LY9CwImnn7NlNu3cLGYKC5rS2t7exobmuL3RvSGh4bG8vFixc5ceIET58+JTIykrt373L58mUqVKiAq6tr/AdqQggh3jw5NvA5ePAgGzZsoFatWtSpUweAoKAgAObNm0edOnX46KOPsLCwYM2aNfzwww98/PHHLF++PF3HOX36NPfv38/w+r8KX1/f7K5CniPXNGn62FgqnL2AEhOTaems48XGop45zwkgRn4fKXrV+7X2sxcvzgcUFga3b3P99m2uZ0Ddcqr79++zdu06Dh8+ysWL57GxscPVtRL58tlhMBgTHR3Jvn2nuXRpLI8e+VO6dBmqVKlEhw7tKViwYHZXP9eSZ2vmkOuaOeS6Zo7svq7+ycwLmJIcGfjcuXOHUaNGYW9vz+TJk+OXxz7LHmVqasoPP/wQ3wWub9++7N+/n71793L16lVKlCiR5mN5eHhQuHDhjD2BV+CbSyeCysnkmqZMdXSEq9ehdCbPm3P1Bop9ASo1bJi5x8nlMvp+jVVVfIOC4rvEHQ0OBqCYqWl8l7h61taY5sIWEFVV2bFjBzNnzuHff3fRrFkP3n33e9zcKmNtbZvsdk+fPuLChaPs3buOnj17U6eOFx98MIQmTZqgZED3zzeFPFszh1zXzCHXNXPkhOt6+/btdG+T4wKfR48e0bdvX8LCwli2bBn29vbx68zNzQGoXLlyfNATx9PTk71793L58uV0BT5CvLFaNIfN2+HDTA58/toOzZtn7jFEIjpFoVq+fFTLl4+vixfHLyIifs6gX+7eZbafHxY6HU2edYlraWuLUy7IqHf37l0GDBjE2bMX6dRpOB9+uBRzc8vUNwTy5ctPtWqNqFatEYMGfc+2bb8zePBw3NxKsHDhApydnTO59kIIIbJTjhr9GhoaysCBA/Hz82PevHm4u7snWF+oUCEALC0T/5OLWxYREZH5FRUiD1DeHwIr10FUdOYdJCoaVqzVjiWylbOJCf0LFWJd+fIE1KnD5vLleadgQXyDguh34QKFDhygmq8vX1+/jm9QUI6bM0hVVf73v2WUL18Re/sK/PrrCdq3H5jmoOdlZmYWtG3bn19/PY6zc1UqVvTk11+XoOaw8xZCCJFxckyLT2RkJMOGDePMmTPMnDmT6tWrJypT9lmq2xs3biRa5+fnB5CghUgIkYJy5aBMGVi5Frp3ypxjrNkApUpD+fKZs3/xSsz0elrY2dHCzo7ZqsqpkJD4LnFfX7/OV9ev42RsHD9nUOP8+bHIxi5xsbGxDBkyjL//3sWUKX9Rpkz6u1c8fhzA4cO7uXjxFBcvnsbP7xqqqjJkyJf07fsVdeu249tve7N37z4WLJiHXq9HVVWWLl3Nb7+t4cqVG5iZmVKtWkVGjOhPhQruyR5r9+6DzJmzhJMnzxITE0uZMqXo27cbbds2fZ3LIIQQ4jXliMAnJiaG0aNHs2/fPiZOnJjkvD4Azs7OlC9fHl9f3wR9Cx8/fsymTZuwsrKiYsWKWVl1IXI1ZfYc1Pr1oL4XFMrggd5378G0eSg7d2XsfkWGUhSFCpaWVLC05NOiRfGPjOSvZ3MGrXjwgJ/v3sVEUWiQP3/82KCipqZZVr/Y2Fj69HmPs2evMX/+fiwtXy074NGj+5k//7v4n18e0+PqWol58/bxySdt6dmzN8uWLeXjj7/jjz/WY2VlQcOGdQgMfMy2bbvZuXM///vfTOrWTfwB3YoVGxk58mt0Oh1eXtUwMTFm9+6DvP/+p1y9epMRI/q9Uv2FEEK8vhwR+MyePZutW7fi6urKrVu3mDVrVoL17u7uNG7cGICxY8fSp08f3nvvPVq2bImFhQXbt28nICCAcePGYSaT+AmRdh4eMGIkjPkKfp4JJhk0F1ZkFIz5Bj4cLq09uYy9sTG9Cxakd8GCRMbGsvfJEzYGBLAhIIChly4x9NIlyltYxAdBNfLlQ5+JiQGGDfuQ06evMHXqVkxNzV95P3Z29rRs2RVX1/K4uVVgwYLvOX78QIIyFhZWTJ68mY8+akmHDj04cuQyTk6ObNiwGCcnBwD++GMdo0aNZ/jwr9i3zwdT0+fjovz9A/j004nodDp+/302Xl7VADh37jJt2rzLjz8uoFmzepQtW/qVz0MIIcSryxGBz927dwG4ePEiFy9eTLS+ffv28YFP1apVWbJkSXywFBUVRenSpRk5ciRt2rTJ0noLkRcoY8agHjkCI8fB1G9fP/iJiITRn4N9QZRPPsmYSopsYazT0TB/fhrmz8/UUqW4GBoa3yVu8q1bfH/zJnYGAy2fBUHNbG2xNmTcv5WVK1fy119/89NPB18r6AGoWLEmFSvWTLWciYkp33+/jj593gL0jBjRLz7oAejWrS3Llq3h2LEzbNr0Dx07toxf99tvPoSFhdO+ffP4oAfA3b0Uffp0Zu7cpSxa9AdTpnz+WucihBDi1eSIwGfixIlMnDgxzeWrVKnC4sWLM7FGQrxBDAaUP/5Afftt6PsBTPwCChd6tX353YWx34BjIZQ//4QMfBMssp+ruTkjzc0ZWaQIj6Oi2PboERsDAtgcEMD/7t/HoCjUtbaObw1yNX/1YOXBgwcMGTKMCRPWvnL3tlel1xtQFGMgBk/PxGN5mjdvwLFjZ9i5c3+CwGfnzv0ANGtWP8lt5s5dGl9GCCFE1stRWd2EENnExARl5Upo3wk69YFlK7SWm7SKjILfVkHHd8C7HcqqVZALUiOLV2djZEQXBweWurtzv04d9nl68lGRIjyMimLUlSu4HTqE68GDjLx8mR2PHhH5bB62tBo8eAjNmvXGwyP1VpqMdufODWJiYjA2NmbMmLGJMr3FdVU7f/5KguVxP7u7l0q0z7ht7t3z5/Hjp5lRbSGEEKmQj2OFEBq9HmXMGPD2Rv3gA5izCDp5Q/NG2iSnxkYJy0dFw6UrsHWHlha7fHmUf3dr2eLEG0WvKNS2tqa2tTUTSpTgRng4m551iZvr58e027fJp9fT7NmcQS1sbbE3Tr5L5YEDBzh0yJdly/6XhWfxXEDAfQCcnYtz6tRhfv99BatW/Y2bW0kmTBiDo6OWPfTu3fvx2wQFBRMcHAJAwYL2hISEMnz4l4SHRzB16pfY29thbW3FkydB3LlzHxubfFl/YkII8YaTwEcIkVDZsijbt8OFC6hz58LY8XDjBpQqCTbWxMTGog8KhstXwMUFmjZF2b1HS40tBFDU1JT3nZ1539mZkJgY/nnWJW5jQAAr/f1RgJr58sV3iStvYZEgy9qsWXPp0GEoJiZZlz3uReHhYQCYmprRseMwpk37ibt3n3Do0HF69GiPpaUFACEhofHbhISExX9vZmbKli272Lx5JwBr1vzFwIE9MTMz48mToATbCSGEyDoS+AghkubmhjJjhvZ9SAicOgVPnnDt4kVKV6umZYRLYjJhIV5kodfTpkAB2hQoQKyqcjw4OD4I+uzaNT67do0iJibxQZBHVBSbNm1kxYoZ2V11AFq06M3ixd9TsKAbbm4lKVWqGPfu+ae6XbVqFSlZsijh4RE0aFA7C2oqhBAiNRL4CCFSZ2EBNbWxFk8LFIAq6Z9AUgidolDZyorKVlZ8UawYdyMi4ucMWnrvHvPu3MF4xQoavNUWa2vbbKunqak2LUJERDiWltbUq9eaqlWL8dlnnwIQGqq17lhYPE/eYGHxfCqFsLBwHBwKsHv36gT7DQtLvJ0QQoisI8kNhBBCZAsnExPec3JijYcHAV5ebK1QgaLnLlK/TvZOTWBn5whAYKDWslO7dmt27dodv/7+fW25k5Nj/DIrK8v4LnBJtQiFhYXz5EkQAIUKOSZaL4QQIvNJ4COEECLbmeh0NLW15em5s7i5ZW+LYqFCRTEYDDx+HMCTJ4G4uVXh6FHf+OxuZ89eAqBMmZIJtov7+dy5y4n2GbdNwYL2kthACCGyiQQ+QgghcoQ7d+4QGRlJwYIu2VoPU1Mz3N09ATh8eDf29oXQ6fTcunULgC1bdgEkGrtTv77287Zt/yba55YtO5PcRgghRNaRwEcIIUSOcPr0aVxdKybI8JZdWrXqBsCKFQsJDPTH1bUip06d4o8/1nHs2GkcHQvQqlWjBNv06NEOU1MT1q3bxt69h+OXnzt3mV9/XYmiKLz7btcsPQ8hhBDPSXIDIYQQOcLTp0+xtLTJlH0/evSQSZNGx//s53cdgFWrfmbbNi0JQYkSZRgwYCwA1arVo3791uzatZHhw7tgMKhMmrSQK1duY2RkYPr0rzA1TThJr4NDAb777mNGj/6W7t2HUrdudYyNjdi9+yDh4RGMHNmfcuVcM+X8hBBCpE4CHyGEEDlCZGQker1R6gVfQVRUJJcunU60/P59P+7f9wPA+KVJVYcO/ZJSpcry998+3Lx5maioaBo3rsvIkf2pWLFsksfp1q0tTk6OzJ79K76+J4mJicXdvTT9+79N27bNMv7EhBBCpJkEPkIIIXIEExMToqMjM2XfDg6FWL36SLq2URSFFi260KJFFz4a1xGL1nUp3a4dB42Nuf7wIQ5GRjgYG+NoZISFXh/fRa9evZrUq1czM05DCCHEa5DARwghRI5gY2PD06cB2V2NJAU+DuBodDRbr19Pcr2ZToeDkRGOxsY4GBs//z4uOHrh+wJGRuhzwDgmIYRITVRUFGfOnOHYsWP4+/sTHh5OREQkAQEP+eeff7Czs8PT0xMPD49EreY5kQQ+QgghcoSKFSty4cJxYmNj0elyTu4dVVXxu3ySKz3/IL+DA/6RkdyPiuJBZCQPoqK4HxmZ4PvbEREcDQriQVQU0c9SYL9IAQoYGaU5ULLQ67P+pIUQb6SgoCB8fHzYv/8/jhzx5ezZ0xQqVBQ3tyrY2jphZGSKkZEpUVH2nDr1kEePTjNp0jRu3bqKu3s5qlatQq1aNejQoQPW1tbZfTqJSOAjhBAiRyhQoAA2Nvm5ffsyLi45JwnA3bvXMTMzo2DBggAUNjWlsKlpqtvFqiqPo6N5kEqgdCQoiAeRkTyNiUlyPxY6XcLgKIVAyVZak4QQr+DMmTPMmTOP5ct/p1Klt6hUqQH9+3endOlKmJtbprp9WFgIly6d4MIFX377bRMjRoykS5euDBkymIoVK2bBGaSNBD5CCCFyjMqVq3D+vG+OCnzOnTtC5crpn1RVpyjYPgtGyqShfFhMDP7PAqQXA6UHkZFasBQVxY3wcA4FBeEfGUlSYZIOrTUpudYjx2df4wInM2lNEuKNpaoqPj4+TJs2k4sXL+LtPYAlS07h4OCc7n2ZmVlQoUJtKlSoTefOwwgIuMf69T/TvHlrihUryvDhw+jSpUu2T1cggY8QQogco2nTxvj4rKFp07ezuyrx9uxZQ4sWjTP9OGZ6PS56PS5pbE16FB2dqPXo5UDp4NOnPIiKIjiZ1iRLvT7FbnYvBkq2RkbopDVJiDzBz8+P/v0HcuXKLXr3Hsf337fDYMi4rJp2dgV5991x9Oo1ln37NvLNN9+ycOEvLFr0My4u2TdJtQQ+QgghcoyePXvw2Wef4e9/B3v7QtldHQID7/Pff1v444952V2VBHSKgp2REXZGRpS1sEi1fGhMTIIWpKQCpavh4fz39Cn+UVHEJrEPPWBvbMxGExOanjiRaqBkKq1JQuQ4qqqyZMlSRo/+iPbt3+eTT9ZgZJR5SQkMBgP16rWjTp3W/P77ZDw9q/D99xPo379ftrT+SOAjhBAix8iXLx9du3Zj/fqF9O37ZXZXhw0bfqFjx07Y2Nhkd1Vei7leTzEzM4qZmaVaNkZVCYyKSnI80oOoKAgO5ml0NJfDwngQGUlIbFJhEuTT61NN3BAXKOU3GLK9C4wQed39+/d5992+XL16m6lTt+HqWinLjm0wGOjd+xPq1PFmwoQ+rFixkiVLFuPsnP5uda9Vjyw9mhBCCJGKoUPfp2HDJnTp8iFWVjbZVo+QkKf4+Mzlr782ZFsdsoNeUbA3Nsbe2JhySbQm+fr68l+V52OeQl5oTUqu693F0FD2RkXxMCqKxHnuwKAo8cFQaoGSvbExJjko658QucH169dp1KgJXl6dMr2VJyUlS3qwYMF//Prrt9Su7cX27dsoXbp0lh1fAh8hhBA5ioeHBx06tGfWrBF8+unibKvHnDkf0apVCzw9PbOtDrmBhV5PcTMziqexNelhChnu4gKlC6Gh3I+KIjyZ1iRrvT5NqcAdjYywltYk8Ya7cOECjRo1oWvXj+jceVh2VweDwUC/fl9hb+/MW2/V5++/t+Lh4ZE1x86SowghhBDpMGXKD3h4VGD//s3Urt0yy49/6NDfHD68hTNnTmX5sfMyvaLg+Cw4SY2qqoTExKSYCvxBVBTnQ0P59/FjAqKjk9yP0bPWpLQESvZGRhhLa5LIQ27cuEGjRk3o3ftL2rTpm93VSaBt2/6YmlrQpEkz9uz5l1KlSmX6MSXwEUIIkeNYWlqyaNHPdO/em59+OvhK6VVf1cOHd5k0qR+LFy8kX758WXZckZCiKFgaDFgaDJRMQ2tSdGwsD6OiUg2UzoaEcD8ykogkJpcFyG8wpDlQyqfXS2uSyLECAgJo1KgJnTuPzHFBT5xmzboTHh5Mo0ZNOHjwQPx8aZlFAh8hhBA5UsOGDRk58kNGjGjC7Nn/kj+/faYf88mTAEaObMrgwQNo2rRpph9PZByDTkdBExMKmpikWlZVVYKejU1KKVA6HRLCg8hIApNpTTJRlDRPLlvAyAgjaU0SWWjIkGFUqdKcrl2HZ3dVUtS27QDu3LlG//6DWL/eJ1M/TJDARwghRI718ccf8fRpEEOH1mPatG04OBTOtGP5+99h5MimdOjgzWeffZppxxHZT1EU8hkM5DMYSEvnmshnrUkpBUr3IiM5+SxQikymNcnOYEg2UKoC7H/yJD5QspTWJPEafHx8+O+/I/z66/Hsrkqa9O37Ff36VeW3336nZ88emXYcCXyEEELkaN9++w358lkxYEANRo2aR926bTL8GPv2bWLy5IF88MEQPvlkrLzhFAkY63QUMjGhUBpbk55ERz+fIymZQOl4cDAPoqJ4/Kw16YiVFXWOHYvfj6lOl2BepBcDpZfnTCpgZIRBWpPEMw8fPmTw4CF8/fVKTE3NM+040dHRnDx5kP/+28G5c8d4+PA+AA4Ohaha9S3ateuVZGZOVVXZunU127evwc/vBiYmppQpU5F33vmaESMG06hRQ5ycnBJtt3v3QebMWcLJk2eJiYmlRIkiREWlL5SRwEcIIUSO9/HHH1GzZg369HmPnTtX8uGHM7C2tn3t/T59+ohZs0Zw6tRuli//Hw0aNMiA2oo3maIo2BgZYWNkhKt56m86I2Jj8Y+M5P6ZM/xVvnySgdKdyEiOPQuUopNoTVIAOyOjZLvZvbzMQiaXzdOGDBlGw4bdqFixTqYe5/z543z33YcAFCxYGE/P2sTGxnDx4mnWrl3Cnj1b+Prr+Tg5FUmw3dy549mxYz3m5hZUrlyHp08fc/jwbo4d20/t2h0YMGAQ69evTfAB1IoVGxk58mt0Oh1eXtUwMTHm33//IyLCjF9++ZMvvxyVpjpL4COEECJXeOuttzh16gSffPIZPXqUoVWrvrRrNxAnp2Lp3te9ezdZt24BGzb8TJcunVm+/CSWlpYZX2khUmGi01HY1JT7QHM7uxTLqqrK4+joBKm/kwqUjgYHcz8ykqcxMUnux1ynS9RqlNzksnZGRuilBTTX2L17NwcOHGLp0szPSKkoOurUaUq7dr0pUaJM/PKwsBB++OEjTp48xKxZXzJhwqL4dYcP72bHjvXY2Tny/feLsbNzAOCff9Yxd+54rl69TkjIDbZu3Urz5s0B8PcP4NNPJ6LT6fj999l4eVUDYNeuvfTo8SELF/5B585tKFs29fmAJPARQgiRa1hYWDBz5nSGDn2fuXPn07dvVcqXr0WdOm1xc6tCiRLlkpyYLzo6iqtXz3D+vC/796/n5Mm99OzZi717/6VMmTJJHEmInEdRFPIbGZHfyIi03LXhMTH4vzRH0suB0s3wcI4EBfEgMpKkwiQdUCCNk8s6GBtjLq1J2WrWrDl07jw8U7u4xSlXrjLlylVOtNzMzIJ33hnOqFHduXDhJA8e3MHBoRAAmzb9AUDnzv3igx6ARo3a8vffa7h06QxeXt7MnDknPvD57TcfwsLCad++eXzQA1CqVDGMjCKJijJh0aI/mDLl81TrLIGPEEKIXMfV1ZXp06cyYcK3rFixgu3bd7JmzTRu3LhGiRLu5Mtni5GRMeHhYYSGPuXq1XMUKVKUqlWr0rt3W7p2/R0LC4vsPg0hMpWpXk8RvZ4ipqaplo1VVR5FR2vBUQqB0qGnT3kQFUVQMq1JFjpdmieXtTUyQietSRnm3r17bNu2jdWrf8ruquDk5BL//ePHATg4FCI8PIxz544CUL16vUTbVK/egEuXzhAbq3DgwH6uX79OsWLF2LlzPwDNmtVPtI3BEE1UlEl8mdRI4COEECLXMjc3p0+fPvTp0weAkJAQTp8+zdOnT4mIiODGjRtUrVqVcuXKSVc2IVKgUxTsjIywMzLCPQ0fCoTFxDwPjpIJlK6Fh3Pw6VP8o6KITWIferTWpLQGSqbSmpSihQt/plGjLlhaWmd3VfD3vxv/fYEC2tw8d+7cIDo6GhsbuyTHaBYrpnVV8/O7QfPmvZk//ycmTpzA+fNXAHB3T5yDUafT7qx79/x5/PgpNjYpz70mgY8QQog8w8LCgho1asT/7OvrS5UqVbKxRkLkTWZ6PUX1eoqmsTUpICoq1UDpSlgYDyIjCYlNKkwCK70+zZPL5jcY3qjWpOjoaObPX8D332/I7qoAsHXrKgDKlq2Mra02B1tAgJb1Le7nW7eusmDBBIoUKUn//mMSlPvww68YOvQtRo8eTXBwCAAFC9oTEhLK8OFfEh4ewejRA1AUsLKyICgohDt37kvgI4QQQgghso9OUbA3Nsbe2JhyaWhNCnk2uWxKgdLlsDD2PXnCw6gokpo1yaAo2BsZscHEhGYnTqQaKJnk8nTge/fuJX9+R1xdK2V3VTh//gRbt65Cp9PTu/cH8cvDw8MAMDHRguWtW1dx7txxzp07TpMm7TEzs3hWLpSiRd0oWrQMW7dujd/ezMyULVt2sXnzTgDKl3cDwNTUlKCgEEJCQlOtmwQ+QgghhBAix7DQ6yluZkZxM7NUy8bEtSYlk+GOkBAeR0dzMSyM+5GRhCXTmmSt1yc7uezLgZKNwZDj5vo6dOgw5ct7ZXc1ePToIdOmfUpMTAzvvDOc0qU9ki1bo0YD9uzZSpEixXF2LkZgoH+C9R4edTh+/GSCZdWqVaRkyaKEh0dQs2ZlfvklffWTwEcIIYQQQuRKekXRghRjY5J6i+3r68vBF7q7BqdhctnzoaHsfvKEgGRak4wUJT4YSi1QsjcywjgLWpMOH/albNlWmX6clISGBvPddx/y8OF9mjXrRJs2PROsNzXVAtmIiHAAypevxpIl/8Svj4gIe1ZOy0jn5laFf/9dHL8+LCwcB4cC7N69GoDbt28DEB6u7c/CIvVMdhL4CCGEEEKIN4KlwYClwUCJNLQmRcfG8vDFsUnJBErnQkO5HxlJRBKTywLYGAwJ5kxKKVDKp9e/UmvSkSNH6NDhi3Rvl1GioiKZOHEU165doHbtJvTr93GiMnZ2jgCJWnbixC2PK1emTBVmzBiGtXVpgoNDuHfPn1KlEnaVVFXixwAVKuSYaj0l8BFCCCGEEOIlBp2OgiYmFDQxSbWsqqoEx8SkOrns2dBQdj5+TGB0dJL7MX7WgpWWQMneyAgjnY7Hjx/j738fFxe3jL4EaRITE8PUqZ9y5owvlSvX4cMPx6NLopWrUKGiGAwGHj8O4MmTwESZ3a5fvwSAi0tJAAoWLEpERAQlSrhw8uQ5zp27TKlSxRJsExure1bWPtXEBiCBjxBCCCGEEK9FURSsDAasDAYSJ11OLOpZa1JqgdLpkBDuR0YSmUxrkq3BgOWZMziVKIs+G9J9q6rKvHnfcujQLjw8qvLRRz9gMCQdXpiamuHu7smpU4c5fHg3jRu3S7D+0KFdAHh61ga0a1qmTGWKF3fi5MlzbNv2L97ejRNsEx2tHatBg9ppqq8EPkIIIYQQQmQhI50OJxMTnNLYmvT0Waa7pAKl48ePE2FdIAtqndivv05l584NuLlVYOzYqRgbp3w+rVp149Spw6xYsRBPz9rY2TkA8M8/67h06TT58xegVq1G8eXz5bOjUiU3tm7dx7p12+jatQ1eXtUAuHz5OlFRxiiKwrvvdk1TfSXwEUIIIYQQIodSFAVrgwFrg4HS5okH8K84fpyfzVJPE57RDh3axcaNywGwtrbl559/SLJc48btcHevBEC1avWoX781u3ZtZPjwLlSoUJ2goMecOXMUg8HAsGFfJQiejI1NMTbW8913HzN69Ld07z6UunWrY2xsxL///gco9O3bhXLlXNNUZwl8hBBCCCGEyKWioqLQ67P+LX1wcFD893Hd1JJSrlyV+MAHYOjQLylVqix//+3D0aP7MDY2oUqVunTp0p9Spcom2NZgMCIyMpI+fdri5OTI7Nm/4ut7kpiYWEqVKsblyyfo3//tNNdZAh8hhBBCCCFyKRMTE6KjI7P8uA0betOwoXe6t1MUhRYtutCiRZdUy0ZFRWBqqk14Wq9eTerVqxm/7vbt2zRq1Ci5TZOUIwKfe/fu4ePjw44dO7h16xYhISEUKVIEb29v+vbti7GxcXzZhg0b4ufnl+R+Dh8+TL58qWd0EEIIIYQQIi8wNTUlMjI8u6uRKSIjw+MDn4yQIwKf5cuXM3/+fNzd3WnVqhVGRkbs27eP6dOnc+DAARYvXpwgU4WzszPt27dPtB+TNAwQE0IIIYQQIq8oWLAg9+7dzO5qZIr7929SsGDBDNtfjgh8KlSowMqVK6lQoUL8spiYGAYMGMDevXvZvHkz3t7Pm9KcnZ0ZNmxYdlRVCCGEEEKIHKN8+fLcvHmZ8PAwTE1Tn5g1t4iOjubSpVN4enpm2D4Tzy6UDRo1apQg6AHQ6/V07twZgKNHj2ZHtYQQQgghhMjRTExMcHUtw+XLJ7K7Khnq+vWzODsXwcrKKsP2mSNafJIT173t5S5sT58+ZeXKlQQGBuLo6IiXlxcFCmRP/nIhhBBCCCGyU9WqVTl/3hcPj5qpF84lzp/3pWrVqhm6zxwd+Gzbtg2AunXrJlh+/vx5xo0bF/+zqakpY8aMoXv37llaPyGEEEIIIbJb9epV2Lz5YHZXI0NdvOhLrVpVMnSfOTbwOXjwIBs2bKBWrVrUqVMnfnnXrl2pXbs2xYsXJzw8nAMHDjBx4kS++eYbXFxc8PLyStdxTp8+zf379zO6+q/E19c3u6uQ58g1zRxyXTOHXNfMIdc148k1zRxyXTPHm3BdbWxsOHTob2JiYhIkBMutVFXl0KFttGr1WbK/P39//3TvN0cGPnfu3GHUqFHY29szefLkBOsGDhwY/72lpSXe3t44ODjQu3dvfvnll3QHPh4eHhQuXDhD6v06fH19qVIlY6PaN51c08wh1zVzyHXNHHJdM55c08wh1zVzvCnXtUqVKkyePJUDB/7Cy6t1dlfntfn67sTc3ITevXujKEqSZW7fvp3u/eaI5AYvevToEX379iUsLIyffvoJe3v7VLepUaMG9vb2nDp1KgtqKIQQQgghRM4ybNj7rF07N7urkSHWrp3L0KHvJxv0vKocFfiEhoYycOBA/Pz8mDdvHu7u7mne1sbGhvDwvDl5kxBCCCGEECnp0qUL584d5vbtK9ldldfy4IEfvr476NWrZ4bvO8cEPpGRkQwbNowzZ84wbdo0qlevnuZtw8LCuHnzJs7OzplYQyGEEEIIIXImMzMz+vTpw7p1C7K7Kq9l/fqFdOv2doamsY6TIwKfmJgYRo8ezb59+/juu+9o1KhRkuWuXbtGcHBwgmWxsbFMmTKFiIgImjZtmhXVFUIIIYQQIscZOvR9Nm1axN2717O7Kq/E3/8Oa9fO5YMPhmbK/nNEcoPZs2ezdetWXF1duXXrFrNmzUqw3t3dncaNG/Pvv/8yY8YMqlWrhouLC6qqcuTIEc6fP4+rq2uCxAdCCCGEEEK8SYoXL87HH3/ExIl9mT59e4aPkclMqqoyefJABg8enK7hLumRIwKfu3fvAnDx4kUuXryYaH379u1p3Lgxnp6e1K5dm7Nnz3Lo0CGio6NxdnZm0KBB9O/fH0tLy6yuuhBCCCGEEDnG6NGjWL16DT4+C+jQYVB2VyfN/vrrfzx6dJPPP1+dacfIEYHPxIkTmThxYqrlKlasyJw5c7KgRkIIIYQQQuQ+BoOBJUsWU7duPWrVao6TU7HsrlKq/P3vMHfuaP7+eyvGxsaZdpwcMcZHCCGEEEIIkTHKli3LRx+N5ttvexMZGZHd1UlRdHQUEyb0YfDgwXh6embqsSTwEUIIIYQQIo/56KPRFCvmyFdfvU10dHR2VydJMTExfPvtO9jamvDFF+My/XgS+AghhBBCCJHH6PV6fv99GXp9CBMm9MlxwU9MTAyTJw8iNPQOq1atwMjIKNOPmSPG+GSHmJgYAO7du5fNNdH4+/tz+/bt7K5GniLXNHPIdc0ccl0zh1zXjCfXNHPIdc0ccl1h3rw5DBgwiLFj2zBixCyMjU2yu0pER0cxa9ZIIiICWLRoIQEBAeneR9x7+Lj39GmhqKqqpvtIecCRI0fo0aNHdldDCCGEEEII8Yp+++03qlatmqayb2zgEx4ezunTp7G3t0ev12d3N4xAcAAALWdJREFUdYQQQgghhBBpFBMTg7+/Px4eHpiamqZpmzc28BFCCCGEEEK8OSS5gRBCCCGEECLPk8BHCCGEEEIIkedJ4COEEEIIIYTI8yTwEUIIIYQQQuR5EvgIIYQQQggh8jwJfIQQQgghhBB5ngQ+QgghhBBCiDxPAh8hhBBCCCFEnmfI7grkdbdv36ZRo0ZJritTpgzr1q1LsOzEiRP8+OOPnDp1CmNjY2rXrs3YsWNxdHTMiurmCr169eLQoUPJri9SpAjbt28HoGHDhvj5+SVZ7vDhw+TLly9T6pjT7dq1i127dnH8+HEuXrxITEwMmzdvpmTJkonKpueefPDgAT/88AN79uwhMjKScuXKMWLECKpUqZIVp5Xt0nJdQ0ND2bhxI1u2bOHKlSsEBARQoEAB3nrrLYYOHYqDg0OCfY4dOxYfH58kjzdnzhwaN26cqeeUE6T1fk3v37vcr6lf11mzZjF79uxU9+Pk5ATI/Xrv3j18fHzYsWMHt27dIiQkhCJFiuDt7U3fvn0xNjZOUF6er6lL6zWVZ2v6pOdezUvPVgl8skj16tWpXr16gmUFChRI8PPZs2fp1asXZmZmdOzYkeDgYDZs2MCJEyfw8fHB2to6K6ucY7Vv3z7RtQS4ceMGGzZsoHbt2gmWOzs70759+0TlTUxMMq2OOd0vv/zCoUOHsLe3x9bWFn9//yTLpeeeDA4OplevXty6dYtWrVphY2PD+vXreeedd/jtt9+oWLFiVp1etknLdT1+/Diff/45Tk5O1K5dGzs7O86dO8eff/7Jzp07WblyJQULFky03dChQxMtK168eKacR06T1vsV0v73Lvdr2q5r9erVk7z3oqOjWbBgAUWLFo0Pel70pt6vy5cvZ/78+bi7u9OqVSuMjIzYt28f06dP58CBAyxevBi9Xg/I8zWt0npN5dmaPum5VyEPPVtVkalu3bqlurq6qjNnzky1bO/evdVy5cqp586di1+2YsUK1dXVVZ06dWpmVjNPGD9+vOrq6qr6+vrGL2vQoIHas2fPbKxVznT48GH11q1bqqqq6pgxY1RXV1f18uXLicql556cPXu26urqqv7222/xyy5evKiWK1dO7datWyadSc6Slut6/vx59a+//lJjYmISLJ8zZ47q6uqqjhs3LsHyuP28ydJ6v6bn713u17Rf16Rs3bpVdXV1VefNm5dg+Zt+v27fvl09ceJEgmXR0dHqe++9p7q6uqrr16+PXy7P17RJ6zWVZ2v6pOdezUvPVhnjk0M8fPiQgwcP4uXlRZkyZeKXd+jQAVtbWzZu3JiNtcv5IiMj2bBhA0WLFqVy5crZXZ0cr2rVqhQuXDjFMum9Jzdt2oSNjQ1dunSJX1a6dGnq16/P0aNHuXPnTsaeRA6Uluvq5uZG8+bN0ekSPn67desGwNGjRzOtfrlVWq5resn9+nrXdc2aNSiKQps2bTK4Vrlbo0aNqFChQoJler2ezp07A8//vuX5mnZpvabybE2ftF7X9Mrp96oEPlnkxo0bLFmyhJ9++ont27cTHh6eYP2JEydQVTXRm3a9Xk+lSpW4ffs2gYGBWVnlXOWff/7h8ePHtG3bNtG6p0+fsnLlShYsWMDatWt5+PBhNtQw90nPPRkcHMyVK1coX748BkPCHrRVq1YF4OTJk1lT8VwqrktBcl0wN2/ezIIFC/j999+5cuVKVlYtV0nL37vcr6/H39+fPXv2UKNGDQoVKpRkGblfE3r571uer68vtWdmWsvJvZpQctcrrzxbZYxPFtmwYQMbNmyI/9nBwYEZM2bEP/TiBo05OzsTFBTEiBEjKFWqFGPHjsXZ2RnQEiXY2tpmfeVzgdWrV6MoSpKBz/nz5xk3blz8z6ampowZM4bu3btnZRVznfTck7dv3waIfxP07bffcvPmTaZOnZqgrEjetm3bAKhbt26S60eMGJHg506dOvH1118n+ufypkvL37vcr6/Hx8eH6OjoJPv7x5H7NaGX/77l+fr6UntmprWc3KsJJXe98sqz9c38rWYhMzMzRo0aRZMmTXBycsLf35/169czb948Bg0axObNmylQoAAhISEAWFhYsHfvXvbs2cOePXsYMGAAFhYWAPFlREL3799n3759VKtWLVG3ja5du1K7dm2KFy9OeHg4Bw4cYOLEiXzzzTe4uLjg5eWVTbXO+dJzT75YNjAwkP/9738A7N27Nz7bi9y/yQsICGDGjBnY2try7rvvJlhXo0YNWrduTdmyZTE2NubMmTNMmjSJVatWUaBAgUT/tN9kaf17l/v19fj4+GBubk7Tpk0TrZP7NbGDBw+yYcMGatWqRZ06dQB5vr6upK5pUuTZmj7JXde89GyVrm6ZzM7OjgEDBlC8eHFMTU0pUqQIQ4YMYeDAgTx58oSVK1cm2qZSpUo4OTnh5eVF/vz5s6HWuYuPjw+xsbFJfvo4cOBAypcvj6WlJQUKFMDb25upU6eiqiq//PJLNtQ2d0rPPWljY0ONGjVwdnbG09Mzi2qYe0VGRjJ8+HAePXrE1KlTsbGxSbC+ffv2eHl5YWtri6WlJTVq1ODnn3/GxsaGpUuXEhkZmT0Vz4Fe5e9d7tf0OXr0KFevXqVZs2aYm5snWi/3a0J37txh1KhR2NvbM3ny5CTLyPM1fdJyTUGeremV0nXNS89WafHJJq1atWL27NmcOnUKIMEnPE5OTuzatSu+7IsRtEgs7tPHZs2apal8jRo1sLe3j7/2ImnpuSdfLKvT6Vi6dGl82bj+vHL/JhYbG8uYMWM4dOgQ3333HbVq1UrTdra2ttSpU4dNmzZx5coV3N3dM7mmuVdSf+9yv766NWvWANCuXbs0b/Om3q+PHj2ib9++hIWFsWzZMuzt7ePXyfP11aR0TV8kz9b0Set1fVFufbZKi082ifvkISIiAiC+72NSE0TFLcvorEZ5wZEjR7h+/TpNmjRJ1x+TjY1NogQTIqH03JNxX5PK1iL3b/K+++47Nm/ezKhRo+jUqVO6to17hsh9nLqX/97lfn01YWFhbN68GWdnZ2rUqJGubd+0+zU0NJSBAwfi5+fHvHnzEr2Bludr+qV2TV8kz9a0S891fVlufLZK4JNNLl68CDwfAFahQgUURUmUPjAmJobjx49TuHBhSWyQhNWrVwOkOMj2ZWFhYdy8eTP+H49IWnruSUtLS0qUKMGpU6eIjo5OUP7IkSPx+xPPzZ49m2XLlvHee+8xYMCAdG//8jNEJC2pv3e5X1/Nli1bCAkJoU2bNiiKkq5t36T7NTIykmHDhnHmzBmmTZuW5ITb8nxNn7Rc0zjybE279FzXl+XWZ6sEPpns7NmzxMTEJFgWHBzMtGnTAOIHh9rb21OtWjX27t3L+fPn48uuWbOGwMBAWrVqlXWVziVCQkLYsmULTk5OSX76eO3aNYKDgxMsi42NZcqUKURERCQ5MFc8l957slWrVjx+/DjBuLXLly+za9cuPD0934h/Imm1ZMkSZs2aRZcuXRgzZkyy5R49esStW7cSLd+8eTOHDx+mUqVKODo6ZmZVc430/r3L/Zp+qXVzk/tVC1xGjx7Nvn37+O6772jUqFGS5eT5mnZpvaYgz9b0SOt1zWvPVkVVVTVba5DHvf/++5w8eZLKlSvj7OzMkydP2LNnDw8ePKB9+/ZMnDgxvuzp06d5++23MTc3p02bNgQHB7N+/XocHR1Zs2ZNooF5b7pVq1bx2WefMWjQoCSzr/z666/MmDGDatWq4eLigqqqHDlyhPPnz+Pq6sry5cuxtLTMhppnv+3bt7N9+3YAfH19uXnzJo0bN8bKygog/r5Mzz0ZFBREhw4d8PPzw9vbG2tra9avX09wcDDLli2jUqVKWX2aWS4t1/XAgQO8++67WFhY0Lt370ST7VlZWdGnTx8Azp07R4cOHfD09KRkyZJYWlpy8eJF9u7di5WVFcuWLUsw+WFelZbrmt6/d7lf0/4cALh58yZNmzalUqVK/PHHH0nuT+5XmDFjBnPnzsXV1TXJD9fc3d1p3LgxIM/XtErrNZVna/qk9brmtWerBD6ZbO3ataxevZpr167x5MkT9Ho9pUuXpnPnznTu3DlRd4Hjx4/z448/curUKYyMjKhTpw5jxozByckpm84g5+revTu+vr789ddflChRItH6EydO8NNPP3H27FkePXpEdHQ0zs7ONG/enP79+7+xQQ/ArFmzmD17drLrL1y4EP99eu7J+/fv88MPP7Bnzx4iIyMpV64cI0aMiJ+4LK9Ly3Vds2YNn3zySbJlnJ2d2bFjB6ClYp0yZQpHjx4lICCAsLAwbG1t8fLyYvDgwbi4uGT4OeREabmur/L3Lvdr2p8D06dPZ968eXz99dd069YtyfJyv8LYsWPx8fFJdv3LH3jK8zV1ab2m8mxNn7Re17z2bJXARwghhBBCCJHnyRgfIYQQQgghRJ4ngY8QQgghhBAiz5PARwghhBBCCJHnSeAjhBBCCCGEyPMk8BFCCCGEEELkeRL4CCGEEEIIIfI8CXyEEEIIIYQQeZ4EPkKIBNzc3HBzc8v048yaNQs3NzdmzZqVYrmGDRvi5ubG7du307Tfp0+fxp/Di6+0bi/E6xg7dixubm6sWbPmlffRq1cv3NzcOHjwYLJlvvvuu0T3+NixY1/5mG+6nPbcE0JkDgl8hBB5ipGREe3bt49/mZubZ3eVcq2MeBOfmdIbFOclFSpUiL/HK1eunN3VSdGb/HsSQuQshuyugBAiZ9m8eXOWHKdHjx60bNmS/PnzZ+h+zczMmDhxYvzPhw4dIjQ0NEOPIURmmjRpEmFhYRQqVCjZMt7e3nh7ewOwZs0ajh49mlXVy5Ny+3NPCJE2EvgIIRIoWbJklhzH1tYWW1vbLDmWELlJSgGPyBzy3BPizSBd3YTII3r37o2bmxs7d+5Mcv3jx4/x8PDA09OTsLCw+OUhISFJjolJi+3bt9OnTx/q1q1L+fLlqVevHu+++y6LFy9GVdVE5SdNmpToOGnt6x4REcGkSZN46623KF++PC1atGDRokXExMSkafu0OnXqFCNGjMDLywsPDw+8vLwYO3Yst27dytDjAPj7+zN58mS8vb3x9PSkatWqdOzYkQULFhAYGJiofFhYGHPmzKF169ZUrFgRT09POnXqxO+//57kdVizZk382A8/Pz9GjhxJzZo1KV++PJ06deK///5LtE1ctyQ3Nzd8fHwA+OSTTxL8znr16pXk+YSHh/Pzzz/ToUMHPD09qVSpEh07dmTlypWJ7ocLFy5QsWJFatSowb179xLt66+//sLNzY3mzZsTEhICwO3btxPUw8/PD4BGjRq90j2VnPr161OmTBmePn2aatm2bdvi5uaW5P1x8OBBevXqReXKlalcuTKDBw9OtrtXhw4dEv1tpDTG53Wk5/f0Kl739/TifRseHs60adNo0qQJ5cuXp3bt2gwaNIgnT57Elz9x4gSTJk2iY8eO1K5dO/7v9oMPPki2JexVnnuv8vcEr/bce7F74J9//om3tzcVKlSgdu3ajB8/nvDw8CS3e/DgAZ988gm1atWiQoUKdOjQgR07dsjYIiGekRYfIfIIb29vDh48yKZNm2jQoEGi9du2bSMqKoqWLVtiZmYWvzxuTEycuDe7qZk9ezazZs3CyMiIKlWqYGdnx4MHDzh79iz79++nV69eGAwJHzHly5ePP9a5c+c4f/58ms/vk08+4cKFC9SqVQu9Xs/+/fuZNGkSFy5cYNKkSWneT0r+/PNPvv76a2JiYihbtiyVK1fm1q1b+Pj4sHPnTpYuXZphA6CPHz/OwIEDefz4MQ4ODnh5eWEwGLh06RJTp07FxMSEPn36xJcPDw+nV69enDp1ChsbG+rVq0dkZCT//fcfX3/9NQcPHmTGjBlJHsvf35/OnTtjbW1N9erVuXTpEqdOnaJ///6sXbs2wafdzZo149GjRwD4+vpy8+ZNKleuTNGiRePLlChRItExAgMD6du3L2fPnsXGxoaqVasC2pvScePGceLECb799tv48m5ubowbN45x48YxatQoli5dil6vB8DPz4/PP/8cU1NTZsyYgYWFBQDm5uYJ7tWtW7cSGhpKs2bNEozlcnd3T/PvISlVqlRh48aNnDx5Ei8vr2TLhYaGcunSJRwcHChSpEiCdfv27WPLli3xb9aPHTvGjh07uHr1Khs2bMDY2DhB+YYNG+Lq6grAnj17ePjw4WudQ3LS+3t6FRn1e4qNjaVv376cPHmSqlWr4uHhwc2bN/n3338JCgrC2toagGnTpnHgwAGKFSuGp6cnJiYm3L17l23btrFt2za+/fZbOnXqlGDfr/rcg/T9PcHrPfdmzZrFtm3b8PT0pGDBghw6dIhly5YRHByc6Ln38OFDunXrhp+fH87OztSqVYs7d+7w/vvvU6VKlTQfU4g8TRVC5AlPnjxRPTw81EqVKqlhYWGJ1vfq1Ut1dXVVd+/eneJ+XF1dVVdX1xTLREREqBUqVFDLlCmjnj9/PsG66Ohodfv27WpMTEyK+5g5c6bq6uqqzpw5M8VyDRo0UF1dXdVq1aqpV65ciV9+8+ZNtUaNGqqrq6v677//prr9rVu3UjzO8ePHVXd3d7VcuXLq9u3bE6xbtWqV6urqqrZv3z7FfaTV06dP1dq1a6uurq7qDz/8oEZFRSVYf/DgQfXvv/9OsGzq1KnxdXjy5En88ps3b6peXl6qq6urum7dugTbrF69Ov73OXHiRDU2NlZVVe13NGjQINXV1VX95ptvkq3nmDFjVFdXV3X16tWpntOAAQNUV1dXtV+/furjx4/jlwcEBKjt27dXXV1d1R07diTabtSoUaqrq6s6bdo0VVVVNSoqSu3atavq6uqqrlixIsVjpvV3m17Lli1TXV1d1dmzZ6dY7tChQ6qrq6v6wQcfxC+Lu2Zubm4JfoeBgYFq/fr1VVdXV3XLli0p7rdnz56qq6ur+t9//6WpvnG/5zFjxqRa9lV/T68jvb+nuPOpXLmy6u3trd65cyfB+gsXLiT4G1i7dq1648aNRPs5fvy46uHhoVarVk0NDQ1N8Zhpee697t+Tqqb/uVenTp0Ez70TJ06obm5uqru7u/rw4cME28Tde0OGDFEjIiLily9evDi+3qkdV4i8Trq6CZFH5MuXj/r16xMaGsqOHTsSrHvw4AGHDx+mQIEC1K5d+7WPFRQURHh4OPny5UvUAqLX62nUqBE6XcY+Xnr16pWgpaFIkSK8++67AKxateq19z9//nxiYmIYMGAAjRo1SrCuY8eOVKlShTNnznDmzJnXPtaKFSt4+PAh7u7ujB49OlHLWPXq1Wn8//buPKiq6w7g+Bd8REREREEMYkUUIggKWIiWiAkSNFYZBLRmXDK4dMZlBqsCjphEa13qwlC3QalVk2oQ1I5LBBdAJAIiRUBRiltAaBEV3BBFoH8w78XneyrCcyO/z0xmfOeee++59+rL/b1zzu8MG6ZWFhcXBzRmWjMxMVGVW1tbM2PGDNVxtTEzMyMkJAQ9PT2g8RlNmDABaBza11IFBQWkpKRgYmLCqlWrVL/EK889f/58oLFH7VmLFy/GxsaG6Oho0tPTWbduHTk5OYwaNYqgoKAWt605lL+O5+XlqcquXLnCunXrSE9PV5Xl5uaq1X/a0KFD1Z5hp06dGD16NKCbe94cLXlOb8ODBw+IjIykW7duauV2dnZq/wb8/Pzo0aOHxv79+/fH3d2dO3fukJOTo7N2ve5/T08LDg5W+95zdnZmwIAB1NXVqX0X3b9/n0OHDqGnp8fChQvVehQnT55M9+7dddouId5XMtRNiFZk1KhRHDlyhEOHDvHFF1+oyn/88Ufq6+v54osvVMOJWqJz58507dqV8vJyVq5cyZdffqkx1EfXPv744+eWtfRlo66uTvVCO3z4cK11HBwcyM7OJj8/H0dHxxad79SpUwAEBgaqXp5epKSkhFu3bmFoaKgamvQ05XCs/Px8GhoaNI7p4OBA27Zt1cqUL5NVVVXNuQQ1aWlpAAwaNAhTU1ON7Q4ODgCcO3dOY1v79u2Jiopi7NixhISEcPfuXWxsbFi8eHGL29VcyhdrZWADsH//fjZt2sSgQYMYNGgQ8OLAx8XFRaNMl/e8OVrynN4GBweHJicdqKysJDk5maKiIu7evaua81ZcXAygdc5cS9r1Ov89PU3b36MPP/yQnJwctXMVFBTw+PFjevXqpREo6unp4e7uLunEhUACHyFalaFDh9KhQwdSU1O5d+8eHTp0AODQoUMAqvS3urBy5Urmzp3L1q1b2bp1K126dKFfv3588sknBAQEqM0j0gVzc/PnlrV0PkRlZaUq4cPL7pFy/ktLlJWVATQ5WLx16xbQeL3aetK6du0KNM4Dun//vuq5K3Xp0kVjH+Uvwk+ePGl6w59DOXk9MTHxhXOgnnfv7O3tmTNnDsuXLwca52wo5/W8Dfr6+gwYMIDU1FSKi4vp0aMHaWlpmJubk52dTXV1NUZGRuTm5tK+fXs++ugjjWO87nveHC19Tm/a0/PKXiQuLo5ly5a9MG19bW2trpr1Rp9tU89VUVEBgIWFhdbjPK9ciF8bCXyEaEU++OADfH19iY+P58iRIwQEBFBcXExeXh49e/bE2dlZZ+caNGgQR48e5dSpU2RmZnLmzBlOnDhBSkoK//znP4mLi8PY2Fhn53uRpvSaNIW+vj5+fn4vrNOnTx+dnOt1adCSlUtX9+dlHB0dVRP0X0VdXR3Hjh1TfU5ISGhxgoKWcnNzIzU1ldzcXDp06MD58+dZunQpixYtIjMzEwcHB8rLy/nd736ntRf1Td3z5mjuc3rTnu1V0eb8+fMsWrQIPT09Zs2axahRo7C0tMTQ0BCAuXPncvDgQZ1kq1N6k8/2Vc/1vOvU5fUL8T6TwEeIVmbUqFHEx8dz6NAhAgICXktvj1L79u3x8fHBx8cHgMuXLzN79mwuX75MbGwsU6ZM0dm5bty4Qc+ePdXKlL9yavtV9FV06tSJdu3a8fDhQyIiIl57wNatWzeuXLnS5BTZnTt3Bhqvt76+XqPXp7y8HGh8UXy2t+dNUK474+7uTnh4+CvvHxkZSVZWFr6+vhQWFhIdHY2bmxtDhgzRdVObTDl8LTc3F319fRQKBSNGjCAuLo6TJ0+qehBcXV3fWhuVmvpy3NLn9C5KSEigoaGBCRMmMHv2bI3tryMN/btI+R2o/C541o0bN95kc4R4Z0lyAyFaGXd3d7p27UpGRgY3b958rYHPs2xtbRk7dizwy9h6XdG2RoZynZMX9WQpV0h/0dj7Nm3a4OHhAcDx48db0MqmUSaYiI+Pb9Ivsd27d8fMzIyamhrOnDmjsV05d8PJyUmnv0YbGBgAqK37pI3yepKTk195XaWUlBRiYmLo0aMHy5YtY+3atSgUCkJDQ7Wu76Otfc9b06QlnJ2dMTAwIDc3l7S0NNzd3TEyMmLo0KGcPHmSs2fPAtrn97xpTfk7Di17Ti3xOp+T8pq1JTcoKSnhwoULOj/nu8jR0REDAwN+/vln1ZBGpfr6ek6fPv2WWibEu0UCHyFaGX19fUaOHEldXR1RUVEUFRXRv3//Jo+Xb4rS0lLi4uK4f/++WnlNTQ1HjhwBwMbGRmfnA/j++++5cuWK6vP169fZtm0b0Jh17XmUQ9MSEhJeePzp06ejr6/PsmXLOHHihMb28vJyNm3axKNHj5rRenVBQUGYmZlx4cIFVq9erTH/IC8vT20hWj09PdU1rlixQm1hzevXr7Nx40bVcXVJOUn6eYtAKjk5OeHp6cm1a9cICwvTeAGvq6sjLS2NxMREtfKysjLCwsJQKBSsWbMGY2NjHB0dmTdvHpWVlYSEhLxwzkRT29ccbdu2pV+/fly4cIGTJ0/i5eUFNM6jKy4uJiEhAYVCwYABA3R+7ldla2uLnp4eWVlZqvlg2jT3ObXU63xOyuQHBw4cUAvQ7927R0REBI8fP9b5Od9FxsbGjBgxgoaGBpYuXap23du2bdMIhoT4tZKhbkK0QqNHj2br1q2q9MbKNLrarFy5Uutk5meHwqxYsUL157t37xIREcHixYvp168fVlZWVFdXk5OTQ2VlJb1799Z4CT9z5oxa2mnlL7HHjh1T+5/ysGHDNFI5Q+OimWPGjFEtYPrTTz9RXV2Nv78/n3zyyXOvb+rUqRw4cIAtW7aQm5uLlZUV0JhR7ekMaW5ubnz99df8+c9/Zvr06dja2tKrVy/09fW5evUqRUVFNDQ0MGnSpCbNPXiRjh07sn79embMmEFMTAz79+/HxcUFhULB5cuXuXjxIgsWLFDbZ8aMGZw6dYrz58/j4+ODh4cHtbW1ZGRkUF1dzeeff/7S+UmvytfXl40bN3Lw4EEqKyuxs7NDoVBgbW3NuHHj1OquWrWK4OBgDhw4QHJyMg4ODlhYWFBZWcm5c+e4c+cOwcHB+Pr6Ao2TzUNCQqiqqiI0NFSt127y5Mmkp6eTkpLC6tWrnzssa+TIkaSnp7NkyRIyMzOxtLRET0+PwYMH6yRtu6urKzk5OVRUVDB06FAAPvroIywtLSktLcXJyUknSTzi4uLIzs5WfVYG+Js3b1ZbWHPatGlas5xZW1szcuRIDh48iJ+fH+7u7nzwwQd06tSJsLAwtbqv+px04XU+pzFjxrBjxw7y8vLw8fHB1dWVJ0+ekJWVRYcOHfj000/VfkRQas73XnO09HvvVcyfP5+srCySkpIYPnw4AwYMoKysjLy8PIYMGUJqauo7PfdMiDdBAh8hWqG+ffvSu3dvLl26hEKhUEtt/azExEStvwY+u5L50y8A1tbWhIeHk5mZyX/+8x8KCgpo164dVlZWTJs2jXHjxmlk5SouLta6OvrFixfVVjK3srLS+gLwl7/8hb1793LgwAFu376NtbU1Y8eOZdKkSc+/EUDv3r2Jjo4mKiqKs2fPqoZ8uLu7a6SGHj9+PP3792f79u1kZWWRkpKCkZERlpaW/OEPf8Db21tt5fmWcHNzY//+/Wzbto3U1FRSU1PR19fH2tqa2bNnawxNNDIy4vvvv2fr1q0cPnyYlJQU9PX1sbW1xd/fn/Hjx+v8pcbW1pYNGzawefNmcnNz+emnn4DGe/ds4GNmZkZsbCw//PADhw8f5sKFC+Tk5GBhYYGTkxNeXl5qL9OrVq0iNzcXT09PgoOD1Y6lp6fH8uXL8fPz4x//+AcDBw7U+nciMDCQBw8esGfPHo4eParqjWvbtq1OAh83Nzf+/ve/07NnT7WhVF5eXsTGxupsmFt2drbWfxvKIYxK/v7+z03vvGTJEkxMTDhy5Ag//vgjDQ0NWFlZaQQ+r/qcdOF1PicTExPi4+P529/+RlpaGsnJyZiZmTFixAhCQkL461//qnW/5nzvNUdLv/dehYWFBbGxsaxdu5YTJ05w7Ngx7OzsiI6OJiMjg9TU1LeaLVGId4Feg6T6EEIIIYRotWbOnMmxY8eIjo5W9V4K8Wskc3yEEEIIId5z9fX15OXlaSRMycrKIjk5GVNTU1USFyF+rWSomxBCCCHEe662tpagoCDMzc2xs7PD1NSUsrIyzp49i76+Pt9++63OF5YW4n0jQ92EEEIIId5zdXV1REZGkpmZSXFxMffv38fExAQXFxemTJnyTqReF+Jtk8BHCCGEEEII0erJHB8hhBBCCCFEqyeBjxBCCCGEEKLVk+QGQgghxFsyceJE1dpS2ixdulRjMWCAhoYGdu3axe7du7l69SqGhoa4uroyc+ZM+vXr9zqbLIQQ7y0JfIQQQrw14eHh7Nu3j+XLlzNmzJi33RwNn332GaWlpRw/fpzu3bu/tvN4enpibm6uUd6zZ0+t9RcuXMiePXswNjbGy8uL27dvk5SUxMmTJ9myZQuDBg16bW0VQoj3lQQ+QgghxFs2ffr0Jq+xkpSUxJ49e7C0tGT37t107doVgPj4eBYuXEhYWBhHjx6lbdu2r7PJQgjx3pE5PkIIIcR7ZMeOHQDMnDlTFfQABAYG4uzsTHl5OQkJCW+reUII8c6SwEcIIVq5iooKVq1axahRo3BxcWHgwIEEBAQQHR3N7du31eo+fPiQDRs28Pvf/57+/fvj4uJCYGAgO3fupK6uTuPYe/fuxd7envDwcEpLS/nTn/7Exx9/jJOTE4GBgWRkZGjs89lnn2Fvb4+9vT379u0DYMGCBaoye3t7Jk6cqPVaampqiImJYcyYMbi4uDBgwAACAgKIi4vTWLG+sLCQ/v374+Hhwf/+9z+NYx0+fBh7e3uGDx/OgwcPALh+/bpaO0pLSwHw9vZWK1+3bl0T7rzuVVdXc+bMGVWbnuXj4wNAamrqG22XEEK8D2SomxBCtGJnz57lj3/8I1VVVVhYWODp6YlCoaCoqIi1a9fStm1bvvrqK6AxqJg4cSL5+fmYmpri5eXF48ePycjIYPHixWRmZhIVFaX1PBUVFQQFBdGxY0fc3d0pKioiPz+fadOm8a9//QtbW1tVXV9fXyorKwHIzs6muLgYV1dXfvOb36jq9OrVS+Mct2/fZsqUKRQUFGBqasrAgQMByM3NJSIigtzcXJYuXaqqb29vT0REBBEREcydO5cdO3bQpk0bAEpLS1m0aBGGhoZERUXRvn17AIyMjPD391cdIzExkerqanx9fTEyMlKV9+3b95Wew8scP36co0ePUltbi5WVFUOHDsXOzk6j3tWrV6mtrcXc3JzOnTtrbLe3twegqKhIp+0TQojWQAIfIYRope7du8fMmTOpqqpi6tSpzJkzB4Xil6/906dPc/fuXdXnTZs2kZ+fj6OjI9u2bcPExASAkpISvvzySxISEti/fz+jR4/WOFdaWhrBwcGEhoaip6dHXV0ds2bNIikpiZ07d7Jo0SJV3bCwMNWfw8PDKS4uJigo6KXJDRYsWEBBQQFDhgxh9erVdOzYEWgMiKZOnUpcXBze3t58+umnqn2CgoLIzMzkwIEDrFu3jpCQEJ48ecLcuXO5d+8eS5cuVQULAGZmZqxYsULtHlVXVxMaGvrc5AaZmZlMmjTphW1/mrZECdu3b1f7vGbNGgIDA/nmm2/44IMPVOXKnisLCwsALl26xNdff02fPn345ptvVEPftPVwCSHEr50EPkII0Urt3r2bmzdv0rdvX+bNm4eenp7adnd3d7XPcXFxQGMwogx6AKytrZkxYwbffvstu3fv1hr4mJmZERISojpHmzZtmDBhAklJSeTn57f4WgoKCkhJScHExIRVq1apgh7luefPn89XX31FbGysWuADsHjxYs6dO0d0dDQeHh5kZGSQk5PDqFGjtKaKflVdunRR6yV6mad7jtzd3Rk/fjzOzs6Ym5vz3//+l+PHj7N+/Xri4+MxNDRUCxqrq6sBMDQ0BGDXrl1kZ2eTnZ3N2LFjMTY2VqsnhBDiFxL4CCFEK3Xq1CmgcdL7s0HPs0pKSrh16xaGhoaqIWRP8/T0BCA/P5+GhgaN4zk4OGhkEevWrRsAVVVVzb0ElbS0NAAGDRqEqampxnYHBwcAzp07p7Gtffv2REVFMXbsWEJCQrh79y42NjYsXry4xe0CsLW1VeslehWzZ89W+9yzZ0+mTJmCs7MzEyZMYNeuXUyZMoUPP/xQ6/7Dhg3j4MGD2NraYmtrS3l5ebPaIYQQvwYS+AghRCtVVlYGNPbYvMytW7cAMDc3R19fM++NcghVTU0N9+/fp0OHDmrbu3TporGPcojWkydPXq3hWiiTDCQmJqoNTXuWcu7Qs+zt7ZkzZw7Lly8HIDIyUjWv513029/+FmdnZ/Ly8sjIyFANA1T2FtXU1ACNgWBmZqZqv4cPH6rVE0II8QsJfIQQQrySZ7OnAS/tUdIVR0dHrZP+X6auro5jx46pPickJOgsQcHly5fZsmVLk+uHhoZiZmb20nrW1tbk5eVRUVGhKrO0tATgxo0bWvdR9vgo6wkhhPiFBD5CCNFKdevWjStXrlBSUvLSusoMYRUVFdTX12v0+ihfqNu2bavR2/MmKId6ubu7Ex4e/sr7R0ZGkpWVha+vL4WFhURHR+Pm5saQIUNa3LabN2+q0nI3xaxZs5oU+Cjvebt27VRlNjY2GBgYUFFRwa1btzQyuxUWFgLQp0+fJrdHCCF+LWQdHyGEaKUGDx4MQHx8vNZemqd1794dMzMzampqVOvEPE05x8bJyUmnvTsGBgbAL0O0nkd5LcnJyVrXE3qRlJQUYmJi6NGjB8uWLWPt2rUoFApCQ0Nfmv1M2T7l0DJtPDw8KCwsbPJ/z8sO97SbN29SUFAANN5zJSMjI9zc3ABISkrS2E/Zq6WLgE4IIVobCXyEEKKVCgoKwszMjAsXLrB69Wpqa2vVtufl5ZGcnAw0DlULCAgAYMWKFWpprq9fv87GjRtVx9QlZQKEf//73y+s5+TkhKenJ9euXSMsLEwjYUJdXR1paWkkJiaqlZeVlREWFoZCoWDNmjUYGxvj6OjIvHnzqKysVKW3bmn7miM9PZ1Tp05RX1+vVl5RUcH8+fOprq7G2dkZFxcXte3K1Nnr169XS2YQHx9Pbm4u5ubmDB8+XOftFUKI950MdRNCiFaqY8eOrF+/nhkzZhATE8P+/ftxcXFBoVBw+fJlLl68yIIFC1T1Z8yYwalTpzh//jw+Pj54eHhQW1tLRkYG1dXVfP755/j5+em0jb6+vmzcuJGDBw9SWVmJnZ0dCoUCa2trxo0bp1Z31apVBAcHc+DAAZKTk3FwcMDCwoLKykrOnTvHnTt3CA4OxtfXF4Da2lpCQkKoqqoiNDQUZ2dn1bEmT55Meno6KSkprF69+rnD50aOHEl6ejpLliwhMzMTS0tL9PT0GDx4sKoXqrkKCwtZvnw5ZmZmODo60rFjR8rLyzl//jzV1dVYW1sTGRmpsZ+3tzf+/v7s27ePkSNHMnjwYCorKzl9+jQGBgasXLlSI8OeEEII0Gt42fgHIYQQ77Xy8nK2bdtGamoqpaWl6OvrY21tjY+PD+PHj1ebJ1JdXc3WrVs5fPgwJSUl6OvrY2tri7+/P+PHj6dNmzZqx967dy8LFizA399fI6Xz9evX8fb2xsrKSuuwLKUTJ06wefNmLl68yP3794HGuTzfffedRt1Hjx7xww8/cPjwYS5dukRNTQ0WFhbY2Njg5eWFr6+vKgPdsmXL2L59O56ensTExGgM0bt9+zZ+fn7cuHGDDRs2MGzYMI3zNTQ0sH37dvbs2cPPP//Mo0ePgMZ5Os+mon5VBQUFfPfdd+Tn53Pr1i3u3buHgYEBNjY2eHt7M3nyZNW6PNratXPnTmJjY7l27RqGhoa4uroyc+ZMtaFxQgghfiGBjxBCCCGEEKLVkzk+QgghhBBCiFZPAh8hhBBCCCFEqyeBjxBCCCGEEKLVk8BHCCGEEEII0epJ4COEEEIIIYRo9STwEUIIIYQQQrR6EvgIIYQQQgghWj0JfIQQQgghhBCtngQ+QgghhBBCiFZPAh8hhBBCCCFEq/d/1ApMPLZx1WgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='Reds', font_scale=1.7, font='monospace')\n",
    "\n",
    "fontsize = 22\n",
    "legsize=20\n",
    "\n",
    "fig, axs = plt.subplots(1, figsize=(12, 8))\n",
    "\n",
    "for i, tgt_len in enumerate([50]):\n",
    "    df_ = mt_base[mt_base.tgt_len == tgt_len]\n",
    "    xl_ = xl_base[xl_base.tgt_len == tgt_len]\n",
    "\n",
    "    df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "    bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "    xl_ = xl_.groupby(['effective context', 'mem_len', 'tgt_len']).mean()['test ppl'].reset_index()\n",
    "    axs.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 15, edgecolor='k', color=(0.78, 0.78, 1))\n",
    "\n",
    "    for bpd in bpds:\n",
    "        slice = df_[df_.mem_backprop_depth == bpd]\n",
    "        axs.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 15 + 15, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "\n",
    "    axs.set_xlabel(f'visible context while training\\ncontext={tgt_len}', size=fontsize)\n",
    "    axs.set_ylabel('ppl', size=fontsize)\n",
    "    lgnd = axs.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds], fontsize=legsize)\n",
    "    for j in range(len(bpds) + 1):\n",
    "        lgnd.legendHandles[j]._sizes = [80]\n",
    "\n",
    "\n",
    "    for m in np.unique(df_.num_mem_tokens):\n",
    "        slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "        axs.plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "    # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "        # axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.1, 0.2, 0.6))\n",
    "        axs.annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, color=(0.6, 0.2, 0.2))\n",
    "\n",
    "    slice = xl_[xl_.tgt_len == tgt_len]\n",
    "    axs.plot(slice['effective context'], slice['test ppl'], c='c', zorder=0)\n",
    "    for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "        # axs[i].annotate(v, (x, y), size=22, c=(0.2, 0.1, 0.1))\n",
    "        axs.annotate(v, (x, y), size=22, c=(0.1, 0.1, 0.2))\n",
    "\n",
    "    axs.grid()\n",
    "    # plt.yticks(fontsize=20)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/effective_context_50.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 394,
   "metadata": {},
   "outputs": [],
   "source": [
    "# xl_ = enwik8[(enwik8.tgt_len == tgt_len) & (enwik8.mem_len > 0)]\n",
    "# xl_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 395,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='Reds', font_scale=1.7, font='monospace')\n",
    "\n",
    "# fontsize = 22\n",
    "# legsize=20\n",
    "\n",
    "# fig, axs = plt.subplots(1, figsize=(12, 8))\n",
    "\n",
    "# tgt_len = 128\n",
    "\n",
    "# enwik8['mem_size'] = enwik8.num_mem_tokens + enwik8.mem_len\n",
    "# df_ = enwik8[(enwik8.tgt_len == tgt_len) & (enwik8.num_mem_tokens > 0)]\n",
    "# xl_ = enwik8[(enwik8.tgt_len == tgt_len) & (enwik8.mem_len > 0)]\n",
    "\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'mem_size', 'tgt_len']).mean()['test bpc'].reset_index()\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_.groupby(['mem_size', 'tgt_len']).mean()['test bpc'].reset_index()\n",
    "# axs.scatter(xl_['mem_size'], xl_['test bpc'], s=120, edgecolor='k', c=(0.78, 0.78, 1))\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     # axs.scatter(slice['mem_size'], slice['test bpc'], s=slice.mem_size * 15 + 15, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "#     axs.scatter(slice['mem_size'], slice['test bpc'], s=120, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "\n",
    "# axs.set_xlabel('memory size', size=fontsize)\n",
    "# axs.set_ylabel('bpc', size=fontsize)\n",
    "# lgnd = axs.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds], fontsize=legsize)\n",
    "# # for j in range(len(bpds) + 1):\n",
    "# #     lgnd.legendHandles[j]._sizes = [80]\n",
    "\n",
    "\n",
    "# # for m in np.unique(df_.num_mem_tokens):\n",
    "# #     slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "# #     axs.plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "# # # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "# #     # axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.1, 0.2, 0.6))\n",
    "# #     axs.annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.6, 0.2, 0.2))\n",
    "\n",
    "# # slice = xl_[xl_.tgt_len == tgt_len]\n",
    "# # axs.plot(slice['effective context'], slice['test ppl'], c='c', zorder=0)\n",
    "# # for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "# #     # axs[i].annotate(v, (x, y), size=22, c=(0.2, 0.1, 0.1))\n",
    "# #     axs.annotate(v, (x, y), size=22, c=(0.1, 0.1, 0.2))\n",
    "# axs.set_title('enwik8 context=128')\n",
    "# axs.grid()\n",
    "# # plt.savefig('../../Memory transformer/_figures_paper/effective_context_128.png', format='png')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 399,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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iDwXFfoiIk+RJ08uZsz4mAULPufmzdu0atWd996byO3bd6wdTURE5KlU6IuIPIeGDWuybdtyunZtx7x5y6lb93V++GGXtWOJiIg8kQp9EZHn5OiYDX//YQQEfIWDQxbefHMg/fv/j2vXblg7moiISDwq9EVEEsjDoxybNy9h8OBebNiwldq12/Ltt4F60JaIiKQqKvRFRF5Apkz2DBnSm82bl/DSS4UZMOA93nhjAGfPXrB2NBEREUCFvohIopQqVZw1a77C338oP/98kLp1X2fOnKVER0dbO5qIiGRwKvRFRBLJxsaGbt3as23bCqpWrcSYMZNo2bIbv/12wtrRREQkA1OhLyKSRAoWdGHRoslMn+7P2bMXadr0DSZMmMG9e/etHU1ERDIgFfoiIknIMAxat25CcPBKWrduwpQp82jUqBN79/5q7WgiIpLBqNAXEUkGzs45+OKLD1i6dBoPHjykTZtejBgxjps3I60dTUREMggV+iIiyah27Sr88MNyfH07s2RJAHXrtmPz5mBrxxIRkQxAhb6ISDJzcMjC+++/zfr188mZMwfdu7+Dr+9wLl++au1oIiKSjiW40N+1axeVK1dm2rRpT2wze/ZsKleuzK5dejy8iMgj5cuXYdOmxQwf3petW3dQp047li1bowdtiYhIskhwob9y5UpiYmLo1q3bE9u8+eabmM1mli9fnqhwIiLpjZ2dLQMGdGfLlqWULv1/vPOOP6+/3odTp85aO5qIiKQzCS70Dx8+TIUKFciaNesT22TJkoUKFSoQGhqaqHAiIulViRJFWblyFhMmvMvhw2E0aNCBGTMWEhUVZe1oIiKSTiS40L98+TI5cuR4Zrvs2bNz5cqVF8kkIpIhmEwm3nijDcHBq6hTpypjx07Fy8uHw4ePWjuaiIikAwku9J2cnLh48eIz2128eBEnJ6cXCiUikpG4uORh7tyJzJnzCZcvX8XLywd//y+4e/eetaOJiEgaluBC383NjQMHDvDHH388sc2JEyf49ddfefXVVxMVTkQkI2nWrB7Bwavo0KElM2cupn799uzYsc/asUREJI1KcKHfrl07oqKi6NWrF0FBQfH2b926ld69exMTE0Pbtm2TJKSISEaRPbsjn3wyihUrZmEYJjp06MvgwR9w48Zf1o4mIiJpjG1CX9CgQQNatmzJunXr6N+/Pzlz5qRQ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",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='Reds', font_scale=1.7, font='monospace')\n",
    "\n",
    "fontsize = 22\n",
    "legsize=20\n",
    "\n",
    "fig, axs = plt.subplots(1, figsize=(12, 8))\n",
    "\n",
    "tgt_len = 128\n",
    "\n",
    "enwik8['mem_size'] = enwik8.num_mem_tokens + enwik8.mem_len\n",
    "df_ = enwik8[(enwik8.tgt_len == tgt_len) & (enwik8.num_mem_tokens > 0) & (enwik8.mem_size != 30)]\n",
    "xl_ = enwik8[(enwik8.tgt_len == tgt_len) & (enwik8.mem_len > 0) & (enwik8.mem_size != 30)]\n",
    "xl_ = xl_[xl_.mem_size < 50]\n",
    "\n",
    "df_ = df_.groupby(['mem_backprop_depth', 'mem_size', 'tgt_len']).mean()['test bpc'].reset_index()\n",
    "bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "xl_ = xl_.groupby(['mem_size', 'tgt_len']).mean()['test bpc'].reset_index()\n",
    "axs.scatter(xl_['mem_size'], xl_['test bpc'], s=120, edgecolor='k', color=(0.78, 0.78, 1))\n",
    "axs.plot(xl_.mem_size, xl_['test bpc'], c=(0.1, 0.1, 0.2), zorder=-1)\n",
    "\n",
    "for bpd in bpds:\n",
    "    slice = df_[df_.mem_backprop_depth == bpd].sort_values('mem_size')\n",
    "    axs.plot(slice.mem_size, slice['test bpc'], zorder=-1)\n",
    "    # axs.scatter(slice['mem_size'], slice['test bpc'], s=slice.mem_size * 15 + 15, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "    axs.scatter(slice['mem_size'], slice['test bpc'], s=120, edgecolor='r', c=None if bpd > 0 else 'w')\n",
    "\n",
    "\n",
    "for bpd in bpds:\n",
    "    slice = df_[df_.mem_backprop_depth == bpd]\n",
    "\n",
    "\n",
    "axs.set_xlabel('memory size', size=fontsize)\n",
    "axs.set_ylabel('bpc', size=fontsize)\n",
    "lgnd = axs.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds], fontsize=legsize)\n",
    "# for j in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[j]._sizes = [80]\n",
    "\n",
    "\n",
    "# for m in np.unique(df_.num_mem_tokens):\n",
    "#     slice = df_[(df_.num_mem_tokens == m) & (df_.tgt_len == tgt_len)].sort_values('effective context')\n",
    "#     axs.plot(slice['effective context'], slice['test ppl'], c='r', zorder=0)\n",
    "# # for x, y in zip(slice['effective context'], slice['test ppl']):\n",
    "#     # axs[i].annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.1, 0.2, 0.6))\n",
    "#     axs.annotate(m, (slice['effective context'].values[-1], slice['test ppl'].values[-1]), size=22, c=(0.6, 0.2, 0.2))\n",
    "\n",
    "# slice = xl_[xl_.tgt_len == tgt_len]\n",
    "# axs.plot(slice['effective context'], slice['test ppl'], c='c', zorder=0)\n",
    "# for v, x, y in zip(slice.mem_len, slice['effective context'], slice['test ppl']):\n",
    "#     # axs[i].annotate(v, (x, y), size=22, c=(0.2, 0.1, 0.1))\n",
    "#     axs.annotate(v, (x, y), size=22, c=(0.1, 0.1, 0.2))\n",
    "# axs.set_title('enwik8 context=128')\n",
    "axs.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/mem_size_enwik_scatter.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 312,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base[mt_base.tgt_len == 150]\n",
    "# df_ = df_.groupby(['mem_backprop_depth', 'effective context', 'num_mem_tokens']).mean()['test ppl'].reset_index()\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# # plt.title('Wt-103: base. Marker size ~ memory size')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# xl_ = xl_base[xl_base.tgt_len == 150]\n",
    "# xl_ = xl_.groupby(['effective context', 'mem_len']).mean()['test ppl'].reset_index()\n",
    "# plt.scatter(xl_['effective context'], xl_['test ppl'], s=xl_['mem_len'] * 10, edgecolor='k', c='r')\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 10 + 15, edgecolor='grey', c=None if bpd > 0 else 'w')\n",
    "\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend(['Transformer-XL'] + [f'RMT BPTT-{int(b)}' for b in bpds])\n",
    "\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "solo trxl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# plt.title('Wt-103: base. Memory transformer. Marker size ~ memory size')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# # for bpd in bpds:\n",
    "# #     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "# #     plt.scatter(slice['effective context'], slice['test ppl'], s=slice.num_mem_tokens * 5 + 15, edgecolor='grey')\n",
    "\n",
    "# plt.scatter(xl_base['effective context'], xl_base['test ppl'], s=xl_base['mem_len']*5, edgecolor='k', c='r')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# # lgnd = plt.legend([f'bpd-{int(b)}' for b in bpds] + ['XL'])\n",
    "\n",
    "# # for i in range(len(bpds) + 1):\n",
    "# #     lgnd.legendHandles[i]._sizes = [60]\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "\n",
    "# df_ = mt_base\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# plt.title('Wt-103: base. Marker size ~ memory size')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd].sort_values('effective context')\n",
    "#     plt.plot(slice['effective context'], slice['test ppl'])#, s=slice.num_mem_tokens * 5 + 15, edgecolor='grey')\n",
    "\n",
    "# xlb = xl_base.sort_values('effective context')\n",
    "# plt.plot(xlb['effective context'], xlb['test ppl'], c='r')# s=xlb['mem_len'] * 5, edgecolor='k')\n",
    "\n",
    "# plt.xlabel('visible context while training')\n",
    "# plt.ylabel('ppl')\n",
    "# lgnd = plt.legend([f'bpd-{int(b)}' for b in bpds] + ['Transformer-XL'])\n",
    "\n",
    "# for i in range(len(bpds) + 1):\n",
    "#     lgnd.legendHandles[i]._sizes = [60]\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### bpd improvement with various mem size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_ = mt_base[(mt_base.mem_backprop_depth > 0)]\n",
    "# df_ = mt_base[mt_base.num_mem_tokens != 50]\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# plt.title('Wt-103: base. Memory transformer')\n",
    "\n",
    "# num_mems = np.unique(df_.num_mem_tokens)\n",
    "# for num_mem in num_mems:\n",
    "#     slice = df_[df_.num_mem_tokens == num_mem].sort_values('effective context')\n",
    "#     # plt.plot(slice['effective context'], slice['test ppl'])\n",
    "#     slice.groupby('effective context').mean()['test ppl'].plot()\n",
    "\n",
    "# plt.xlabel('effective context size')\n",
    "# plt.ylabel('ppl')\n",
    "# plt.legend([f'{m} mem' for m in num_mems])\n",
    "# plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fontdict = {'fontsize': 18, 'font':'monospace'}\n",
    "\n",
    "# df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "# df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "# mem_lens = np.unique(df.mem_size)\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "\n",
    "# # STD\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "# std_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# # Mean\n",
    "\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "# ax = plot_df.reset_index().iloc[:-2].plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.8, yerr=std_df)\n",
    "\n",
    "\n",
    "# # plt.title('WT103: base')\n",
    "# plt.legend(['Transformer-XL', 'RMT', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=15)\n",
    "# plt.xlabel('memory size', fontsize=18)\n",
    "# plt.ylabel('test ppl', fontsize=18)\n",
    "# plt.xticks(rotation=0)\n",
    "# plt.ylim(21, 40)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import seaborn as sns\n",
    "\n",
    "# sns.set_theme(style='white', palette='PuBu', font_scale=1.3, font='monospace')\n",
    "# fontsize=28\n",
    "# legsize=22\n",
    "\n",
    "# df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "# df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "# mem_lens = np.unique(df.mem_size)\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "# fontdict = {'fontsize': 18, 'font':'courier'}\n",
    "# width = 0.8\n",
    "\n",
    "\n",
    "# # STD\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "# std_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# # Mean\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "# plot_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# width = 0.2\n",
    "# x = np.arange(plot_df.shape[0])\n",
    "\n",
    "# col_pos = np.arange(len(plot_df.columns[1:]))\n",
    "# biases = (col_pos - np.mean(col_pos)) * width\n",
    "\n",
    "\n",
    "# fig, ax = plt.subplots(figsize=(12, 8))\n",
    "# rects = []\n",
    "# for i, col in enumerate(plot_df.columns[1:]):\n",
    "#     if i == 0:\n",
    "#         color=(0.84, 0.3, 0.3)\n",
    "#     else:\n",
    "#         color = None\n",
    "#     rect = ax.bar(x + biases[i], plot_df[col], width, edgecolor='k', color=color, yerr=std_df[col], capsize=4)\n",
    "#     rects.append(rect)\n",
    "\n",
    "# plt.legend(['Transformer-XL', 'RMT', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=legsize, loc='upper right')\n",
    "\n",
    "# plt.xlabel('memory size', fontsize=fontsize)\n",
    "# plt.ylabel('test ppl', fontsize=fontsize)\n",
    "# plt.xticks(rotation=0)\n",
    "# plt.ylim(21, 40)\n",
    "# plt.savefig('../../Memory transformer/_figures_paper/mem_size.png', format='png')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 401,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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eumBBx6wUqSlR1JgxyrrP5G6derosoWmx7rR7c2aKf3YMYvXCwC2LjU1Wdu2Ga0dRqkFBVlucGRoaKhCQ0MLbfvqq6/0yy+/6I477tCMGTMs1pYt2bdvn44fP64ePXpoyZIl1g6nRmrXrp3GjBmjRYsWafr06Xr//fdN+5KTk/XBBx+odu3aevnll60YZemRFNixyvpPJCjIoPzDuyxer0PbAIvXCQBATXTixAlJUosWLawcSc02YcIErVmzRps2bdKPP/6oe+65R5L0yiuvKDs7W88995x8fHysHGXpMKYAAADYreDgYPn6+iotLU07d+7UX//6V/Xs2VPdunXT/fffr5iYGFPZrKwsLV26VOPHj9e9996rrl27qkePHho+fLjmz59f5MqyaWlp8vX1VXBwsK5cuaLXX39d99xzjzp16qQBAwbos88+Kza2zMxMvfbaaxo0aJC6d++ugIAA3X///Zo6daqSkpLMyk+ePNk0duI///mPJCk2NrZUYypWrlyphx9+WP7+/urcubPuu+8+vfHGG7pw4UKx8X311VemvvFXr17VW2+9pXvvvVedO3fWXXfdpb/97W86f/686XUODg7Wxx9/rF69eqlXr1765JNPdPToUY0ePVqdO3fWqFGjlJqaWmRb3333ncaOHauePXua4nvrrbdKXM234PX46quvlJaWpv/85z/q06ePOnfurODgYE2bNq3YY0urTp06evHFFyVJ06dPV3Z2ttavX6+ffvpJHTt21NixYyvcRlXhTgEAALB7P/30k6ZNm6bbb79dd911l7KysnTw4EHt3LlTI0eOlCT9+uuv+u9//6u6devKz89PXbp00aVLl3TgwAHNnj1ba9as0eeff6569eqZ1Z+fn69//OMfSk5OVpcuXdS0aVP98ssvevnll1WnTh1TGwUyMzM1fPhwZWZmytvbW3369FF+fr5SUlK0bNkyubu7q0OHDoWO8ff3N/1dMK7Cx8en0PaixhRER0fr888/V61atdSrVy+5ublp165dWrhwodavX68lS5aoYcOGxb52+fn5+utf/6p9+/YpICBAnTp1UkpKijZt2qSLFy+qQYMGkqSMjAx9+OGH6tGjh3766Se9+uqr+uSTT9S4cWP5+flp9+7deu211zRv3jxT3UajUZMnT9bKlStVq1YtdevWTQ0bNtSBAwe0YMEC/fTT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p09X586dtXTpUm3cuFG1a9fWPffco/Hjx6tz587WDq/GMBiNRqO1g7BnaWlpCgkJ0YYNG6p8KlODwaBt2yx/+oOCDMo/bPnl4R3aBoi3q+1gISzbwzmrvpKSktShQwez7bawsBL+h/Nle2zhnBX3/XCzW11zVu95twAAAABUOpICAAAAwM6RFAAAAAB2jqQAAAAAsHMkBQAAAICdIykAAAAA7BxJAQAAAGDnSAoAAAAAO0dSAAAAANg5kgIAAADAzpEUAAAAAHaOpAAAAACwcyQFAAAAgJ1zsnYAAAAA5TV37lzNmzev0DYXFxc1bdpUgYGBGjt2rO64445C+4ODg5Weni5JiomJUadOnQrtj46O1ueffy5JmjBhgiIiIuTr61umuD755BMFBgaW9elIknbs2KHHH3+80DaDwaD69evL19dXI0aM0LBhw2QwGAqVmTx5smJjYwttc3Z2loeHhwICAjRmzBh17NjRtK88z2nevHmKj48v9TEFr195ZWdna/369dqzZ4/27t2rgwcPKjs7W8OHD9eMGTPKXS/MkRQAAGDjWvo0V3JqmrXDKLUWzb11NCXVonX6+PjI399fknT69Gnt379fy5Yt09dff613331Xffr0KfK4NWvWFEoK8vLy9P3335uVGz58uNm277//XpcvX1afPn3k4eFRaF/jxo0r8nQkSXXr1tV9990nScrJydGJEye0a9cuxcfHa8uWLZo1a1aRx/n5+aldu3aSpHPnzmn//v36+uuvtXr1as2cOVODBg0q93Pq27evvLy8Cm1PSEhQSkqK2rdvrw4dOhTad/Pjsjp58qT++c9/mh7fnAjBckgKAACwccmpacqNnWvtMErNaXj5fzkujr+/f6FfjrOysjRx4kRt3rxZkydPVlxcnJydnQsd07VrV61Zs0b//ve/Tdt27NihU6dOqWvXrtq7d69pe1G/SsfHx+vy5csKDw8v912BkjRs2NCs3X379unhhx/Wt99+q2HDhqlv375mxw0cOFDh4eGmx1euXNGUKVO0evVq/fe//1Xv3r3l7u5erufUunVrs22TJ09WSkqKQkNDK3RXoCguLi4aPny4unbtqu7du+vHH3/U7NmzLdoGrmNMAQAAqHHc3NwUGRkpScrMzNSePXvMyoSFhSk9Pb3Qxf/q1avl7u6uoKCgKoq0bLp06aKePXtKkrZu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aSlubm6699579c033+ibb77Rv/71L+Xl5ZmmAA0LCyt28K+ltWjRQs8884yk6wO0ExMTtWTJEn311Ve6dOmSXnzxRX3//fdFThNrSfHx8XrzzTclSffdd5/++te/3vKYG99ft912m2mgOQDQfQgAqpH27dub/t6zZ4/V4rhxleIbu+vc7MZ9pVnZuCIKuhCdOHFCO3bs0ObNm00Dfitz1qGSODg4qEuXLpo+fbrpojwlJUXp6emV2m5GRob++c9/Kjc3Vy1bttSrr75aquOqy/sLQPVDUgAA1UjHjh1NfcJjYmIKDf6tSp07dzZ1Gylpca0b95V28bLy6tWrl26//XZJ12ccKph1qHXr1urSpUultl0aNz7/M2fOVFo7OTk5mjhxok6dOqU6depo7ty5peoGJEmBgYGm7ltffvmljEZjpcUJwLaQFABANeLo6KgxY8ZIktLS0jR16tRCA4BvVDBF548//mjxOOrVq2fqo799+/YiE4P9+/eb+vR37ty50LoIlcHBwUFDhw6VJH3//fem512wjkFlW7VqVYlJWkHffgcHBzVv3rzS4pg5c6Z++eUXSVJ0dHSZupg1bNhQI0eOlHR9atW333672LLZ2dn64osvtHfv3ooFDMAmMKYAAKqZMWPGKC4uTgkJCfrqq6+UlJSkv/zlL2rfvr0cHR114sQJ7dq1S999951Onjypl156qVLi+Ne//qVNmzbp6tWrmjhxop588kndfffdcnR0VHx8vBYsWKCcnBwZDAZNnjy5UmK42YgRIzR//nxdunRJ0vUL8IIF1CpbdHS0pk2bpnvvvVcBAQFq0aKFnJycdOzYMa1cuVJxcXGSrvfvb9SokdnxGRkZZuMzLly4IOn6r/+//fZboX21atUyLXxXYNu2baYFyu6++261b9/e7LgbtWrVymyg8KRJk7R161YdPXpU7777rnbt2qWRI0eaBrWnpaVp+/bt+v7773Xu3DktWLCgNC8PABtHUgAA1YyTk5Pef/99/fvf/1ZcXJySkpI0derUYsuXtutIWbVs2VLz5s3T3//+d12+fFkLFiwwu0B0cnJSdHS0AgICKiWGm/n4+CggIEC7du2SdL07TNOmTaukbUk6d+6cli9fruXLlxe5v3v37oqKiipy31tvvaXY2Ngi9508edJs4TUvLy9TolHg+PHjpr83bdqkTZs2lRjvhg0b5O3tXWibm5ubPvvsM0VERGj37t2Kj49XfHx8kcc7ODiobt26JbYBoGYgKQCAasjNzU3z58/Xtm3btHLlSv3yyy/KzMxUbm6uGjVqpLZt2yowMFADBgyo1AG+ffv21dq1a/Xhhx/qp59+0vHjx5WXl6cmTZooKChITzzxRKV3G7rZ/fffb0oKCroTVYVly5bpxx9/1M6dO5WcnKzMzExdvXpV7u7uat++vQYNGqQhQ4YUWvuhuvLw8NCSJUu0bt06rV69Wvv27dOZM2eUn58vDw8PtWvXTkFBQRo4cKBVF2YDUHUMRkYZAQBsSFRUlL744gvVqVNHW7ZsqbQ7JQBgTxhoDACwGVeuXNG3334rSRowYAAJAQBYCEkBAMBmfPbZZ6bBuaNGjbJyNABQczCmAABQbeXm5io9PV3Xrl3T1q1bNXfuXEmSn5+f7rzzTitHBwA1B0kBAKDaOnHihAYMGFBoW926dUu9gi8AoHToPgQAsAn169dXcHCwli5dqvbt21s7HACoUZh9CAAAALBz3CkAAAAA7BxJAQAAAGDnSAoAAAAAO0dSAAAAANg5kgIAAADAzpEUAAAAAHbu/wdQ+/ggRIFiIgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='Reds', font_scale=1.3, font='monospace')\n",
    "fontsize=28\n",
    "legsize=22\n",
    "\n",
    "df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "mem_lens = np.unique(df.mem_size)\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "fontdict = {'fontsize': 18, 'font':'courier'}\n",
    "width = 0.8\n",
    "\n",
    "\n",
    "# STD\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "std_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# Mean\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "plot_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "width = 0.2\n",
    "x = np.arange(plot_df.shape[0])\n",
    "\n",
    "col_pos = np.arange(len(plot_df.columns[1:]))\n",
    "biases = (col_pos - np.mean(col_pos)) * width\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(12, 8))\n",
    "rects = []\n",
    "for i, col in enumerate(plot_df.columns[1:]):\n",
    "    if i == 0:\n",
    "        color=(0.78, 0.78, 1)\n",
    "        # color = 'lightblue'\n",
    "    else:\n",
    "        color = None\n",
    "    rect = ax.bar(x + biases[i], plot_df[col], width, edgecolor='k', color=color, yerr=std_df[col], capsize=4)\n",
    "    rects.append(rect)\n",
    "\n",
    "plt.legend(['Transformer-XL', 'RMT BPTT-0', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=legsize, loc='upper right')\n",
    "\n",
    "plt.xlabel('memory size', fontsize=fontsize)\n",
    "plt.ylabel('test ppl', fontsize=fontsize)\n",
    "plt.xticks(ticks = np.arange(len(plot_df.index)), rotation=0, labels=plot_df['index'], fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.ylim(21, 40)\n",
    "plt.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/mem_size.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 405,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ -1,   0,   4,   9,  24,  49,  99, 199])"
      ]
     },
     "execution_count": 405,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[1] * (mem_lens-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 410,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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X19f+Pj4wNPTs9bzmjRpEp48eYJffvkFv//+OyoqKgAAc+fOlUkKjhw5goyMDLnjn13ErKFJgTrOibSPSFA0tJ6aTHp6uvTbCnt7+yZtWyQSYV+8ehcWGeUxCufOqfdXystLhMrb8Wqt06Cbh8JZJajxJSQkwN3dXdNhUB14jbRPcnIyXFxcAFR1zTAzM5PZ79jREWmpdQ+O1SYOjg5ITUl9fkEdpegakXZpTteo5t+HujzvnpNPCoiIiHRcc77BJqKmwYHGRERERER6jkkBEREREZGeY1JARERERKTnmBQQEREREek5JgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnmNSQERERESk55gUEBERERHpOSYFRERERER6zkjTASgjNzcX3377La5fv46MjAwUFBTA1tYWrq6uCAwMhJubm7TsggULEBUVVWd977//PubMmVPveJydnWvdt3btWowYMaLedRMREZHy1q1bh7CwMKXL9+/fHz/99FMjRqQ9/vzzT6xduxZXrlxBTk4OKisr9er8G5MgCJgyZQoSEhLw9ttv4z//+Y9cmSdPnsDf3x/37t3DsmXL8I9//APA/35nx44dixUrVjR16LXSiaQgKysLkZGR6Nu3L3x9fWFpaYns7GwcPXoUR48exYoVKxAQEAAA8PPzg1gsVljPrl278ODBAwwaNKjBMYnFYowdO1Zue9euXRtcNxERkSocHTshLS1F02EozcGhI1JT76qlLhcXF7n/j1NSUnDp0iVYW1vL/Z//4osvqqVdbVdcXIx33nkHmZmZ6NWrFwYMGABDQ0O9Of/GJhKJEBwcjLFjx2L79u2YMGECOnfuLFNm/fr1uHfvHgYMGCBNCLSZTiQFXbp0wcWLF9GyZUuZ7bNnz8bo0aPxxRdfYOTIkWjRogX8/Pzg5+cnV0dWVhbCw8Ph7OyMXr16NTgmsViMoKCgBtdDRETUUGlpKTh3TtB0GErz8hKprS5F/+/v2bMHly5dwosvvqhV38Q2pWvXriEzMxP9+vXDjh07NB1Os+Tk5ITp06dj06ZNWL58OTZs2CDdl5KSgi1btqBly5ZYunSpBqNUnk6MKTA2NpZLCADA0dERnTt3xqNHj/DgwYM664iIiEBFRQUmTJjQWGESERERaYX79+8DADp27Kjh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71NrnaM8RuHcOfX+Snl5iVB5u/bp3+rDoJuH3OwG1DQ4B7724zXSPsnJyXBxcQGgeH51R8dOSEtL0URo9eLg0BGpqXc1HUajaS5rSTRnzeka1fz7UJfn3XPySQEREZGOa8432ETUNHRioDERERERETUeJgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnmNSQERERESk55gUEBERERHpOSYFRERERER6jkkBEREREZGeY1JARERERKTnmBQQEREREek5I00HQERERFRf69atQ1hYmMw2ExMT2NnZwdPTEzNmzMCLL74os9/HxwcZGRkAgMjISLi5ucnsDw0Nxc8//wwAmDt3LoKCguDs7KxSXNu3b4enp6eqpwMAuHDhAqZNmyazTSQSwcLCAs7Ozhg3bhwCAgIgEolkyixYsABRUVEy24yNjWFjYwMPDw9Mnz4dPXr0kO6rzzmFhYUhLi5O6WOq37+GEAQBO3bswK5du/D333+jZcuW6NevH+bMmSN37aj+mBQQERHpuE4dOyIlNVXTYSito6Mj7qakqLVOR0dHuLu7AwAePnyIxMRE7Nq1C7/99hu+//57eHt7Kzzu0KFDMjeWFRUVOHLkiFy5sWPHym07cuQIiouL4e3tDRsbG+n28vJyWFtbN/SUYGpqildffRUAUFZWhvv37yM+Ph5xcXGIjY3F6tWrFR7n6uoKJycnAEB+fj4SExPx22+/4cCBA1i1ahVGjhyp8jkBgLW1NQYNGgSxWCyzPSEhAampqejevTtcXFxk9j37uj4WLlyIyMhImJubY8iQIcjNzYVEIsHp06exceNGeHl5NbgNYlJARESk81JSU1F5O17TYSjNoJuH2ut0d3fHihUrpK8LCwsxb948nD59GgsWLIBEIoGxsbHMMb1798ahQ4fw73//W7rtwoULyMnJQe/evXH16lXp9pp1V4uLi0NxcTECAwNlngoUFRXBzMyswedkZWUl1+61a9fwxhtvYP/+/QgICMCgQYPkjhsxYgQCAwOlr588eYKFCxfiwIED+OyzzzBw4EBYWlqqdE7VunTpIrdtwYIFSE1NhZ+fX4OfCjxLIpEgMjISdnZ22LVrF9q3bw8A2L17NxYuXIiPP/4Yx44dg4mJiVrb1UccU0BERETNjrm5OYKDgwEA2dnZ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+ejevXu9gyQiIiIiosZTr+5De/fuxdixY3HixAmUl5dDEASF/yoqKhAbG4t//OMfiI6OVnPoRERERESkDio/Kbhx4wY+/fRTlJeXw8jICMOHD8fgwYPlVjS+c+cOTp06haNHj6K8vByLFi1Ct27d4OrqqvaTICIiIiKi+lM5Kdi0aRPKy8vRpk0b/Pjjj+jRo4fCcr169UJAQACuX7+OmTNn4vHjx9i0aVOdKxsTEREREVHTU7n7UFxcHEQiEYKCgmpNCGpydXXFnDlzIAgCLl68WK8giYiIiIio8aicFDx+/BgA0KdPH6WP6devHwCgoKBA1eaIiIiIiKiRqZwUdOjQAYBqN/jVZdu3b69qc0RERERE1MhUTgpGjBgBQRCwZ88epY+JjIwEALz66quqNkdERERERI1M5aTgvffeg4uLC/bv34/PP/9c2p1IkcePH2Pp0qXYv38/unfvjtmzZzcoWCIiIiIiUr96zT708ssv4+7du/j5558RERGBvn37yk1J+tdff+Hy5csoKyuDqakpBg4ciM2bN9da79y5c+t/FkREREREVG8qJwVhYWEQiUTS1yUlJbhw4QIuXLggV1YQBIhEIjx58gRbtmyps14mBUREREREmqFyUgBU3ezX9VrZfUTUPJgYG8t8WfA8ypTt6OiIuykpDQmLiIiIlKRyUnDz5s3GiIOIdFhJaSkqb8c/t9wrUwIBAL//vOG5ZQ26eTQ4LiIiIlKOygONiYiIiIioeWFSQERERESk55gUEBERERHpOSYFRERERER6jkkBEREREZGeY1JARERERKTnmBQQEREREek5JgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnjPSdABEREQEdOrYESmpqWqts6OjI+6mpKi1TiJqnpgUEBERaYGU1FRU3o5Xa50G3TzUWh8RNV/sPkREREREpOeYFBARERER6TkmBUREei44OBgikUj6z8PDQ+Z1cHCwpkMkIqJGxqSAiEjPBQcHQxAECIKAIUOGoF+/ftLXgiAwKSAi0gNMCoiIiIiI9ByTAiIiIiIiPafylKTTpk2DSCTCF198AbFYrNQxJSUlmDVrFkQiEbZt26ZykERE1DCqzoEvEomeW4Zz4BMRNR8qJwVxcXEQiUR48uSJ0sdUVFRIj6uP3Nxc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GE9PT9y6davOMsOHD8fw4cNVqpeIiIiISJvpzJgCIiIiIiJqHEwKiIiIiIj0nE50HyIiIu1j0sLouVND16RM2Y4O9ribmtaQsIiIqB6YFBARUb2UlJWjPGrdc8v5LFoLAJB8/q/nljUaW/v4Mc5oRETUeNh9iIiIdEJwcDAEQYAgCBgyZAiGDBkifS0IAhMCDQsODq5znnteHyLtxicFRERE1GCchpZIt/FJARERERGRnuOTAiIiUruQXw9i6c5DMttqjhdYPOn/sOR1f7njTAwN1D94WfwC7qZnKF0nEZE+YlJARERqt+R1f4U3/c9TUlGJ8pAZzy3n82NVwiGZ8X/PLWu05EeV4yAi0jfsPkREREREpOeYFBARERER6Tl2HyIiIp0Q8vtlLD1xRWZbza5Bi4f2wZJX+jZxVEREzQOTAiIi0glLXunLm341qe9AcEC1weDKluNgcCLNY1JARESkZ+o7EBxQbjC4KgPBAQ4G11eOjp2Qlpai6TDo/2NSQERERERNLi0tBefOCXLbN20KxubNIbUe9/bbS/DOO8EK93l5KT+lMcliUkBEREREWuOdd4JrvemnxsPZh4iIiIiI9ByTAiIiIiIiPcfuQ0REREQaYtLCSOlZmogaE5MCIiIiajCuI1E/JWXlKI9ap9Y6a04vS6QsJgVERETUYFxHgki3cUwBEREREZGeY1JARERERKTnmBQQEREREek5JgVERERERHqOSQERERERUS2qp41V579Ojg6aPi05nH2IiIiIiKgW+jJtLJ8UEBERERHpOSYFRERERER6jkkBEREREZGeY1JARERERKTnmBQQEREREek5JgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnmNSQERERESk55gUEBERERHpOSYFRERERER6jkkBEREREZGeY1JARERERKTnjDQdgDLy8/Nx4MABHD9+HHfv3kV2djYsLCzQr18/zJo1C71795Yp7+zsXGtda9euxYgRIxoc09mzZxEeHo7r168DAFxdXTFnzhwMGDCgwXUTERERETUlnUgKJBIJQkND0aFDBwwYMAA2NjZITU3F8ePHERMTg9WrV8Pf31/mGLFYjLFjx8rV1bVr1wbHc+zYMQQFBcHc3BxjxoyBIAjYt28fZsyYge+++w4+Pj4N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1SpERUXB2NgYoaGhKteZlJSErKysBsVFqklISNB0CNRM8HdJ+/EaaT9eI+3Ha6ReTf1+Zmdn17lfJ5MCQRCwePFiXLlyBe+99x58fX3VUlZZ8+fPl3k9bNgwdOvWDaNHj0ZERATmzp0LW1tblep0c3ODvb19g2Mj5bm7u2s6BGom+Luk/XiNtB+vkfbjNVKvpn4/09PT69yvEwONnxUSEoLo6GhMmjQJ8+bNU1vZhujUqRN69+6NyspKJCYmNlo7RERERETqpnNJwfLly7Fjxw6MGzcOISEhaiurDpaWlgCAp0+fNnpbRERERETqolNJwVdffYWtW7dizJgxWLZsWZ1jA1Qpqw6CIOCPP/4AAHYDIiIiIiKdojNJwZo1a7Bx40aMGjUKK1askE4v2tCyNSUkJMDT0xOenp61Dv5ITk5GaWmp3PbNmzfj7t276NixI9zc3JQ7KSIiIiIiLaATA4337NmD8PBwtG7dGvb29vjuu+/kyvj5+cHFxUWlss8qLy9Hfn6+9GdFtm3bBolEAnd3d9jb20MQBFy9ehXXrl2DmZkZVq5cCUNDw4adMBERERFRE9KJpCAjIwNA1YJh4eHhCsuIxWK4uLioVLY+fHx8kJOTgxs3buD8+fMoKyuDra0tJk6ciMDAQDg4ONSrXiIiIiIiTdGJpCAoKAhBQUFqL/ssT09P3Lp1q84yw4cPx/Dhw+tVPxERERGRNtKZMQVERERERNQ4mBQQEREREek5JgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnmNSQERERESk55gUEBERERHpOSYFRERERER6jkkBEREREZGeY1JARERERKTnmBQQEREREek5JgVERERERHqOSQERERERkZ5jUkBEREREpOeYFBARERER6TkmBUREREREeo5JARERERGRnmNSQERERESk55gUEBERERHpOSYFRERERER6jkkBEREREZGeM9J0APquoqICAHD//v0mb9vIyAi52blqrzM7O13tdaZnZau/znT1xqkrdOkaZeQ+Vn+dhU/VXqe6f5d4jXiN1Fknr5F66+Q1Um+d+nyNmvo+pPpes/re81kiQRCEpgyIZMXHx2PKlCmaDoOIiIiI9MDPP/8MDw8Pue1MCjTs6dOnSEpKgo2NDQwNDTUdDhERERE1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",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='Reds', font_scale=1.3, font='monospace')\n",
    "fontsize=28\n",
    "legsize=22\n",
    "\n",
    "df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "mem_lens = np.unique(df.mem_size)\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "fontdict = {'fontsize': 18, 'font':'courier'}\n",
    "width = 0.8\n",
    "\n",
    "\n",
    "# STD\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "plot_df['Baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0)]['test ppl'].std()]  + [None] * len(mem_lens[:-1])\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "std_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# Mean\n",
    "# plot_df['Baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0)]['test ppl'].std()] \n",
    "plot_df['Baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0)]['test ppl'].mean()]  + [None] * len(mem_lens[:-1])\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "plot_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "width = 0.2\n",
    "x = np.arange(plot_df.shape[0])\n",
    "\n",
    "col_pos = np.arange(len(plot_df.columns[1:]))\n",
    "biases = (col_pos - np.mean(col_pos)) * width\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(12, 8))\n",
    "rects = []\n",
    "for i, col in enumerate(plot_df.columns[1:]):\n",
    "    if i == 1:\n",
    "        color=(0.78, 0.78, 1)\n",
    "        # color = 'lightblue'\n",
    "    elif i == 0:\n",
    "        color=(0.7, 0.8, 0.7)\n",
    "    else:\n",
    "        color = None\n",
    "    rect = ax.bar(x + biases[i], plot_df[col], width, edgecolor='k', color=color, yerr=std_df[col], capsize=4)\n",
    "    rects.append(rect)\n",
    "\n",
    "plt.legend(['Baseline', 'Transformer-XL', 'RMT BPTT-0', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=legsize, loc='upper right')\n",
    "\n",
    "plt.xlabel('memory size', fontsize=fontsize)\n",
    "plt.ylabel('test ppl', fontsize=fontsize)\n",
    "plt.xticks(ticks = np.arange(len(plot_df.index)), rotation=0, labels=plot_df['index'], fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.ylim(21, 40)\n",
    "plt.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/mem_size.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-1.5, -0.5,  0.5,  1.5])"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "biases"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# plot_df.plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=width)\n",
    "# mean_df = plot_df\n",
    "\n",
    "# # STD\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "# plot_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# # plt.title('WT103: base')\n",
    "# plt.legend(['Transformer-XL', 'RMT', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=15)\n",
    "\n",
    "\n",
    "\n",
    "# plt.xlabel('memory size', fontsize=16)\n",
    "# plt.ylabel('test ppl', fontsize=16)\n",
    "# plt.xticks(rotation=0)\n",
    "# plt.ylim(21, 40)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAuoAAAHxCAYAAAA7npljAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABPxklEQVR4nO3deVxV1f7/8TeDiAgyOAtG3kxUBIdU1NBUvFnpDcVv5c0oE70OV60QBQxTM7NETdTKLB45RKKZWplejczqe50aHUocS3FISRQRFQLO74++np8nUQ4C52zk9Xw8fDzYa6+99mdLh95s117bwWQymQQAAADAUBztXQAAAACA6xHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEB2Depvv/22AgIC9MYbb5jbzpw5o1GjRqlNmzbq3LmzZs6cqcLCwlKNW1BQoBkzZigkJERt27bVmDFjlJWVVd7lAwAAABXGbkH9559/1scff6y6detatD/77LP67bfflJKSopdfflkrV67UW2+9Vaqx58+fr9WrV2vmzJlaunSpjh07pujo6PIsHwAAAKhQdgnqV65c0YQJEzR16lS5uLiY29PT0/Xdd99p0qRJCgwMVI8ePTR48GC9//77svYFqkVFRUpNTdXQoUN13333KSgoSAkJCdq2bZsOHz5cUZcEAAAAlCtne5z01Vdf1b333qt27dpZtO/Zs0fVq1dX69atzW0hISGaP3++Tp48KV9f3xLHzsjI0Pnz59WhQwdzW7t27eTs7Kzdu3frrrvuKnGMK1euaO/evapbt66cnJxKcWUAAACA9QoLC5WZmalWrVrJ1dXVYp/Ng/qWLVu0detWffTRR9ftO3v2rDw9PZWXl6c+ffrogQce0IABA8z7rAnqZ8+elST5+Pho7NixOnXqlD744AN5enqa95Vk7969GjRoUCmuCgAAALh1KSkpat++vUWbTYN6VlaWEhISNHfu3Ot+Y7iWk5OTGjZsqNq1a5fpfPXq1bul467Om09JSVGDBg3KVEN5uTrHfs6cOZViXAAAAJTst99+06BBg657blOycVA/ePCgMjMz9fTTT5vb8vPz9frrr+vTTz/V4MGDlZ2dLWdnZ6WkpEiSvvnmG0myOrRf7Xf1lwLpz39SyM7OtnqMq9NdGjRoID8/P+suroJVr15d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pUu68847lZKSInd39+v6rVixQn379rW4y26Nhx9+WH5+fvLx8dGePXuUmJioM2fOaMaMGeV1CQAAAECFsssd9datW2vt2rVKSUlRkyZNNHHixOvueO/atUvp6el65JFHSj3+I488os6dOysgIED/8z//o/j4eK1evVrZ2dnldQkAAABAhbLLHXVXV1f5+/vL399fwcHBCgkJ0bp16zRgwABzn9TUVAUGBqply5ZlPl+rVq0kSSdOnJCnp2eZxwMAAChJQECA+etatWqpadOmGj16tO69915JMq9217JlS61Zs8bc9/HHH9d3332nSZMmae/evRb7/qpjx45atmyZVfVcuypetWrV1KhRI/Xr10//+te/5Oz8ZyScP3++FixYIElydHRUgwYN1KlTJ40bN0516tRRXFxcifX4+vqWW81ZWVl644039N133yk9PV3t27e3+tjbgV2C+rUcHR3l4OCgy5cvm9suXLig9evXKzY29obH5ebm6ty5c/L29lbNmjVveo5Dhw5Jknx9fcunaAAAYBezE+fo4qUcm5/X3c1D48ZHl/q4IUOGqHfv3jp//rwWL16sYcOGKTU1VcHBweY+GRkZ+u2339SgQQNlZWWZc4v056IbAwcONPeLiYnRCy+8oMDAwD/rKmbq8M2EhIQoOjpaBQUFOnDggBITE1VYWKgxY8aY+3h4eOidd95RUVGRDh48qLlz5+rQoUNasWKFVfW4uLiUW82nT5/W+vXr1b59+yr5vKFNg3pubq7mzJmjXr16yc/PTzk5OUpOTpbJZLJYlvGjjz6Sg4OD/vGPf9xwrI0bNyo+Pl4zZsxQRESEuf3o0aNas2aNevToodq1ays9PV2vvPKKwsPDuZsOAEAld/FSjmoeLvu/tpf6vHf9fEvH+fr6qk2bNpKkDh06qHv37vrwww8tgnpoaKg+//xzDRo0SF988YW6dOmiDRs2SJLuuOMO3XHHHZL+/1LTTZs2NY9ZWl5eXuZj27dvr4MHD2rTpk0WQd3Jycncp127dnJ1ddWECRO0d+9eBQcHW1VPedUcEBCgrVu3SpLGjh2rc+fOlXqMysymQd3Z2VmZmZmKj4/X2bNn5ebmpsDAQCUnJ8vf39/cb8WKFerdu7c8PDxKfQ4XFxdt375dKSkpunz5sho2bKjw8HCNGDGiPC8FAACgVGrWrKk777xTJ0+etGjv2bOnPvroIw0aNEibN29W7969zUG9ojk5OVnMaijOtVOIr/0FwxYcHe26QKHd2TSoV69eXfPmzSux37p160rsExERYXEn/aqGDRsqNTX1luoDAACoKCaTSb///rtat25t0X7vvfdq2rRpysrK0vbt2zV9+vQKraGgoECFhYX66aeftH79ej300EM3PSYjI0OSeD+NHdh9jjoAAMDtqqioSAUFBcrJyVFKSopMJpOefvppiz6urq665557NHPmTLVs2VJeXl4VVs+mTZvMc8UlKSwsrNhnAgsKCsxz1BMTE+Xr62u+sw7bIagDAABUkOnTp5vvkNepU0eLFy8udnGLsLAwJSQkKC4urkLr6dSpk2JiYlRQUKBDhw4pKSlJr776qhISEsx9zp8/bxHmmzVrpqSkpFK/18YaJpNJhYWF5m1HR8cqP93lWgR1AACAChIVFaUHH3xQx48f1/Tp0xUdHa21a9fKycnJol+PHj0UGhqqXr16VWg9np6eCgoKkiS1bdtWNWvW1Lhx4zRs2DDVr19f0p+rvrz77rtycnJS/fr1Vbt27QqrZ82aNYqPjzdvjx492uLB1qqOoA4AAFBBGjVqpKCgIAUFBcnDw0NRUVH6+OOP1b9/f4t+derUUXJyss3rCwgIUFFRkX755RdzUHdycjKH+YrWo0cPrVq1yrxdr149m5y3siCoAwAA2EBoaKjat2+v5ORk9evXz97lSJKOHTsmyX4Pinp7e8vb29su564MCOoAAAA2EhUVpZEjR+qrr76yy/nPnz+vH3/8UQUFBTp27Jhef/11tWnTRk2aNLFLPdb4z3/+I+nPlx9dvHjRvP3AAw/YsyybIKgDAADYSI8ePdS0aVO73VXfsWOHHnvsMTk7O6t+/foKDQ3VmDFjDP0A5zPPPFPs9v79++1Rjk0R1AEAQKXh7uZxy28JLet5S6u4IOng4KBPP/3UvF3cO2FudGyzZs3KFE6XLVtWYp8xY8ZY/TCnNfWUtWapagTyGyGoAwCASmPc+Gh7lwDYjHH/nQMAAACowgjqAAAAgAER1AEAAAADIqgDAAAABkRQBwAAAAyIoA4AAAAYEEEdAAAAMCCCOgAAAGBABHUAAADAgHgzKQAAQAUICAgwf12rVi01bdpUo0eP1r333itJWr16teLj49WyZUutWbPG3Pfxxx/Xd999p0mTJmnv3r0W+/6qY8eOWrZsmVX1REZGaufOnZKkatWqqVGjRurXr5/+9a9/ydn5z0g4f/58LViwQJLk6OioBg0aqFOnTho3bpzq1KmjuLi4Euvx9fUtt5rXr1+vDz74QPv371d+fr5atGih5557Tu3atbPq+MqOoA4AACqNxFcSdSnvks3P61bdTePjxpf6uCFDhqh37946f/68Fi9erGHDhik1NVXBwcHmPhkZGfrtt9/UoEEDZWVl6dChQ+Z9o0aN0sCBA839YmJi9MILLygwMFCS5O7uXqp6QkJCFB0drYKCAh04cECJiYkqLCzUmDFjzH08PDz0zjvvqKioSAcPHtTcuXN16NAhrVixwqp6XFxcyq3mlJQUNW7cWIMGDZKrq6tSU1P15JNP6sMPP7T4Reh2RVAHAACVxqW8S/puyjc2P+89Uzrc0nG+vr5q06aNJKlDhw7q3r27PvzwQ4ugHhoaqs8//1yDBg3SF198oS5dumjDhg2SpDvuuEN33HGHJMnNzU2S1LRpU/OYpeXl5WU+tn379jp48KA2bdpkEdSdnJzMfdq1aydXV1dNmDBBe/fuVXBwsFX1lFfNCxYskLe3t3m7Y8eO6t69u95//31NnTq11ONVNsxRBwAAsIGaNWvqzjvv1MmTJy3ae/bsqc2bN0uSNm/erJ49e9qsJicnJ12+fPmmfVq1aiVJOnHihC1KsnBtSJckFxcX+fn52aUWeyCoAwAA2IDJZNLvv/8uf39/i/Z7771Xu3fvVlZWlrZv365u3bpVaA0FBQXKy8vT999/r/Xr16t79+43PSYjI0OSVLdu3Qqry1qXL1/W4cOHdffdd9u7FJtg6gsAAEAFKSoqUkFBgXJycpSSkiKTyaSnn37aoo+rq6vuuecezZw5Uy1btpSXl1eF1bNp0ybzXHFJCgsLU2xs7HX9CgoKzHPUExMT5evra76zbk+LFi3SH3/8oUGDBtm7FJvgjjoAAEAFmT59ugIDA9WpUyctX75cb7/9tnx9fa/rFxYWpjVr1lT4tJdOnTpp1apVSk1N1UsvvaTdu3fr1Vdftehz/vx5BQYGKigoSBEREXJ0dFRSUpJcXV3LvZ6rd/iv/ikqKrph3x07dmjRokWKjY2Vn59fuddiRNxRBwAAqCBRUVF68MEHdfz4cU2fPl3R0dFau3atnJycLPr16NFDoaGh6tWrV4XW4+npqaCgIElS27ZtVbNmTY0bN07Dhg1T/fr1Jf256su7774rJycn1a9fX7Vr166wetasWaP4+Hjz9ujRoy0ebL3q2LFjGjt2rCIiIqrM3XSJoA4AAFBhGjVqpKCgIAUFBcnDw0NRUVH6+OOP1b9/f4t+derUUXJyss3rCwgIUFFRkX755RdzUHdycjKH+YrWo0cPrVq1yrxdr1696/pcuHBBw4cPV8uWLfXCCy/YpC6jIKgDAADYQGhoqNq3b6/k5GT169fP3uVI+vNOtWS/B0W9vb2vW9nlWn/88YfGjBkjZ2dnzZs3T9WqVbNhdfZHUAcAALCRqKgojRw5Ul999ZVdzn/+/Hn9+OOPKigo0LFjx/T666+rTZs2atKkiV3qKcmUKVP0/fffa+bMmTp8+LC53d3dXU2bNrVjZbZBUAcAAJWGW3W3W375UFnPWx569Oihpk2b2u2u+o4dO/TYY4/J2dlZ9evXV2hoqMaMGSNHR2OuL7Jt2zbl5+fr2WeftWjv2LGjli1bZp+ibIigDgAAKo3xcePtXYLV9u/ff12bg4ODPv30U/N2RESE1cc2a9as2HZrWRNsx4wZU+zDnMWxpp6y1nz1RVBVlTF/fQIAAACqOII6AAAAYEAEdQAAAMCACOoAAACAARHUAQCAIZlMJnuXAJRZWf47JqgDAADDqVatmi5fvmzvMoAyu3z58i2/qImgDgAADKdevXo6ceKELl26xJ11VEomk0mXLl3SiRMnVK9evVsag3XUAQCA4dSqVUuSdPLkSf3xxx92rga4NdWqVVP9+vXN/z2XFkEdAAAYUq1atW454AC3A6a+AAAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIAB2Xwd9fnz52vDhg06efKkXF1d1bZtW8XExOiuu+6SJAUEBFx3zNtvv61u3bpZfY6CggIlJiZq7dq1ys/PV2hoqKZOnSofH59yuw4AAACgItk8qDdu3FgJCQny8/PTlStXtGDBAg0ZMkSfffaZXFxcJEkvvPCC7r//fvMxnp6epTrH/PnztXr1as2aNUs+Pj5KSEhQdHS0Fi9eXJ6XAgAAAFQYmwf1fv36WWyPGjVK4eHhOnLkiJo3by5Jcnd3V926dW9p/KKiIqWmpmro0KG67777JEkJCQl64okndPjwYfOdewAAAMDI7DpH/eLFi1q5cqW8vb3l5+dnbp89e7ZCQkI0YMAArV27tlRjZmRk6Pz58+rQoYO5rV27dnJ2dtbu3bvLq3QAAACgQtn8jrok7dixQyNGjNClS5d05513KiUlRe7u7pKk6OhodezYUS4uLtq8ebPi4+NlMpnUv39/q8Y+e/asJMnHx0djx47VqVOn9MEHH8jT09O8DwAAADA6uwT11q1ba+3atcrMzNQ777yjiRMnaunSpapevbqGDx9u7hcYGKhTp05p8eLFVgf1a9WrV688ywYAAABsxi5B3dXVVf7+/vL391dwcLBCQkK0bt06DRgw4Lq+gYGB2rhxo9Vj165dW5KUlZWlhIQESVJhYaGys7PN+wAAAACjs/s66o6OjnJwcNDly5eL3X/48GH5+vpe156bm6vjx48rNzfXor1x48by8vLSN998Y277/vvvVVBQoODg4PItHgAAAKggNg3qubm5mjZtmrZt26aMjAz9/PPPio2NlclkUteuXZWWlqaUlBSlp6fr6NGjeu+997Ry5Uo9+eST1421ceNGhYWFXXe33dHRUQMHDlRycrK+/PJL7dmzR9OnT1fnzp1Z8QUAAACVhk2nvjg7OyszM1Px8fE6e/as3NzcFBgYqOTkZPn7++vo0aNavny5Zs2aJZPJJH9/f7344ouKiIgo1XnGjBmjy5cva8KECcrLyzO/8AgAAACoLGwa1KtXr6558+bdcH+3bt2sfgNpRETEDQO8s7OzJk6cqIkTJ95SnQAAAIC92X2OOgAAAIDrEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1oJxFRkYqMjLS3mUAAIBKjqAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAA3K29Qnnz5+vDRs26OTJk3J1dVXbtm0VExOju+66SydOnFBSUpJ27typrKwsNWzYUAMGDNDQoUPl6Gj97xSRkZHauXOnRduwYcMUExNT3pcDAAAAVAibB/XGjRsrISFBfn5+unLlihYsWKAhQ4bos88+09GjR+Xs7KwZM2bIz89P3377rRISElRYWKiRI0eW6jx9+/ZVXFycedvNza28LwUAAACoMDYP6v369bPYHjVqlMLDw3XkyBF16dJFXbp0Me9r3LixNm3apE2bNpU6qLu6uqpu3brlUTIAAABgc3ado37x4kWtXLlS3t7e8vPzK7ZPTk6OPDw8Sj12WlqaOnXqpD59+ui1115TXl5eWcsFAAAAbMbmd9QlaceOHRoxYoQuXbqkO++8UykpKXJ3d7+u39dff61vv/1WixYtKtX4Dz/8sPz8/OTj46M9e/YoMTFRZ86c0YwZM8rrEgAAAIAKZZeg3rp1a61du1aZmZl65513NHHiRC1dulTVq1c39zl8+LBiYmL0zDPPqFu3bqUa/5FHHjF/HRAQIGdnZ8XGxiouLk6enp7ldh0AAABARbHL1BdXV1f5+/urffv2mjdvng4cOKB169aZ9x87dkyDBw/WgAEDSj03vTitWrWSJJ04caLMYwEAAAC2YPd11B0dHeXg4KDLly9L+jNMP/XUU+rTp48mTJhww+Nyc3N1/Phx5ebmlniOQ4cOSZJ8fX3Lp2jgNtK9e3d1797d3mUAAIC/sOnUl9zcXM2ZM0e9evWSn5+fcnJylJycLJPJpK5du+r06dN66qmn1LFjR0VFRSkzM1OS5OTkJB8fH4uxNm7cqPj4eM2YMUMRERHm9qNHj2rNmjXq0aOHateurfT0dL3yyisKDw9n2gvKZO7cucrOzi6x36+//ipJmjp1aol9PT099eyzz5bYLzIyUpK0bNmyEvuW1pYtW8p9TAAAUHY2DerOzs7KzMxUfHy8zp49Kzc3NwUGBio5OVn+/v5avXq1MjIylJGRobVr15qP8/X11ebNm606h4uLi7Zv366UlBRdvnxZDRs2VHh4uEaMGFFBV4WqIjs7W7EJk0rsd+DgQUmyqu+rL00rc10AAOD2ZNOgXr16dc2bN++G+yMiIizujt/Mjfo2bNhQqampt1wjAAAAYAR2n6MOAAAA4HoEdQAAAMCACOoAAACAAZU5qGdlZVk8+AkAAACg7Moc1DMyMhQfH18etQAAAAD4P2UO6jk5OXJxcSmPWgAAAAD8nxsuz2jNdJbz589r+fLlatWqVXnWBOAvNm3aZO8SAACAjd0wqMfFxcnBwUEmk+mmA7Rq1UrTpvHSFgAAAKA83fSFR/Pnz1eLFi2K3efg4CBPT0/VrFmzQgoDAAAAqrKbBvV69erJ19fXVrUAAAAA+D83fJh00qRJ8vPzs2UtAAAAAP7PDe+oDxo0yJZ1AAAAALjGTae+/NXp06d14MABnT17VrVr11azZs1Uv379iqoNAIAKERkZKUlatmyZnSsBgBuzKqhfvHhRL774otavX6+CgoL/f7Czs/r27atJkybxUCkAAABQjqwK6tOmTdNnn32msWPHqlOnTqpVq5YuXLig7du3680335SDg4NmzJhR0bUCAAAAVYZVQT0tLU3x8fF69NFHLdqDg4NVq1YtJSYmEtQBAACAcnTDVV+u5eLicsO56PXr15ezc6mmugMAAAAogVVB/amnntKCBQt0+vRpi/bTp09r4cKF5odyAKAqi4yM5OchAKDcWHUr/L///a8OHjyonj17yt/fX15eXsrOztavv/4qFxcXVa9eXU8++aSkP99YumTJkgotGgAAALjdWT1nJSgoyGLbx8dHPj4+kiSTyWRuv/ZroCpKXrLU3iUAAIDbgFVBnXVmgYrh4OioqVOnltjvypUrkmRVX0ny8Kil6OjnylQbAACwL54CBezIVFSkFr2eLLGf0/wFkmRVX0nal8ZdfQAAKjurg/qFCxeUmpqq9PR0/f7776pTp45atGihxx57TLVq1arIGgEAAIAqx6pVX3744Qf17NlTc+fOVXp6uvLz85Wenq7XXntNYWFh2rVrV0XXCQAAAFQpVr+ZtGnTpkpKSrJYT/306dN65plnNG3aNK1atarCigQAAACqGqvuqB86dEgjR4687qVH9evX14gRI3TgwIEKKQ4AAACoqqwK6k2aNNHJkyeL3Xfy5En5+/uXa1EAUNF4OREAwOismvoyfPhwTZs2TRcuXFDnzp3l5eWl8+fPa9u2bVqyZIkmTpxoEeQbNWpUYQUDAAAAVYFVQT06OlqS9Nprr2nu3Lnm9qsvNxo/frxF/3379pVTeQAAAEDVZFVQnzFjRkXXAQAAAOAaVgX1/v37V3QdAAAAAK5h1cOkAAAAAGyLoA4AAAAYEEEdAAAYEsuoVg58nyqOVXPUAdhXhy732bsEAABgYwR1AMBtY86c15STc6HEfr/++qskaerUqSX29fCopejo58paGgCUGkEdAHDbyMm5oBa9niyx39bv9kiSVX33pS0tc10AcCuYow4AAAAYEEEdAAAAMCCCOgAAAGBAzFEHACtY85BiaR5QlHhIEQBwcwR1ALCCNQ8pluYBRYmHFAEAN2fV1JewsDClp6cXuy8jI0NhYWHlWhQAAABQ1Vl1R/3EiRPKz88vdl9+fr5OnjxZrkUBsBQVm2jvEgAAgI2V+WHSo0ePqlatWuVRCwAAAID/c8M76mlpafr888/N22+88Ya8vb0t+ly6dElbt27VPffcU3EVAgAAAFXQDYP6iRMntGPHDvP23r175eLiYtHH3d1dPXv21HPPWb9qwfz587VhwwadPHlSrq6uatu2rWJiYnTXXXdJks6cOaMpU6Zo69atqlGjhvr3769x48bJycnJ6nMUFBQoMTFRa9euVX5+vkJDQzV16lT5+PhYPQYAAABgTzcM6k899ZSeeuopSVLz5s31xhtvKDg4uMwnbNy4sRISEuTn56crV65owYIFGjJkiD777DO5uLjo2Wef1ZUrV5SSkqIzZ85o/Pjxcnd316hRo6w+x/z587V69WrNmjVLPj4+SkhIUHR0tBYvXlzm+gEAAABbsPnyjP369bPYHjVqlMLDw3XkyBFJ0nfffafU1FQFBgYqMDBQgwcP1vvvv6+RI0fKwcGhxPGLioqUmpqqoUOH6r777pMkJSQk6IknntDhw4fNd+4BoLLp3r27JGnLli12rQMAYBtWBfXPP/9cdevWLfeTX7x4UStXrpS3t7f8/Py0YcMGVa9eXa1btzb3CQkJ0fz583Xy5En5+vqWOGZGRobOnz+vDh06mNvatWsnZ2dn7d69m6AO3Obmzp2r7OzsEvuV9uVEAADYmlVB3ZqAXBo7duzQiBEjdOnSJd15551KSUmRu7u7zp49K09PT+Xl5alPnz564IEHNGDAAEnS2bNnrarj7NmzkiQfHx+NHTtWp06d0gcffCBPT0/zPgC3r+zsbMUmTCqx34GDByXJqr6S9OpL08pUV3ngTjoAVC23vDzj2bNnlZ6erj/++KPUx7Zu3Vpr165VSkqKmjRpookTJyovL8+838nJSQ0bNlTt2rVvtTxJUr169dSwYcMyjQEAsJ/IyEhFRkbauwwAsAur7qi//fbbOnnypCZPnixJ+uijj5SQkKCCggI1bNhQycnJatKkidUndXV1lb+/v/z9/RUcHKyQkBCtW7dOtWvXVnZ2tpydnZWSkiJJ+uabbyTJ6tB+tV9WVpYSEhIkSYWFhcrOzi5z8AcAAABsxao76qtXr1bTpk3N27Nnz1br1q2VlJSkmjVr6rXXXrv1Ahwd5eDgoMuXLysoKEh5eXnatWuXef+OHTtUp04dNWrUyOK43NxcHT9+XLm5uRbtjRs3lpeXlzngS9L333+vgoKCclm1BgAAALAFq4L6qVOnzEH96NGjOnPmjJ5//nndf//9Gj16tL7//nurTpabm6tp06Zp27ZtysjI0M8//6zY2FiZTCZ17dpVzZs3V7t27TRt2jT99NNP2rJlixYvXqxBgwZdt+LLxo0bFRYWpo0bN1pekKOjBg4cqOTkZH355Zfas2ePpk+frs6dO/MgKQAAACoNq6a+1KhRQxcuXJAkffvtt/L29laLFi0kSZ6enrp48aJ1J3N2VmZmpuLj43X27Fm5ubkpMDBQycnJ8vf3lyQlJSVp8uTJevzxx1WjRg09+uijGj58eKkuasyYMbp8+bImTJigvLw88wuPAAAAgMrCqqDepk0bzZ07V8ePH9f777+vzp07m/f98ssvql+/vlUnq169uubNm3fTPvXq1dObb75Z4lgRERGKiIgodp+zs7MmTpyoiRMnWlUXAACwnTlzXlNOzoUS+5VmGVUPj1qKjrb+TekoWUV8nyS+V6VhVVCfMGGCRowYoVdffVUNGjTQmDFjzPvWrVune+65p8IKBFAxrq6ksWzZMjtXAtheVGyivUuo0nJyLqhFrydL7Lf1uz2SZFXffWlLy1wXLFXE90nie1UaVgX1Jk2aaOPGjTp37py8vLws5osnJiaqVq1aFVYgAAAAUBVZFdSv8vb2vq7tr6uxAAAAACi7Ur3wKDs7W99++60++eQT8yu6b+WFRwAAAABuzqo76kVFRZo1a5bef/99XblyRQ4ODlq1apU8PT31xBNP6L777tOoUaMqulYAAACgyrDqjvqcOXO0YsUKRUdHa+XKlTKZTOZ9vXv31pYtWyqqPgAAAKBKsuqO+tq1axUdHa1BgwapsLDQYt/dd99t1XKKAG5/VX0lGVYSAQCUJ6vuqF+4cEFNmjQpdp/JZFJBQUG5FgUAAABUdVYF9b/97W/atGlTsfu2bdumpk2blmtRAAAAQFVn1dSXwYMHKy4uTjk5OXrwwQfl4OCgQ4cO6auvvtJ7772nGTNmVHSdAAAAQJViVVDv16+fzp07p3nz5mn9+vUymUyKjY1VjRo19Mwzz6hv374VXScAAABQpVj9wqOnn35ajzzyiH788UfzG0rbtm0rd3f3iqwPAAAAqJJK9WZSd3d3hYaGVlQtAAAAAP5Pqd5MCgAAAMA2rArqLVq00O7du4vdd+TIEbVo0aJciwIAAACqOqumvlz7JtLi9t1sPwAYUfKSpfYuAbep7t27SxJv7QZQZmWe+vLTTz/Jx8enPGoBAAAA8H9ueEd9zZo1WrNmjXl7ypQp163wcunSJaWnp+uBBx6ouAoBALeluXPnKjs7+6Z9fv31V0nS1KlTbVBR2URGRtq7BAC3mZtOffnrlJa/btetW1fdunXTkCFDyr8yAMBtLTs7W7EJk27a58DBg5JUYr+rXn1pWpnrKiumvAAoLzcM6v3791f//v0lSc2bN9eUKVMUHBxss8IAAACAqozlGQEAAAADsmrVl/T09IquAwAAAMA1SvVmUgC3j02bNtm7BAC4qajYRHuXACvwfao4BHXgdlTkUOIqGc2aNZNk/Woa7m4eGjc+usylAQAA6xDUgduRo0k1D7e8aReny1slqcR+V1286+cylwUAAKxHUAcAoBwwnQxAeWPVFwAAUGaRkZG89AkoZwR1AAAAwIAI6gAAAIABMUcdgFWK/igqcYWYX3/9VZL1K8m4VXfT+LjxZS0NAIDbEkEdgFUcqznquynf3LRPjl+OJJXY76p7pnQoc10AANyumPoCAAAAGBBBHQAAoAxY8QYVhaAOAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABEdQBwMBYTQIAqi6COgAAAGBAvJkUAGBYyUuW2rsEqchBU6dOLbHblStXJMmqvu5uHho3PrrMpQG4vRHUAQC4GUeTah5uWWI3hyInSbKq78W7fi5zWQBuf0x9AQAAAAyIoA4AVRAPqQKA8RHUAQAAAAMiqAMAAAAGZNOHSRcuXKj169crIyNDNWrUUKdOnRQTE6NGjRpJklavXq34+Phij926datq165t1XkiIyO1c+dOi7Zhw4YpJiambBcA3Eb6thxq7xIAAMBN2DSo//DDD4qKilKrVq2Uk5OjyZMnKyoqSp988omcnZ310EMPqWvXrhbHvPzyy/r999+tDulX9e3bV3FxceZtNze3crkGAAAAwBZsGtTfeusti+3Ro0dr9OjROnTokJo3by5XV1e5urqa91+8eFFbtmzRlClTSn0uV1dX1a1bt6wlAwBgN1cf+F22bJmdK7n9dO/eXZK0ZcsWu9YB3Ixd11G/cOGCJMnDw6PY/R9//LGcnZ3Vu3fvUo+dlpamzz//XLVr11avXr00atQoVa9evUz1AgBQ1cydO1fZ2dkl9vv1118lWffCJ9gPv/xVLnYL6rm5uVq0aJH69OkjX1/fYvusWLFCffv2tbjLbo2HH35Yfn5+8vHx0Z49e5SYmKgzZ85oxowZ5VE6AABVRnZ2tmITJpXY78DBg5JkVd9XX5pW5rrKijvpqAzsEtQLCgo0btw4ubm5adq04j+su3btUnp6+i2F60ceecT8dUBAgJydnRUbG6u4uDh5enrect0AAACArdg8qBcVFSk2NlYZGRlatmyZatasWWy/1NRUBQYGqmXLkl/FXJJWrVpJkk6cOEFQByrQHcf97F0CAAC3DZuuo24ymfT8889r3759WrJkiXx8fIrtd+HCBa1fv17/8z//c8OxcnNzdfz4ceXm5pZ43kOHDknSDafYAAAAAEZj06A+efJkbdu2TXPmzJHJZFJmZqYyMzOVn59v0e+jjz6Sg4OD/vGPf9xwrI0bNyosLEwbN260aD969Kjmzp2rXbt26fjx40pLS9Mrr7yi8PBw7qYDAACg0rDp1JcVK1ZIksLDwy3aly5dqpCQEIt+vXv3vuFqMDfj4uKi7du3KyUlRZcvX1bDhg0VHh6uESNGlK14AABuok1AB3uXACuUdtWTxFcSdSnv0k37lHbFG7fqbhofN96qvqjabBrU9+/fb1W/devWldgnIiJCERER17U3bNhQqamppa4NAADgry7lXdJ3U765aZ8cvxxJKrHfVfdM4Zc6WMemU18AAAAAWIegDgAAABiQXd9MCgC4uU2bNtm7BACAnXBHHQAAADAg7qgDgL0UOZS4SsSVK1ckWb+ahLubh8aNjy5zaQBgT6Vdned2RVAHAHtxNKnm4Zu/fdmhyEmSSux31cW7fi5zWQAAYyCoA4CBsTZ35dG35VB7lwDgNsMcdQCoJN7cNEVvbppi7zIAADZCUAcAAAAMiKkvAHAbKfqjyKoHT0vzynNedw4A9kFQB4DbiGM1R6teY16aV57zuvPSuTo9aeT9U+xaB4DKj6AOAJUEwQ8AqhbmqAMAAAAGRFAHAAAADIipLwAA2FhFPPQr8eAvcLshqAMAYGMV8dCvZN8Hf5OXLLXbuSHNnTtX2dnZJfYr7S9/sC+COgAAQCWXnZ2t2IRJJfY7cPCgJFnV99WXppW5LpQNc9QBAAAAA+KOOgAA5YhlNAGUF+6oAwAAAAbEHXUAAFD5FTlUyEo6gD0R1AEAQOXnaFLNwy1L7OZ0easkWdVXknLv+rnEPncc97NqLKC0mPoCAAAAGBBBHQAAADAggjoAAABgQAR1AAAAwIAI6gAAAIABseoLABhY35ZD7V0CAJQvK5bSLO0ymu5uHho3PrqslRkOQR0AAAC2Y8VSmqVdRvOiFctoVkZMfQEAAAAMiKAOAAAAGBBBHQAAADAg5qgDQBXEK88BwPi4ow4AAAAYEEEdAAAAMCCCOgAAAGBABHUAAADAgHiYFAAAg+KhX6BqI6gDAABUEclLltq7BJQCU18AAAAAAyKoAwAAAAZEUAcAAAAMiKAOAAAAGBAPkwIAgCqjb8uh9i4BsBp31AEAAAADIqgDAAAABkRQBwAAAAzIpnPUFy5cqPXr1ysjI0M1atRQp06dFBMTo0aNGpn7BAQEXHfc22+/rW7dull9noKCAiUmJmrt2rXKz89XaGiopk6dKh8fn3K5DgAAAKCi2TSo//DDD4qKilKrVq2Uk5OjyZMnKyoqSp988omcnf9/KS+88ILuv/9+87anp2epzjN//nytXr1as2bNko+PjxISEhQdHa3FixeX16UAAAAAFcqmQf2tt96y2B49erRGjx6tQ4cOqXnz5uZ2d3d31a1b95bOUVRUpNTUVA0dOlT33XefJCkhIUFPPPGEDh8+rLvuuuvWLwAAAACwEbvOUb9w4YIkycPDw6J99uzZCgkJ0YABA7R27dpSjZmRkaHz58+rQ4cO5rZ27drJ2dlZu3fvLnPNAAAAqFh9Ww5lKU3ZcR313NxcLVq0SH369JGvr6+5PTo6Wh07dpSLi4s2b96s+Ph4mUwm9e/f36pxz549K0ny8fHR2LFjderUKX3wwQfy9PQ07wMAAACMzi5BvaCgQOPGjZObm5umTZtmsW/48OHmrwMDA3Xq1CktXrzY6qB+rXr16pW5VgAAAMAebB7Ui4qKFBsbq4yMDC1btkw1a9a8af/AwEBt3LjR6vFr164tScrKylJCQoIkqbCwUNnZ2eZ9AAAAgNHZdI66yWTS888/r3379mnJkiVWLZd4+PBhi6kxV+Xm5ur48ePKzc21aG/cuLG8vLz0zTffmNu+//57FRQUKDg4uOwXAQAAANiATYP65MmTtW3bNs2ZM0cmk0mZmZnKzMxUfn6+JCktLU0pKSlKT0/X0aNH9d5772nlypV68sknrxtr48aNCgsLu+5uu6OjowYOHKjk5GR9+eWX2rNnj6ZPn67OnTuz4gsAAAAqDZtOfVmxYoUkKTw83KJ96dKlCgkJkYuLi5YvX65Zs2bJZDLJ399fL774oiIiIkp1njFjxujy5cuaMGGC8vLyzC88AgAAACoLmwb1/fv333R/t27drH4DaURExA0DvLOzsyZOnKiJEyeWukYAAADACOy6jjoAAACA4hHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIGdbnmzhwoVav369MjIyVKNGDXXq1EkxMTFq1KiRJOnEiRNKSkrSzp07lZWVpYYNG2rAgAEaOnSoHB2t/50iMjJSO3futGgbNmyYYmJiyvV6AAAAgIpi06D+ww8/KCoqSq1atVJOTo4mT56sqKgoffLJJ3J2dtbRo0fl7OysGTNmyM/PT99++60SEhJUWFiokSNHlupcffv2VVxcnHnbzc2tvC8HAAAAqDA2DepvvfWWxfbo0aM1evRoHTp0SM2bN1eXLl3UpUsX8/7GjRtr06ZN2rRpU6mDuqurq+rWrVsudQMAAAC2Ztc56hcuXJAkeXh43LBPTk7OTfffSFpamjp16qQ+ffrotddeU15e3i3XCQAAANiaTe+oXys3N1eLFi1Snz595OvrW2yfr7/+Wt9++60WLVpUqrEffvhh+fn5ycfHR3v27FFiYqLOnDmjGTNmlEfpAAAAQIWzS1AvKCjQuHHj5ObmpmnTphXb5/Dhw4qJidEzzzyjbt26lWr8Rx55xPx1QECAnJ2dFRsbq7i4OHl6epapdgAAAMAWbD71paioSLGxscrIyFBycrJq1qx5XZ9jx45p8ODBGjBgQKnnphenVatWkv5cVQYAAACoDGwa1E0mk55//nnt27dPS5YskY+Pz3V9Tpw4oaeeekp9+vTRhAkTbjhWbm6ujh8/rtzc3BLPe+jQIUm64RQbAAAAwGhsGtQnT56sbdu2ac6cOTKZTMrMzFRmZqby8/MlSadPn9ZTTz2ljh07Kioqyrw/KyvrurE2btyosLAwbdy40aL96NGjmjt3rnbt2qXjx48rLS1Nr7zyisLDw5n2AgAAgErDpnPUV6xYIUkKDw+3aF+6dKlCQkL03//+VxkZGcrIyNDatWvN+319fbV582arzuHi4qLt27crJSVFly9fVsOGDRUeHq4RI0aU23UAAAAAFc2mQX3//v033R8REaGIiAirxrpR34YNGyo1NfWW6gMAAACMwq7rqAMAAAAoHkEdAAAAMCCCOgAAAGBABHUAAADAgAjqAAAAgAER1AEAAAADIqgDAAAABkRQBwAAAAyIoA4AAAAYEEEdAAAAMCCCOgAAAGBABHUAAADAgAjqAAAAgAER1AEAAAADIqgDAAAABkRQBwAAAAyIoA4AAAAYEEEdAAAAMCCCOgAAAGBABHUAAADAgAjqAAAAgAER1AEAAAADIqgDAAAABkRQBwAAAAyIoA4AAAAYEEEdAAAAMCBnexdgRIWFhZKk3377zSbnu3jxok6cOFHuY577vXzrv3jxoo4fP16uY1YmleX7dHXcorxz5TrmpYsX9YfzH+U6ZkX8N1UR36er41bEZ6qqfp+ujlsZPlOV5fskVZ7PVGX5PkmV5zNVWb5PV8etiM9UZc0oV/Pm1fx5LQeTyWSydUFG9+2332rQoEH2LgMAAABVREpKitq3b2/RRlAvxpUrV7R3717VrVtXTk5O9i4HAAAAt6nCwkJlZmaqVatWcnV1tdhHUAcAAAAMiIdJAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABgQQR0AAAAwIII6AAAAYEAEdQAAAMCACOoAAACAARHUYZW33npLXbt2VXBwsAYPHqxjx47ZuyT8xaFDh/TMM88oLCxMAQEBmj9/vr1LQjHi4uIUEBBg8ee5556zd1lVXkmfnzNnzmjUqFFq06aNOnfurJkzZ6qwsNBO1VZdCxcu1MMPP6y2bduqS5cuio6O1smTJy36/PXzFRAQoK+++spOFVddJf2s4zNlHWd7FwDj++CDDzR//nzNmDFDd999t2bOnKnhw4frk08+kbMz/wkZRW5urho0aKBevXopMTHR3uXgJtq3b6+5c+eat//6ymjYXkmfn2effVZXrlxRSkqKzpw5o/Hjx8vd3V2jRo2yQ7VV1w8//KCoqCi1atVKOTk5mjx5sqKioq77/9ELL7yg+++/37zt6elpj3KrvJv9rOMzZR1SFkqUkpKiiIgI/eMf/5AkvfTSS+rRo4f++9//6r777rNzdbiqdevWat26tSRp3rx5dq4GN1OtWjXVrVvX3mXgGjf7/KSnp+u7775TamqqAgMDFRgYqMGDB+v999/XyJEj5eDgYI+Sq6S33nrLYnv06NEaPXq0Dh06pObNm5vb3d3d+YwZwI1+1vGZsh5TX3BT+fn52r9/vzp06GBua9Sokfz8/LRnzx47VgZUXnv27NG9996r+++/X1OnTtWFCxfsXRJuYs+ePapevbo5yEtSSEiIMjMzr5t2Adu6+tnx8PCwaJ89e7ZCQkI0YMAArV271g6VQbrxzzo+U9bjjjpu6ty5cyoqKpKPj49effVVbdq0SevWrZOPj4/Onj1r7/KASqdbt2568MEH1aBBAx0+fFizZs3S4cOHtXTpUnuXhhs4e/asPD09lZeXpz59+uiBBx7QgAEDzPt8fX3tXGHVlJubq0WLFqlPnz4W34Po6Gh17NhRLi4u2rx5s+Lj42UymdS/f387Vlv13OxnHZ8p6xHUYTVvb281atRITk5O9i4FqLQeeugh89cBAQGqV6+eBg0apH379qlFixZ2rAwlcXJyUsOGDVW7dm17l1LlFRQUaNy4cXJzc9O0adMs9g0fPtz8dWBgoE6dOqXFixcT1G3sZj/rruIzVTKCOm7K29tbjo6OysrK0r/+9S/961//kiRlZWXxwQLKQWBgoCTp+PHjBHWDql27trKzs+Xs7KyUlBRJ0jfffGPeB9sqKipSbGysMjIytGzZMtWsWfOm/QMDA7Vx40YbVYcbufZnHZ8p6zFHHTfl4uKigIAA8wdIkk6ePKnjx48rKCjIjpUBt4dDhw5JEv/Ua2BBQUHKy8vTrl27zG07duxQnTp11KhRIztWVvWYTCY9//zz2rdvn5YsWSIfH58Sjzl8+DCfLwO49mcdnynrcUcdJRo0aJCmTp2qDh06mJdnbNKkie699157l4Zr5Ofn6/Dhw5KkP/74Q5mZmdq3b588PT35wWcQubm5mjt3rnr37q0GDRro2LFjmjFjhjp27MjddDu72eenefPmateunaZNm6Zp06YpMzNTixcv1pAhQ1idwsYmT56sbdu2aeHChTKZTMrMzJT05/KLLi4uSktL0+nTp3XPPfeoRo0a+vrrr7Vy5UpNmTLFvoVXMSX9rHNwcOAzZSUHk8lksncRML6FCxfqvffeU3Z2tu655x5NnTpV/v7+9i4L1zh+/LjCwsKua+/fv79eeeUVO1SEv7py5YqGDx+u9PR05ebmql69eurWrZueffZZeXl52bu8Kq2kz8+ZM2c0efJkbd26VTVq1FBERITGjRvHMzs2FhAQUGz70qVLFRISoq+++kozZ87UiRMnZDKZ5O/vr6eeekoRERE2rrRqs+ZnHZ8p6xDUAQAAAANijjoAAABgQAR1AAAAwIAI6gAAAIABEdQBAAAAAyKoAwAAAAZEUAcAAAAMiKAOAKi0IiMjFRkZae8yAKBCsI46AKDSuvpa8qZNm9q5EgAofwR1AAAAwICY+gIAdnL8+HEFBARo+vTpatOmjSIjI/Xpp5+qU6dO+vvf/6709HSL/mvXrlV4eLiCgoIUGhqqxMREFRQUmPf37NlTzz//vDp37qxevXpp8+bNevDBBxUSEqI1a9ZYjJWWlqZ+/fopKChInTt3VkJCgnJycq6rMS4uTj179tSBAwf0xBNPqHXr1urSpYuWL18uSYqIiFBUVNR1x7322mtq27atLl68WKq/kzNnzigmJkahoaEKCgpSWFiYpk+fbtGnoKBAAQEB5j83mvoSFxdn0e9G/XNycvTiiy+qa9euatWqlcLDw/Xll1+Wqm4AqAgEdQCws/z8fCUkJGjnzp2aN2+eZs6cKRcXF7311lvmPu+++65iY2PVunVrvfnmmxoxYoSWL1+u2bNnW4x1+PBhvfLKK8rNzdUzzzyjMWPGqEuXLpo1a5a5z9atWzV69Gg1atRICxYs0NixY7VhwwaNGjWq2Pry8vI0ZswYhYaG6s0339Szzz5r/gXhkUce0datW/Xbb7+Z+xcVFemjjz7Sgw8+KHd391L9XcTFxWn79u2aMGGC3nnnHY0YMUKZmZkWfZydnbVixQqtWLFCLVu2vOFYo0aNMvdbsWKFXn/9dbm6uurOO+8098nPz9fgwYP16aefasSIEVq4cKFatmypkSNHat++faWqHQDKnQkAYBcZGRmmZs2amX7++WeTyWQytW/f3vTSSy+ZTCaTafr06aaHH37YZDKZTDk5OaY2bdqYnnnmGYvjFy9ebAoKCjJlZWWZTCaTqUePHqZ3333XZDKZTKNGjTIf/9lnn5maNWtmys7ONplMJtOQIUNMXbt2Nf3xxx/msZYvX25q1qyZadeuXRbniI2NNTVr1sy0Zs2aYq/ham2vv/66ue1///d/Tc2aNTP98MMPpf47adOmjWnq1KlW93/iiSdMTzzxRIn9CgoKTE888YSpb9++ptzcXHP7ypUrTc2aNTNt2bLFon94eLhpzJgx1hcOABWAO+oAYGdX7zrXrFlTHh4e5q9zc3MlST/88IMuXbqkhx56SAUFBeY/bdu2VV5eng4ePGge69rjr/1aknm8vXv3qnPnznJ2djYf161bN0nS7t27r6vPyclJffr0uWHtDz30kNasWSPT/z3ytHr1ajVr1kxt2rQp9d9FQECA1q9fr/fee08HDhxQYWFhqccozuzZs7Vv3z4tWLBAbm5u5vZt27bJ09NTXbp0sfi7bdeunfbu3Vsu5waAW+VcchcAQEVycHCQJDk6Olp8XVRUJEk6d+6cJGnMmDHFHn/q1KkSx5JkDr05OTny8vKyGMPb21uSdOHChevGr1OnjqpVq3bD+h999FGtWrVKO3fuVGBgoNLS0hQdHX2TK76xpKQkJSUlaeHChZo2bZq8vLw0dOhQDRs27JbGk6RNmzbp3Xff1euvvy5/f3+LfefOnVN2drZatWp13XFOTk63fE4AKA8EdQAwuKuh+pVXXil2GUI/P79Sjefh4aHz589btF39ZaBWrVrX9b/2zntxWrdurYCAAH344Yc6evSoioqKFB4eXqqarqpfv75efvllSdKRI0c0Z84czZo1S507dy42TJfkyJEjiouL08iRI9WzZ8/r9nt5ecnX11dJSUm3VC8AVCSCOgAYXNu2bVWjRg2dPHlS/fv3L/N4rVq10rZt21RQUGAO4V999ZUkKTg4+JbGfOyxx5SYmKiDBw/q73//+3V37G/F3/72N40YMUKfffaZTp06VeqgfunSJY0dO1YdOnS44b9GdO7cWZ999pm8vLzUuHHjMtcMAOWJoA4ABufh4aF///vfSkpK0sWLF9WpUyc5ODjo0KFD+s9//qP33ntPLi4uVo/39NNPa+jQoRo7dqwee+wxnTx5UrNmzVKHDh1uOag//PDDSkxM1M8//6xx48bd0hiS1K9fP/Xr109333238vPz9fbbb8vDw8NivvuxY8eUlZUlSeblH3/88UdJUoMGDdSgQQNJf/4LxKlTpzRhwgTt2rXLfLy7u7v5Xyb69eun5cuXa/DgwRo6dKj+9re/KSsrS99//70cHBw0ceLEW74WACgrgjoAVALDhg1T/fr1tWTJEr3//vtydnZWkyZN1L179xKnpvxVaGiokpKS9MYbb+jf//63atasqfvvv19xcXG3XJ+Hh4c6duyo/fv3q0uXLrc8Tps2bfTBBx/oxIkTql69ulq2bKl33nlHdevWNfd54403rlsX/rHHHpMkjR492nz3/JdfftHFixevm9/esWNHLVu2TJLk4uKipUuXat68eVq0aJEyMzPl7e2toKAgDRw48JavAwDKA28mBQCUWU5Oju677z4NHjxYY8eOtXc5AHBb4I46AOCWZWVl6ciRI1q6dKkKCwvNd7YBAGXHOuoAgFu2ZcsWDRo0SHv27NHs2bNVv359e5cEALcNpr4AAAAABsQddQAAAMCACOoAAACAARHUAQAAAAMiqAMAAAAGRFAHAAAADIigDgAAABjQ/wMvxpirGImJpQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fontdict = {'fontsize': 18, 'font':'monospace'}\n",
    "width = 0.8\n",
    "\n",
    "df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "mem_lens = np.unique(df.mem_size)\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "# Mean\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "plot_df = plot_df.reset_index().iloc[:-2]\n",
    "plot_df.plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=width, yerr=1)\n",
    "mean_df = plot_df\n",
    "\n",
    "col2b = dict(zip(plot_df.columns[1:], [0.12, -0.1, 0.1, 0.12]))\n",
    "\n",
    "# STD\n",
    "plot_df = pd.DataFrame(index = mem_lens)\n",
    "plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].std() for i in mem_lens]\n",
    "plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].std() for i in mem_lens]\n",
    "\n",
    "plot_df = plot_df.reset_index().iloc[:-2]\n",
    "\n",
    "# plt.title('WT103: base')\n",
    "plt.legend(['Transformer-XL', 'RMT', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=15)\n",
    "\n",
    "for i, row in plot_df.iterrows():\n",
    "    for col in plot_df.columns[1:]:\n",
    "        if pd.isna(row[col]):\n",
    "            continue\n",
    "        # print(i, )\n",
    "        std = row[col]\n",
    "        # print(col2b[col])\n",
    "        # print(mean_df.loc[i, col])\n",
    "        plt.vlines(i + col2b[col], mean_df.loc[i, col] - std/2, mean_df.loc[i, col] + std/2, color='k')\n",
    "\n",
    "plt.xlabel('memory size', fontsize=16)\n",
    "plt.ylabel('test ppl', fontsize=16)\n",
    "plt.xticks(rotation=0)\n",
    "plt.ylim(21, 40)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fontdict = {'fontsize': 18, 'font':'monospace'}\n",
    "\n",
    "# df = res_df[(res_df.n_layer == 16) & (res_df.tgt_len == 50)]\n",
    "# df['mem_size'] = df.mem_len + df.num_mem_tokens\n",
    "\n",
    "# mem_lens = np.unique(df.mem_size)\n",
    "# plot_df = pd.DataFrame(index = mem_lens)\n",
    "\n",
    "# plot_df['ppl_XL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == i)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-0'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 0)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-1'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 1)]['test ppl'].mean() for i in mem_lens]\n",
    "# plot_df['ppl_MT_bpd-2'] = [df[(df.num_mem_tokens == i) & (df.mem_len == 0) & (df.mem_backprop_depth == 2)]['test ppl'].mean() for i in mem_lens]\n",
    "\n",
    "# ax = plot_df.reset_index().iloc[:-2].plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.8)\n",
    "\n",
    "\n",
    "# for p in ax.patches:\n",
    "#     x = p.get_x()  # get the bottom left x corner of the bar\n",
    "#     w = p.get_width()  # get width of bar\n",
    "#     h = p.get_height()  # get height of bar\n",
    "#     min_y = z[h]['min']  # use h to get min from dict z\n",
    "#     max_y = z[h]['max']  # use h to get max from dict z\n",
    "#     plt.vlines(x+w/2, min_y, max_y, color='k')  # draw a vertical line\n",
    "\n",
    "# # plt.title('WT103: base')\n",
    "# plt.legend(['Transformer-XL', 'RMT', 'RMT BPTT-1', 'RMT BPTT-2'], fontsize=15)\n",
    "# plt.xlabel('memory size', fontsize=16)\n",
    "# plt.ylabel('test ppl', fontsize=16)\n",
    "# plt.xticks(rotation=0)\n",
    "# plt.ylim(21, 40)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 225,
   "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>ppl_XL</th>\n",
       "      <th>ppl_MT_bpd-0</th>\n",
       "      <th>ppl_MT_bpd-1</th>\n",
       "      <th>ppl_MT_bpd-2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>39.042</td>\n",
       "      <td>39.042</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>28.693</td>\n",
       "      <td>28.438</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>30.111</td>\n",
       "      <td>30.453</td>\n",
       "      <td>27.191</td>\n",
       "      <td>26.707</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>29.060</td>\n",
       "      <td>30.687</td>\n",
       "      <td>28.884</td>\n",
       "      <td>26.380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>27.631</td>\n",
       "      <td>29.751</td>\n",
       "      <td>26.322</td>\n",
       "      <td>27.308</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>26.550</td>\n",
       "      <td>29.748</td>\n",
       "      <td>26.030</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>25.654</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>200</th>\n",
       "      <td>25.136</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ppl_XL  ppl_MT_bpd-0  ppl_MT_bpd-1  ppl_MT_bpd-2\n",
       "0    39.042        39.042           NaN           NaN\n",
       "1       NaN           NaN        28.693        28.438\n",
       "5    30.111        30.453        27.191        26.707\n",
       "10   29.060        30.687        28.884        26.380\n",
       "25   27.631        29.751        26.322        27.308\n",
       "50   26.550        29.748        26.030           NaN\n",
       "100  25.654           NaN           NaN           NaN\n",
       "200  25.136           NaN           NaN           NaN"
      ]
     },
     "execution_count": 225,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AADa4rjW3AIAAAAA0Bm0OnNbr34GFwAAAACAziikmVsAAAAAADqzkMLthx9+qI0bNwZu//3vf9dFF12kpUuXqry8vMMGBwAAAABAKEIKt7///e9VWloqSXrvvfd03333aeTIkfrwww/1u9/9riPHBwAAAADAUYW05varr77SqFGjJEn/+9//dO6552rp0qX69NNP9bOf/axDBwgAAAAAwNGENHMbFRWlsrIySdLHH3+sGTNmSJKSkpIoSwYAAAAARFxIM7fTpk3TDTfcoBNPPFFffPGFpk2bJknasWOH0tLSOnSAAAAAAAAcTUgzt7feequmTJkit9utP/3pT0pKSpJU2yJo9uzZHTpAAAAAAACOJqSZ24SEBC1evLjJ8YULF7b7gAAAAAAAaCv63AIAAAAALC+kmVu/369//OMfeuaZZ7R37169+OKLSk9P1wMPPKATTzxR55xzTkePE8BR+E1TNV6/arx+eXx1X70Nvvrqb/tU4zNlM6Qop11RTruinXZFOW0NvrfL5bTJZhiRfloAAABASEIKtw8++KDWrl2rSy+9VHfddVfgeL9+/fTEE08QboF2ZJqmvH4zOJzWhdUjQdUXHFy9fnn95jE8Wk2rZ10OWyDsRjkbfn/ktstpl91GCAYAAEBkhRRuV69erbvvvluTJk3SPffcEzg+YcIE3X333R02OMDq/H6zwYxpwxlUXzMzqkdum8eSUzuAp25Mqmo9BDvttuDw67Irum4m+MjssE12GyshAAAA0DFCCrclJSXq06dPk+M1NTXy+XztPiigszFNU16f2aDctzacNgmmjUqCfcc0m3rsnHabnA6bXA6bnPa6r44GX+vOOx02+fym3DU+uWv8ctf4VF3jC7rt8fpDftwaX+1/i/Jqb6vXOexGkzLo5m47bIYMSqIBAADQBiGF2/Hjx+vpp5/WddddF3T8n//8pyZMmNAhAwM6iq++5NdXu/60+XWpTcuBwxlT7TYjOKg2CKb1t5uEV7utXQOh32/K7W0+/Aa+9/jkbkMI9vpMeX1eVRwlBNttRjOl0MFrgqOcdjnthGAAAADUCinc/vrXv9Yll1yijRs3qqamRnfffbd2796t4uJiPfbYYx08RKB5pmmqxmceCagtBNPG4TXcs6mNZ1GbC6pHrrHL6bB1ijWsNpuhGJdDMa7WrzNNU26vvy741oVfjy9w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4cKF2r17t7788sug6zZs2KD33ntPV155ZbiGBgAAAACwuIjtlnz48GFJCpqhPXTokG655RYtW7ZM5eXlkRoaAAAAAMBiIrKhVEVFhR555BGde+65gfYzkrRkyRKdd955yszMjMSwAAAAAAAWFfZw6/V6df311ys2NlZ33HFH4Pjq1au1e/du/exnPwv3kAAAAAAAFhfWsmS/36+bbrpJubm5evzxxxUXFxc49/7772vXrl2aOHGiJKm+/e63vvUtXXPNNbriiivCOVQAAAAAgIWEbebWNE3dcsstysnJ0T//+U8lJSUFnb/uuuu0Zs0arV69WqtXr9add94pSVqxYoXmz58frmFGxMyZM/Xee++F5bHy8/OVlZWlMWPG6Pvf/36L1y1ZskQPPfRQWMYEAAAAAMcrbDO3S5cu1YYNG7R8+XKZpqnCwkJJUs+ePeVyuZSamqrU1NTA9UVFRZKkgQMHKjExMVzD7PL69OmjTZs26bnnntPTTz/d4nW33357GEcFAAAAAMcnbOH2ySeflCTNmTMn6PjKlSuVnZ0drmEAAAAAALqgsJUl79ixo9k/LQXb7Oxs7dixQ3379g3XECPq3Xff1fTp03XqqafqueeekyS99dZbmjNnjrKysjR16lTdd999gbXIkrR8+XJNnz5dEyZM0Lx585Sfnx84t2PHDi1YsEAnnXSS5s6dq02bNoU0jv/+97/KyspSZmam7rvvvqBzzz33nC688EL9+te/VlZWli666CKVlJQc92MCAAAAwPGKWJ/bSHv66acDs8kd5cILLwx5vfDHH3+sV155Rbt379aPfvQjZWdnyzRN/eY3v9G4ceN04MABfe9739OYMWN05plnavfu3Xr44Ye1du1aDRgwQFu3bpXT6ZQklZeX6/LLL9c111yjxx57TO+8846uueYavf7664qJiWl1HKeffro2bdqkX//6182e37Jli37+85/r1ltv1YIFC/Tss8/qJz/5yXE9JgAAAAAcr4j0uUVTF154oeLj4zV27FiNHz9e77zzjk477TRNmjRJTqdT6enpys7O1vbt2yVJhmHI5/Np9+7d8vl8Gjt2bGCTrjfffFMpKSm68MILZbfbdeqppyopKUmffPLJcY9z0KBBmjZtmqKjozVlyhR9/fXXHf6YAAAAAHA03Xbmdv78+Z1qF+aGu0cnJyeruLhYn332me655x7t3LlTXq9X1dXVGjRokCRp8ODBuv322/Xwww/r2muv1YwZM/S73/1O8fHx2r9/v7788ktNmjQpcJ81NTWBTbyOR8+ePQPfO51Oud1uSerQxwQAAACAo+m24bazKS4uDvo+Oztb1113nX74wx/q0UcfldPp1MKFC4PW3M6bN0/z5s1TcXGxfvzjH+uZZ57RpZdeqn79+ik7O1srVqxo8fGcTqf8fn+7jT+UxwQAAACAjkJZcifx1FNPqby8XJ999pk2b96sGTNmqKKiQomJiXI4HNq4caPeeeedwPXffPONNmzYII/HI7vdLtM0FR8fL0k67bTT9MUXX+jll1+W1+tVZWWlXnvtNR06dCjw84MHD9auXbuCNoQ6HqE8JgAAAAB0FGZuO4mJEydq1qxZstvtuvXWW9WvXz8tXbpUd911l2699VbNmDFDp5xySuD6mpoa/elPf9KuXbvkcrl01llnBdosxcfH629/+5t+//vfa+nSpbLZbJo0aZKmTJkS+PnRo0dr7ty5+ta3viW/36/169crMTFRl112mTZt2iSPxyPDMLRy5UqdffbZ+sMf/tDq+EN5TAAAAADoKIbZsM7V4vLy8nTGGWdo3bp1SktLCzqXk5OjkSNHRmhkaA6/EwAAAABt0VrmoywZAAAAAGB5hFsAAAAAgOURbgEAAAAAlke4BQAAAABYXrcKt11o7yzL43cBAAAAoD11m3AbHR2t4uJiQlUnYJqmiouLFR0dHemhAAAAAOgiuk2f27S0NOXl5amwsDDSQ4FqP2xovHU3AAAAAByrbhNunU6nBg8eHOlhAAAAAAA6QLcpSwYAAAAAdF2EWwAAAACA5RFuAQAAAACW16XW3Pp8PknSgQMHIjwSAAAAAEB7q8969dmvoS4Vbut3Qr744osjPBIAAAAAQEcpLCxURkZG0DHD7EKNX6urq7V161b17t1bdrs90sMBAAAAALQjn8+nwsJCjR49WtHR0UHnulS4BQAAAAB0T2woBQAAAACwPMItAAAAAMDyCLcAAAAAAMsj3AIAAAAALI9wCwAAAACwPMItAAAAAMDyCLcAAAAAAMsj3AIAAAAALI9wG0Z//etfNWPGDI0dO1aXXnqpvvnmm0gPCV3cl19+qV/84hc644wzNHz4cC1btizofEFBga6++mqNHz9eU6ZM0d133y2fzxeh0aKrWr58uWbPnq2srCxNnTpV1113nfbt2xd0Da9FhMOyZct0zjnnaPz48Zo8ebKuuuoq7dq1K3Ce1yHC7W9/+5uGDx+uv/zlL4FjvA4RDr/+9a81fPjwoD+//OUvA+et+jp0RHoA3cXTTz+tZcuW6fe//72GDh2qu+++Wz/96U+1Zs0aORz8GtAxKioq1LdvX5155pm65557mpy/9tprVV1drVWrVqmgoEA33HCD4uPjdfXVV0dgtOiqNm3apMsvv1yjR49WWVmZli5dqssvvzzo7z9eiwiH9PR0LV68WGlpaaqurtaDDz6oyy67TK+//rpcLhevQ4TVtm3b9MILL6h3795Bx3kdIlwmTZqkP//5z4Hb0dHRge8t+zo0ERZz5swxf/Ob3wRu79271xw2bJj55ptvRnBU6E7OPPNM84EHHgjczsnJMYcNG2Z+8skngWPLli0zp02bZvr9/kgMEd3Ea6+9Zg4bNszMyckxTZPXIiKn/rWXk5PD6xBhVVVVZZ577rnmxx9/bJ5++unmQw89ZJomfx8ifG666SbzkksuafaclV+HlCWHgcfj0Y4dO3TSSScFjvXv319paWnasmVLBEeG7mzLli2KiorSuHHjAseys7NVWFjYpGQUaE+HDx+WJCUkJEjitYjIKC8v11NPPaXExMTAv8e8DhEud911l6ZNm6YJEyYEHed1iHDasmWLpk2bprPOOku33XZb4N9nK78OCbdhcPDgQfn9fiUlJemuu+7SGWecoaqqKiUlJam4uDjSw0M3VVxcrJ49e8rtdmvmzJm6++67lZSUFDgHdISKigo98sgjOvfcczVgwABJvBYRXhs3blRWVpYmTpyod999V6tWrVJ8fDyvQ4TNm2++qffeey9ofWM9XocIl1NOOUX33nuvHn30UV177bV66623tHDhQknWfh2y2DPMEhMT1b9/f9nt9kgPBZAk2e129evXT8nJyZEeCro4r9er66+/XrGxsbrjjjuanOe1iHAYN26cVq9ercLCQv3973/XokWLtHLlysB5XofoSCUlJVq8eLH+/Oc/B61vbIzXITraOeecE/h++PDhSk1N1cUXX6ycnJzAcSu+Dgm3YZCYmCibzaaSkhJdccUVuuKKKyTV/gVnpRcLupbk5GQdOnRIDodDq1atkiR9+OGHgXNAe/L7/brpppuUm5urxx9/XHFxcYFz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fP3kJz/RunXr2hRu3333XT300EN69NFHAyXK9YYOHSrTNHXo0CFNmDChzWMDAKCt2FAKAIAQXXzxxSopKdGiRYu0fft2ffnll3r66ad1//33h3wfF154oZ5++mm98sor2rVrl2677TY5HA6dddZZbRrLmWeeKbfbrX/961+aM2dOW5+Kfve73+ntt99Wbm6u3n//fX3++ecaNmxY4HxpaakKCwt16NAhSVJJSYkKCwsDG18VFBTouuuu04IFCzR48GAVFhYGnU9PT9fs2bN1880366233lJubq7+97//6frrr1d5eXmbxwsAwNEwcwsAQIiSkpL02GOP6Y9//KO+//3vy2azaejQoVqwYEHI9zF//nzt379fd955p0pLSzVixAg9/PDDio+Pb9NYoqKi9O1vf1svvfSSZs6c2danIr/fr9tvv10HDhxQr1699J3vfEeXX3554Pw111yjDz74IHC7fkZ34cKFuuaaa/TVV1+ptLRUjz76aGA36YbnJem2227Tfffdp1tuuUWlpaXq37+/pk+fLpfL1ebxAgBwNIZ5LIuAAABAxF155ZXq3bu37rjjjkgPBQCAiGPmFgAAizl06JA+/PBDvfXWW3rqqaciPRwAADoFwi0AABZz/vnn69ChQ/rlL3+pMWPGRHo4AAB0CpQlAwAAAAAsj92SAQAAAACWR7gFAAAAAFge4RYAAAAAYHmEWwAAAACA5RFuAQAAAACWR7gFAAAAAFje/wfeaGcL/0rrUQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fontdict = {'fontsize': 14}\n",
    "plot_df.reset_index().iloc[:-2].plot(x='index', figsize=(16, 8), linewidth=3)\n",
    "plt.plot(plot_df.index[:-2], plot_df.ppl_XL[0] * np.ones_like(plot_df.index[:-2]), c='k')\n",
    "plt.legend([ 'tr-XL', 'MT', 'MT bpd-1', 'MT bpd-2', 'baseline',], fontsize=12)\n",
    "plt.xlabel('memory size', fontdict=fontdict)\n",
    "plt.ylabel('test ppl', fontdict=fontdict)\n",
    "plt.ylim(23, 40)\n",
    "# plt.ylim(20, 40)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "['ppl_XL, ppl_MT_bpd-0']",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-45-92e90eb436b8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mplot_df\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdropna\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msubset\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'ppl_XL, ppl_MT_bpd-0'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfillna\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/envs/cudaenv/lib/python3.9/site-packages/pandas/util/_decorators.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    309\u001b[0m                     \u001b[0mstacklevel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstacklevel\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    310\u001b[0m                 )\n\u001b[0;32m--> 311\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    312\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    313\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/cudaenv/lib/python3.9/site-packages/pandas/core/frame.py\u001b[0m in \u001b[0;36mdropna\u001b[0;34m(self, axis, how, thresh, subset, inplace)\u001b[0m\n\u001b[1;32m   5946\u001b[0m             \u001b[0mcheck\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mindices\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5947\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mcheck\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0many\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 5948\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mKeyError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompress\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcheck\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msubset\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   5949\u001b[0m             \u001b[0magg_obj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtake\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindices\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0magg_axis\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5950\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: ['ppl_XL, ppl_MT_bpd-0']"
     ]
    }
   ],
   "source": [
    "plot_df.dropna(subset=['ppl_XL, ppl_MT_bpd-0']).fillna(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='mem_size'>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAEQCAYAAACp7S9lAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAXp0lEQVR4nO3dfbRddX3n8fc3kJLy0IDhNgIhXiyIungIrGsqg9Mx4EOQFHQNpaUDglqDS2lldIDguMSutmuFxRSQZYWJgoRReZBWcYDaIIZBWzUmISbRxCahsZOA5MqDPDigwHf+ODvxenNO7tn7PNy7k/drrbPuOXv/9v59f/vc87n77rPPPpGZSJLqZ9J4FyBJqsYAl6SaMsAlqaYMcEmqKQNckmrKAJekmtq7n50dfPDBOTg42M8uJan2VqxY8bPMHBg9ve0Aj4i9gOXA1sycFxFHALcB04AVwHmZ+ctdrWNwcJDly5eXq1yS9nAR8ZNm08scQvkwsG7E4yuBazLzSOBJ4H3Vy5MkldVWgEfEDOB04HPF4wBOAe4smiwG3tmD+iRJLbS7B34tcCnwcvF4GvBUZr5YPN4CHNbd0iRJuzLmMfCImAdsy8wVEfHmsh1ExHxgPsDMmTPLLi5pN/GrX/2KLVu28Pzzz493KRPWlClTmDFjBpMnT26rfTtvYp4MnBER7wCmAL8DfAo4MCL2LvbCZwBbmy2cmYuARQBDQ0NeOUvaQ23ZsoUDDjiAwcFBGkdhNVJm8vjjj7NlyxaOOOKItpYZ8xBKZl6emTMycxD4E+CbmflfgKXAWUWz84G7qpUtaU/w/PPPM23aNMO7hYhg2rRppf5D6eSDPJcBH4mIjTSOid/Ywbok7QEM710ru31KBXhmPpCZ84r7D2fm7Mw8MjP/KDNfKNWzJPXRU089xWc+85nKy1977bX84he/6EotDzzwAPPmzet4PX39JKZUd4ML7mk6ffPC0/tcSf212pZVjfUcbA/wD37wg5XWf+2113Luueey7777Vlq+F7wWiqQ9woIFC9i0aROzZs3ikksuAeCqq67iDW94A8cddxxXXHEFAM899xynn346xx9/PMcccwy333471113HY888ghz5sxhzpw5O617cHCQSy+9lGOPPZbZs2ezceNGAC644AI+8IEPMDQ0xGte8xruvvvuro7JPXBJe4SFCxeydu1aVq1aBcCSJUvYsGEDy5YtIzM544wzePDBBxkeHubQQw/lnnsa/yH8/Oc/Z+rUqVx99dUsXbqUgw8+uOn6p06dypo1a7jlllu4+OKLd4T15s2bWbZsGZs2bWLOnDk7wr0b3AOXtEdasmQJS5Ys4YQTTuDEE09k/fr1bNiwgWOPPZb77ruPyy67jG9961tMnTq1rfWdc845O35+5zvf2TH97LPPZtKkSRx11FG8+tWvZv369V0bg3vgkvZImcnll1/OhRdeuNO8lStXcu+99/Lxj3+cU089lU984hNjrm/kGSSt7jd73An3wCXtEQ444ACeeeaZHY/f/va3c9NNN/Hss88CsHXrVrZt28YjjzzCvvvuy7nnnssll1zCypUrmy4/2u23377j50knnbRj+pe//GVefvllNm3axMMPP8zRRx/dtTG5By5pjzBt2jROPvlkjjnmGE477TSuuuoq1q1btyNs999/f77whS+wceNGLrnkEiZNmsTkyZO5/vrrAZg/fz5z587l0EMPZenSpTut/8knn+S4445jn3324dZbb90xfebMmcyePZunn36aG264gSlTpnRtTJHZv0+3Dw0NpdcDV515GmF169at43Wve914l9ET27/rYPQbnBdccAHz5s3jrLPOarHkzpptp4hYkZlDo9t6CEWSaspDKJLUoc2bNzedfvPNN/e0X/fAJammDHBJfdPP99zqqOz2McAl9cWUKVN4/PHHDfEWtl8PvMxZKh4Dl9QXM2bMYMuWLQwPD493KRPW9m/kaZcBLqkvJk+e3PY3zag9HkKRpJoywCWppgxwSaqpMQM8IqZExLKI+EFE/DAi/rKYfnNE/FtErCpus3perSRph3bexHwBOCUzn42IycC3I+Ifi3mXZOadvStPktTKmAGejZM2ny0eTi5unsgpSeOsrWPgEbFXRKwCtgH3Zeb3ill/ExGrI+KaiNinxbLzI2J5RCz3/E9J6p62AjwzX8rMWcAMYHZEHANcDrwWeAPwCuCyFssuysyhzBwaGBjoTtWSpHJnoWTmU8BSYG5mPpoNLwCfB2b3oD5JUgvtnIUyEBEHFvd/G3grsD4iDimmBfBOYG3vypQkjdbOWSiHAIsjYi8agX9HZt4dEd+MiAEggFXAB3pXpiRptHbOQlkNnNBk+ik9qUiS1BY/iSlJNWWAS1JNGeCSVFMGuCTV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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df.plot(x='mem_size', y=['test ppl'], kind='bar')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "gb = df[df.num_mem_tokens > 0].groupby(['mem_size', 'mem_backprop_depth']).mean()['test ppl']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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>mem_size</th>\n",
       "      <th>mem_backprop_depth</th>\n",
       "      <th>test ppl</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>28.693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>2.0</td>\n",
       "      <td>28.438</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>3.0</td>\n",
       "      <td>28.374</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>30.453</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>27.191</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>26.707</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>26.565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>5</td>\n",
       "      <td>4.0</td>\n",
       "      <td>26.662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>10</td>\n",
       "      <td>0.0</td>\n",
       "      <td>30.687</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>1.0</td>\n",
       "      <td>28.884</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>10</td>\n",
       "      <td>2.0</td>\n",
       "      <td>26.380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>10</td>\n",
       "      <td>3.0</td>\n",
       "      <td>26.366</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>10</td>\n",
       "      <td>4.0</td>\n",
       "      <td>26.071</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>25</td>\n",
       "      <td>0.0</td>\n",
       "      <td>29.751</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>25</td>\n",
       "      <td>1.0</td>\n",
       "      <td>26.322</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>25</td>\n",
       "      <td>2.0</td>\n",
       "      <td>27.308</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>25</td>\n",
       "      <td>3.0</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>50</td>\n",
       "      <td>0.0</td>\n",
       "      <td>29.748</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>50</td>\n",
       "      <td>1.0</td>\n",
       "      <td>26.030</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    mem_size  mem_backprop_depth  test ppl\n",
       "0          1                 1.0    28.693\n",
       "1          1                 2.0    28.438\n",
       "2          1                 3.0    28.374\n",
       "3          5                 0.0    30.453\n",
       "4          5                 1.0    27.191\n",
       "5          5                 2.0    26.707\n",
       "6          5                 3.0    26.565\n",
       "7          5                 4.0    26.662\n",
       "8         10                 0.0    30.687\n",
       "9         10                 1.0    28.884\n",
       "10        10                 2.0    26.380\n",
       "11        10                 3.0    26.366\n",
       "12        10                 4.0    26.071\n",
       "13        25                 0.0    29.751\n",
       "14        25                 1.0    26.322\n",
       "15        25                 2.0    27.308\n",
       "16        25                 3.0       NaN\n",
       "17        50                 0.0    29.748\n",
       "18        50                 1.0    26.030"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gb.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_ = mt_base[mt_base.num_mem_tokens != 50]\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103. Memory Transformer - base')\n",
    "\n",
    "num_mems = np.unique(df_.num_mem_tokens)\n",
    "for num_mem in num_mems:\n",
    "    slice = df_[df_.num_mem_tokens == num_mem].sort_values('effective context')\n",
    "    # plt.plot(slice['effective context'], slice['test ppl'])\n",
    "    slice.groupby('effective context').mean()['test ppl'].plot()\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'{m} mem' for m in num_mems])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1440x720 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# df_ = mt_base\n",
    "# context_sizes = np.unique(df_.tgt_len)\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "\n",
    "# fig, axs = plt.subplots(len(context_sizes), len(bpds), figsize=(20, 10))\n",
    "\n",
    "# for i, context_size in enumerate(context_sizes):\n",
    "#     axs[i, 0].set_ylabel('ppl')\n",
    "#     for j, bpd in enumerate(bpds):\n",
    "#         df = df_[(df_.tgt_len == context_size) & (df_.mem_backprop_depth == bpd)]\n",
    "#         axs[i, j].scatter(df.num_mem_tokens, df['test ppl'])\n",
    "#         axs[i, j].set_title(f'tgt {context_size}, bpd {bpd}')\n",
    "\n",
    "# axs[-1, 0].set_xlabel('num mem')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "    plt.figure(figsize=(10, 5))\n",
    "    plt.scatter(df['num_mem_tokens'], df['test ppl'])\n",
    "\n",
    "    plt.title(f\"Tgt len {context_size}\")\n",
    "    plt.xlabel('num_mem_tokens')\n",
    "    plt.ylabel('ppl')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = mt_base\n",
    "plt.figure(figsize=(10, 5))\n",
    "plt.scatter(df_['effective context'], df_['test ppl'])\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAl4AAAE9CAYAAADaqWzvAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAci0lEQVR4nO3df5RfdX3n8derk0EGZBmBrJsMwSC4YWmjGZkl2NhdpavBH4edRVRSqdTD2VTbeqiVQdOT0xY2FjjTinq6y5EFhS02gBjGllojK6Fqe4jOMCETSKeLgIQJSooM1jrLhuG9f3zvjJOc78x8v5ncz733O8/HOd+T7/3ce7/3PR+Gb165n8+91xEhAAAA5O8Xii4AAABgsSB4AQAAJELwAgAASITgBQAAkAjBCwAAIBGCFwAAQCJLii6gEaecckqsXLmy6DIAAADmNTQ09E8RsbTeukoEr5UrV2pwcLDoMgAAAOZl+wezrWOoEQAAIBGCFwAAQCIELwAAgEQIXgAAAIkQvAAAABIheAEAACRC8AIAAEikEvfxAspgYHhM/dtHtX98Qss7O9S3fpV6u7uKLgsAUCEEL6ABA8Nj2rRtRBMHJyVJY+MT2rRtRJIIXwCAhjHUCDSgf/vodOiaMnFwUv3bRwuqCABQRQQvoAH7xyeaagcAoB6CF9CA5Z0dTbUDAFAPwQtoQN/6VepobzukraO9TX3rVxVUEQCgiphcDzRgagI9VzUCABaC4AU0qLe7i6AFAFgQhhoBAAASyT142W6zPWz73mz5VttP2N6VvdbkXQMAAEAZpBhqvELSXkn/akZbX0TcneDYAAAApZHrGS/bp0p6l6Sb8zwOAABAFeQ91PgZSVdJevmw9k/Z3m37BtuvyLkGAACAUsgteNl+t6RnI2LosFWbJJ0l6d9LOknSJ2bZf6PtQduDBw4cyKtMAACAZPI847VO0oW2n5R0h6Tzbd8eEc9EzYuSvijp3Ho7R8RNEdETET1Lly7NsUwAAIA0cgteEbEpIk6NiJWSLpF0f0RcanuZJNm2pF5Je/KqAQAAoEyKuIHql2wvlWRJuyR9uIAaAAAAkksSvCLiAUkPZO/PT3FMAACAsuHO9QAAAIkQvAAAABIheAEAACRC8AIAAEiE4AUAAJAIwQsAACARghcAAEAiBC8AAIBECF4AAACJELwAAAASIXgBAAAkQvACAABIhOAFAACQCMELAAAgEYIXAABAIgQvAACARAheAAAAiRC8AAAAEiF4AQAAJELwAgAASITgBQAAkAjBCwAAIBGCFwAAQCIELwAAgEQIXgAAAIkQvAAAABIheAEAACRC8AIAAEiE4AUAAJAIwQsAACARghcAAEAiBC8AAIBECF4AAACJELwAAAASIXgBAAAkQvACAABIhOAFAACQCMELAAAgEYIXAABAIgQvAACARAheAAAAiRC8AAAAEiF4AQAAJELwAgAASITgBQAAkAjBCwAAIBGCFwAAQCIELwAAgEQIXgAAAInkHrxst9ketn1vtny67Z22H7N9p+1j8q4BAACgDFKc8bpC0t4Zy9dLuiEizpT0vKTLE9QAAABQuFyDl+1TJb1L0s3ZsiWdL+nubJPbJPXmWQMAAEBZ5H3G6zOSrpL0crZ8sqTxiHgpW35aUlfONQAAAJRCbsHL9rslPRsRQ0e4/0bbg7YHDxw4cJSrAwAASC/PM17rJF1o+0lJd6g2xPhZSZ22l2TbnCpprN7OEXFTRPRERM/SpUtzLBMAACCN3IJXRGyKiFMjYqWkSyTdHxEfkLRD0sXZZpdJ+mpeNQAAAJTJkvk3Oeo+IekO21skDUu6pYAaAKDlbB4Y0dad+zQZoTZbG9au0Jbe1UWXBWCGJMErIh6Q9ED2/nFJ56Y4LgAsFpsHRnT7g09NL09GTC8TvoDy4M71ANACtu7c11Q7gGIQvACgBUxGNNUOoBgELwBoAW12U+0AikHwAoAWsGHtiqbaARSjiKsaAQBH2dQEeq5qBMrNUYHx/56enhgcHCy6DAAAgHnZHoqInnrrGGoEAABIhOAFAACQCMELAAAgEYIXAABAIgQvAACARAheAAAAiRC8AAAAEiF4AQAAJELwAgAASITgBQAAkAjBCwAAIBGCFwAAQCJLii4AAHB0bB4Y0dad+zQZoTZbG9au0Jbe1UWXBWAGghcAtIDNAyO6/cGnppcnI6aXCV9AeTDUCAAtYOvOfU21AygGwQsAWsBkRFPtAIpB8AKAFtBmN9UOoBgELwBoARvWrmiqHUAxmFwPAC1gagI9VzUC5eaowPh/T09PDA4OFl0GAADAvGwPRURPvXUMNQIAACRC8AIAAEiE4AUAAJAIwQsAACARghcAAEAiBC8AAIBECF4AAACJELwAAAASIXgBAAAkQvACAABIhOAFAACQCMELAAAgEYIXAABAIgQvAACARAheAAAAiRC8AAAAEiF4AQAAJELwAgAASITgBQAAkAjBCwAAIJElc620/XtzrY+ITx/dcgAAAFrXnMFL0glJqgAAAFgE5gxeEXF1qkKweAwMj6l/+6j2j09oeWeH+tavUm93V9FlAQCQu4bmeNl+re2/sn3A9rO2v2r7tXkXh9YzMDymTdtGNDY+oZA0Nj6hTdtGNDA8VnRpAADkrtHJ9X8h6S5JyyQtl/RlSVvn2sH2sba/a/th24/Yvjprv9X2E7Z3Za81C6gfFdO/fVQTBycPaZs4OKn+7aMFVQQAQDrzzfGaclxE/PmM5dtt982zz4uSzo+In9pul/Qd23+TreuLiLubLRbVt398oql2AABaSaNnvP7G9ibbK22/xvZVkr5m+yTbJ9XbIWp+mi22Z684CjWjwpZ3djTVDgBAK2k0eL1P0kZJ90vaIekjki6RNCRpcLadbLfZ3iXpWUn3RcTObNWnbO+2fYPtV8yy70bbg7YHDxw40GCZKLu+9avU0d52SFtHe5v61q8qqCIAANJxxPwnoWx3SPotSW9W7azVtyXdGBH/t6GD2J2S7pH0UUnPSfqhpGMk3STp+xFxzVz79/T0xODgrPkOFcNVjQCAVmZ7KCJ66q1rdI7XbZJ+Iulz2fKvSfpfqp0Jm1dEjNveIemCiPiTrPlF21+UdGWDNaBF9HZ3EbQAAItSo8HrlyLi7BnLO2w/OtcOtpdKOpiFrg5Jb5N0ve1lEfGMbUvqlbTnSAoHAAComkaD10O2z4uIByXJ9lrNMbcrs0zSbbbbVJtLdldE3Gv7/iyUWdIuSR8+stIBAACqpdHgdY6kv7f9VLZ8mqRR2yOqXcD4+sN3iIjdkrrrtJ9/pMUCAABUWaPB64JcqwAAAFgEGgpeEfGDvAsBAABodY3exwsAAAALRPACAABIhOAFAACQSKOT6wEAJbd5YERbd+7TZITabG1Yu0JbelcXXRaAGQheANACNg+M6PYHn5penoyYXiZ8AeXBUCMAtICtO/c11Q6gGAQvAGgBkxFNtQMoBsELAFqAm2wHUAyCFwC0gNnOa3G+CygXghcAAEAiBC8AaAFtrj+oOFs7gGIQvACgBWxYu6KpdgDFIHgBQAvY0rta68446ZC2dWecxD28gJIheAFACxgYHtNDT71wSNtDT72ggeGxgioCUA/BCwBaQP/2UU0cnDykbeLgpPq3jxZUEYB6CF4A0AL2j0801Q6gGAQvAGgByzs7mmoHUAyCFwC0gL71q9TR3nZIW0d7m/rWryqoIgD1ELwAoAX0dnfpPed0Td+3q83We87pUm93V8GVAZiJ4AUALWBgeExfGRqbfij2ZIS+MjTGVY1AyRC8AKAFcFUjUA0ELwBoAVzVCFQDwQsAWgBXNQLVQPACgBbAVY1ANSwpugAAwMJNXb3Yv31U+8cntLyzQ33rV3FVI1AyBC8AaBG93dw+Aig7hhoBAAASIXgBAAAkQvACAABIhOAFAACQCMELAAAgEYIXAABAIgQvAACARAheAAAAiRC8AAAAEiF4AQAAJELwAgAASITgBQAAkAjBCwAAIBGCFwAAQCJLii6gaJsHRrR15z5NRqjN1oa1K7Sld3XRZQEAgBa0qIPX5oER3f7gU9PLkxHTy4QvAABwtC3qocatO/c11Q4AALAQizp4TUY01Q4AALAQizp42c21AwAALMSiDl4dS+r/+LO1AwAALMSiThgTB19uqh0AAGAhcgteto+1/V3bD9t+xPbVWfvptnfafsz2nbaPyauG+Szv7GiqHQAAYCHyPOP1oqTzI+INktZIusD2eZKul3RDRJwp6XlJl+dYw5z61q9SR3vbIW0d7W3qW7+qoIoAAEAry+0+XhERkn6aLbZnr5B0vqRfy9pvk/RHkm7Mq4659HZ3SZL6t49q//iElnd2qG/9qul2AMUZGB7j/00ALSfXG6jabpM0JOlMSf9d0vcljUfES9kmT0sq9Ju0t7uLL3OgZAaGx7Rp24gmDk5KksbGJ7Rp24gk8f8rgErLNXhFxKSkNbY7Jd0j6axG97W9UdJGSTrttNNyqU/ikUFFoM8xn/7to9Oha8rEwUn1bx8leAGotCRXNUbEuKQdkt4kqdP2VOA7VdLYLPvcFBE9EdGzdOnSXOqaemTQ1A1Tpx4ZtHlgJJfjgT5HY/aPTzTVDgBVkedVjUuzM12y3SHpbZL2qhbALs42u0zSV/OqYT48Mig9+hyN4IpjAK0qzzNeyyTtsL1b0vck3RcR90r6hKTfs/2YpJMl3ZJjDXPikUHp0edoBFccA2hVeV7VuFtSd532xyWdm9dxm9Fm1/0Lv41nBuWGPkcjuOIYQKvKdXJ92W1Yu0K3P/hU3Xbkgz5Ho7jiGEArWtTBa+pKOq6wS4c+BwAsZo4KzK3p6emJwcHBossAAACYl+2hiOipt25RPyQbAAAgJYIXAABAIot6jleV8Rw7AACqh+BVQTzHDgCAamKosYLmeo4dAAAoL4JXBY3N8ry62doBAEA5ELwqaLa7vHP3dwAAyo05XhVU9ecdbh4Y4QaqAIBFieBVQV2dHXWHFbs6OwqopjmbB0YOeWTQZMT0ctnDF4ERALBQDDVWUN/6VepobzukraO9TX3rVxVUUeO27tzXVHtZTAXGqbOKU4Fx88BIwZUBAKqE4FVBvd1duvai1erq7JBVO9N17UWrK3EriaoOk1Y1MAIAyoWhxorq7e6qRNA6XJtdN2SV/cKAqgZGAEC5cMYLSW1Yu6Kp9rLgSlIAwNFA8EJSW3pX69LzTpsOLG22Lj3vtNJPUq9qYAQAlIujAkMlPT09MTg4WHQZWOS4qhEA0AjbQxHRU3cdwQsAAODomSt4MdQIAACQCMELAAAgEYIXAABAIgQvAACARLiBKpLj6kAAwGJF8EJSVX5INgAAC8VQY0UNDI9p3XX36/RP/rXWXXe/BobHii6pITzzEACwmHHGq4IGhse0aduIJg5OSpLGxie0aduIJJX++Y088xAAsJhxxquC+rePToeuKRMHJ9W/fbSgiho326MNeeQhAGAxIHhV0P7xiabay6RjSf1fudnaAQBoJfxtV0HLOzuaai+TiYMvN9UOAEArIXhVUN/6VepobzukraO9TX3rVxVUUeNO7Ghvqh0AgFbC5PoKmppA3799VPvHJ7S8s0N961eVfmK9JB2crH9ma7Z2LNzA8Fglf1cAoBURvCqqt7urkn95/sv/m2yqvUyqGGCqfAUsALQihhqBBkwFmLHxCYV+HmDKfv+0Kl8BCwCtiOCFpDpnmcs1W3tZVDXAVPkKWABoRQSviqrqnet/cfkJTbWXxdgsQWW29rKo8hWwANCKCF4VVNVhL0l68PHnm2ovi7ZZ7vA6W3tZVPkKWABoRQSvCqrqsJdU3UcGVbXu3u4uXXvRanV1dsiSujo7dO1Fq5lYDwAFIXhVUJXn7VT1zFHXLENzs7UDAFAPwauCqnwT0g1rVzTVXhZVHbKr8rA0ALQiglcFVflB01t6V+vS806bPsPVZuvS807Tlt7VBVc2t6oO2VV5WBoAWhE3UK2g8Z8dbKq9bLb0ri590KqnijetrfKwNAC0Is54VRC3CECj+F0BgHIheFVQVecbIT1+VwCgXBhqrKAqPyQbafG7AgDl4ij5fYgkqaenJwYHB4suAwAAYF62hyKip946hhoBAAASYagRQCkNDI8xRAqg5RC8AJTO1I1fp+5BNnXjV0mELwCVxlAjgNLhxq8AWlVuwcv2Cts7bD9q+xHbV2Ttf2R7zPau7PXOvGoAUE3c+BXA0TYwPKZ1192v0z/511p33f2FPTotz6HGlyR9PCIesn2CpCHb92XrboiIP8nx2AAqbHlnh8bqhCxu/ArgSJRp+kJuZ7wi4pmIeCh7/8+S9kpicgaAeb31rKVNtQPAXMo0fSHJHC/bKyV1S9qZNf2O7d22v2D7VbPss9H2oO3BAwcOpCgTQEns+If6/8/P1g4AcynT9IXcg5ftV0r6iqTfjYifSLpR0hmS1kh6RtKf1tsvIm6KiJ6I6Fm6lH/lAotJmb4kUW5lmbeDcivTc2tzDV6221ULXV+KiG2SFBE/iojJiHhZ0v+UdG6eNQConjJ9SaK8pubtjI1PKPTzeTuELxyuTM+tzfOqRku6RdLeiPj0jPZlMzb7L5L25FUDgGoq05ckyqtM83ZQbr3dXbr2otXq6uyQJXV1dujai1YXcl/APK9qXCfp1yWN2N6Vtf2+pA2210gKSU9K+s0cawBQQTzcG41gSBrN6O3uKsV3SG7BKyK+I8l1Vn0tr2MCaB1l+ZJEeXHbEVQRd64HAFQSQ9KoIp7VCACoJIakUUUELwBAZTEkjaphqBEAACARghcAAEAiBC8AAIBECF4AAACJELwAAAASIXgBAAAkQvACAABIhOAFAACQiCOi6BrmZfuApB8UXUdJnSLpn4ouYpGhz9Oiv9Oiv9Oiv9NL0eeviYil9VZUInhhdrYHI6Kn6DoWE/o8Lfo7Lfo7Lfo7vaL7nKFGAACARAheAAAAiRC8qu+mogtYhOjztOjvtOjvtOjv9Artc+Z4AQAAJMIZLwAAgEQIXiVn+wu2n7W9Z0bbSbbvs/1/sj9flbXb9udsP2Z7t+03Fld5NdleYXuH7UdtP2L7iqydPs+B7WNtf9f2w1l/X521n257Z9avd9o+Jmt/Rbb8WLZ+ZaE/QEXZbrM9bPvebJn+zpHtJ22P2N5lezBr4zslJ7Y7bd9t+x9s77X9pjL1N8Gr/G6VdMFhbZ+U9M2IeJ2kb2bLkvQOSa/LXhsl3ZioxlbykqSPR8TZks6T9Nu2zxZ9npcXJZ0fEW+QtEbSBbbPk3S9pBsi4kxJz0u6PNv+cknPZ+03ZNuheVdI2jtjmf7O31sjYs2M2xjwnZKfz0r6ekScJekNqv2ul6e/I4JXyV+SVkraM2N5VNKy7P0ySaPZ+89L2lBvO15H3PdflfQ2+jxJXx8n6SFJa1W7ueGSrP1NkrZn77dLelP2fkm2nYuuvUovSaeq9hfP+ZLulWT6O/c+f1LSKYe18Z2ST1+fKOmJw39Py9TfnPGqpldHxDPZ+x9KenX2vkvSvhnbPZ214QhkwyrdknaKPs9NNuy1S9Kzku6T9H1J4xHxUrbJzD6d7u9s/QuSTk5acPV9RtJVkl7Olk8W/Z23kPQN20O2N2ZtfKfk43RJByR9MRtOv9n28SpRfxO8Ki5qEZ1LU48y26+U9BVJvxsRP5m5jj4/uiJiMiLWqHYm5lxJZxVbUeuy/W5Jz0bEUNG1LDJvjog3qjas9du2/8PMlXynHFVLJL1R0o0R0S3pX/TzYUVJxfc3wauafmR7mSRlfz6btY9JWjFju1OzNjTBdrtqoetLEbEta6bPcxYR45J2qDbU1Wl7SbZqZp9O93e2/kRJz6WttNLWSbrQ9pOS7lBtuPGzor9zFRFj2Z/PSrpHtX9g8J2Sj6clPR0RO7Plu1ULYqXpb4JXNf2lpMuy95epNg9pqv2D2VUa50l6YcapVTTAtiXdImlvRHx6xir6PAe2l9ruzN53qDafbq9qAezibLPD+3vqv8PFku7P/vWKBkTEpog4NSJWSrpEtf77gOjv3Ng+3vYJU+8lvV3SHvGdkouI+KGkfbZXZU2/KulRlai/uYFqydneKuktqj1N/UeS/lDSgKS7JJ0m6QeS3hcRP85Cw5+pdhXkzyR9KCIGCyi7smy/WdK3JY3o53Ngfl+1eV70+VFm+/WSbpPUpto/BO+KiGtsv1a1MzInSRqWdGlEvGj7WEl/rtrcux9LuiQiHi+m+mqz/RZJV0bEu+nv/GR9e0+2uETSX0TEp2yfLL5TcmF7jaSbJR0j6XFJH1L2/aIS9DfBCwAAIBGGGgEAABIheAEAACRC8AIAAEiE4AUAAJAIwQsAACARgheABbP9Xtt7be/Ilrfa3m37Y01+Tqft35qxvNz23Ue73iNle43tdy5g/97soeuNbt9j+3NHejwA5cPtJAAsmO2vS9oSEd+x/W8kfScizjyCz1kp6d6I+KWjXePRYPs3JPVExO8c4f63qvbzlSZMAkiLM14AGmb7Utvftb3L9uezB1z/gaQ3S7rFdr+kb0jqyrb5Fdtn2P569oDgb9s+K/usV9u+x/bD2euXJV0n6Yxs337bK23vybZ/0PYvzqjlgeyM0PG2v5DVNWz7P89S+ydsj2THui5rW5N97u6sllfN+Ozrs8/8x+znOEbSNZLen9X3/tmObfuzWb/I9nrb38p+vgsl9Wf7n3FYfe+1vSer71tZ21ts35u9/1q23y7bL9i+LOv/ftvfy36G3zw6/6UB5CYiePHixWvel6R/J+mvJLVny/9D0gez9w+odiZIklZK2jNjv29Kel32fq1qj52RpDtVewi5VLtz/Yl19p1elvQxSVdn75dJGs3e/7Fqd1qXpE5J/yjp+MNqf4ekv5d0XLZ8Uvbnbkn/MXt/jaTPzPh5/jR7/05J/zt7/xuS/mzG59Y9tqTjJD0i6a2SRiWdkW1zq6SLZ+nfEUldU5+V/fkW1c6QzdzunKzuEyVtlLQ5a3+FpEFJpxf9u8KLF6/ZX1MPRQWA+fyqan/pf6/2lA116OcPmq3L9isl/bKkL2f7SLWAINUe0PxBSYqISUkvTJ1xmsVdqp1N+0NJ71Pt4bdS7dl3F9q+Mls+VrXHguydse9/kvTFiPhZdrwf2z5RtYDzt9k2t0n68ox9ph6QPqRaAKyn7rEjYq/t/yrpW5I+FhHfn+PnmvJ3km61fdeMYx/C9imqPcLnfRHxgu23S3q97annLJ4o6XWSnmjgeAAKQPAC0ChLui0iNjWxzy9IGo+INQs9eESM2X7Otec7vl/Sh2fU9Z6IGF3oMQ7zYvbnpGb/rpzr2KslPSdpeSMHi4gP214r6V2Shmyfc8iB7DbVnqd4TUTsmXH8j0bE9kaOAaB4zPEC0KhvSrrY9r+WJNsn2X7NXDtExE8kPWH7vdk+tv2GGZ/3kay9LTsD9c+STpjjI++UdJWkEyNid9a2XdJHnZ1Ss91dZ7/7JH3I9nFTtUfEC5Ket/0r2Ta/Lulv6+w70+H11T121i8fV+3h0u/IAlW9/afZPiMidkbEH0g6IGnFYZtcJ2l3RNxx2PE/Yrs9+4x/a/v4eX4GAAUieAFoSEQ8KmmzpG/Y3q1amFnWwK4fkHS57YdVm/c0Nfn9CklvtT2i2nDe2RHxnKS/yyaZ99f5rLslXaLasOOU/yapXdJu249ky4fX/nVJfylp0PYuSVNDg5epNtl9t6Q1qs3zmssOSWdPTa6vd+wshN0i6cqI2C/pckk32z5WtTNWfdlE/DMO++z+bPL/HtXmoz182PorJb19xgT7CyXdLOlRSQ9l+31ejGQApcbtJAAAABLhjBcAAEAiBC8AAIBECF4AAACJELwAAAASIXgBAAAkQvACAABIhOAFAACQCMELAAAgkf8PBo48qMEV1fQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 5))\n",
    "plt.scatter(mt['effective context'], mt['test ppl'])\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_ = mt_base\n",
    "# plt.figure(figsize=(16, 8))\n",
    "# plt.title('Wt-103: base. Memory transformer')\n",
    "\n",
    "# bpds = np.unique(df_.mem_backprop_depth)\n",
    "# for bpd in bpds:\n",
    "#     slice = df_[df_.mem_backprop_depth == bpd]\n",
    "\n",
    "#     plt.scatter(slice['effective context'], slice['test ppl'])\n",
    "\n",
    "# plt.xlabel('effective context size')\n",
    "# plt.ylabel('ppl')\n",
    "# plt.legend([f'bpd-{int(b)}' for b in bpds])\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_[[col for col in df_.columns if df_[col].unique().shape[0] > 1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Qq1bt04LFy7Udddd50F1A0NgRUJt+6BW4faIiqbneV0KAAAAMCKccsopys/P32d7ZWWlLr74YknSxRdfrGXLlu1zzJ133qmKigotWrRIU6ZM0a233qobb7xRxxxzjObNm6ddu3ZJkqqrq7V48WIdd9xxWrBggd555x1J0bB8+eWXa968eZo2bZqeeuopXXLJJZo5c6aWLl064M+WPOArAAehpiooiQmXAAAAMPJc/9L1emfXO4N6zcPzD9e/Hf9v/Tp369atKioqkiQVFhZq69atPR735ptv6rXXXlNzc7OmT5+u66+/Xq+99pquvvpq3X333fra176myy67TLfddptmzJihF198UVdccYWefPJJSdLu3bv1/PPPa/ny5VqyZIlWrlyp22+/XXPnztXq1as1e/bsftUvEViRYIHqkMYUZiojJ9XrUgAAAIBRw8xkZj3uO+2005STk6OcnBz5/X6dd955kqSysjKtWbNG9fX1eu6553TBBRd0ntPS0tL5+rzzzpOZqaysTAUFBSorK5MkHXnkkdqwYQOBFcODizhtqQ6p9NgJXpcCAAAADLr+toTGS0FBgQKBgIqKihQIBDRhQs//H56Wltb52ufzdb73+Xxqb29XJBJRXl6eVq9evd/zu57b9fyBYAwrEmZXoEEtje0qYsIlAAAAIO6WLFmiu+66S5J01113qby8vF/Xyc3N1dSpU3XvvfdKkpxzev311wetzv0hsCJhatYFJUnFTLgEAAAADJpPf/rTmj9/vt59912VlJTojjvukCRdc801euyxxzRjxgw9/vjjuuaaa/p9j3vuuUd33HGHjj76aB155JGqrKwcrPL3y5xzCbnRQMyZM8etWrXK6zIwQI/e8ZZq3tuti687qdf+8wAAAMBwsnbtWs2cOdPrMoaVnn5mZvaKc25O92NpYUVCOOcUqAqqaHoeYRUAAABAnxBYkRB1u5pVv7uF9VcBAAAA9BmBFQkRqApJEhMuAQAAAOgzAisSIlAVVGp6ksZOzPa6FAAAAADDBIEVCVFTFVJhqV8+H+NXAQAAAPQNgRVx11zfpt2BBsavAgAAADgoBFbEXaA6KEkqZvwqAAAAMKg2btyo0047TUcccYSOPPJI3XTTTZ37fvCDH2jixImaPXu2Zs+erYceesjDSvsn2esCMPIFqkLyJZsmTMn1uhQAAABgRElO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6/pauYhj/CoAAACQAA0NDaqrq+t8/eijj2rWrFmSpCVLluiuu+6SJN11110qLy/v1z1yc3M1depU3XvvvZIk55xef/31Qaj+wAisGFSBqqDMpKJpfq9LAQAAAEa8rVu36uSTT9bRRx+t448/Xuecc44WL14sSbrmmmv02GOPacaMGXr88cd1zTXX9Ps+99xzj+644w4dffTROvLII1VZWTlYH2G/zDmXkBsNxJw5c1zX6ZkxdC37xWtqaWzTJ797vNelAAAAAHG3du1azZw50+syhpWefmZm9opzbk73Y2lhxaAJhyPauj5Ed2AAAAAAg4LAikGzY2O92lsjKiqlOzAAAACAgSOwYtAEqoKSpGJaWAEAAAAMAgIrBk2gKqTccenKyks78MEAAAAAcAAEVgwK55wC1UFaVwEAAAAMGgIrBkVwa6Oa6tqYcAkAAADAoCGwYlAEqkKSpKLpTLgEAAAAJMq7776r2bNnd37l5ubql7/8pSTpBz/4gSZOnNi576GHHvK22H5I9roAjAyBqqAyclKUV5DpdSkAAADAqHHYYYdp9erVkqRwOKyJEyfq/PPP79x/9dVX65vf/KZH1Q0cLawYFDVVQRWV5snMvC4FAAAAGJWeeOIJlZaWavLkyX0+56mnntKpp56q8vJyTZs2Tddcc43uueceHX/88SorK1N1dbUkafv27fr4xz+uuXPnau7cuVq5cqWkaCvuxRdfrAULFmjy5Mn6+9//rm9/+9sqKyvT4sWL1dbWNqDPRAsrBqwh2KLaHc0q+0iJ16UAAAAAnllx52+07YP3B/WaEyZP02lLL+vTsX/605/06U9/eq9tt956q+6++27NmTNHN9xwg8aMGbPPea+//rrWrl2r/Px8TZs2TZdeeqleeukl3XTTTbrlllv0y1/+UldddZWuvvpqnXzyyfrwww915plnau3atZKk6upqrVixQm+//bbmz5+vv/3tb/rZz36m888/Xw8++KAqKir6/flpYcWA1cTWXy0qzfO0DgAAAGC0am1t1fLly3XBBRd0brv88stVXV2t1atXq6ioSN/4xjd6PHfu3LkqKipSWlqaSktLdcYZZ0iSysrKtGHDBknS448/rq985SuaPXu2lixZotraWtXX10uSzjrrLKWkpKisrEzhcFiLFy/e5/z+ooUVAxaoDik51adxh2R7XQoAAADgmb62hMbDww8/rGOPPVYFBQWd27q+/uIXv6hzzz23x3PT0tI6X/t8vs73Pp9P7e3tkqRIJKIXXnhB6enpvZ7v8/mUkpLSOUyw6/n9RQsrBixQFVTBVL+SknicAAAAAC/88Y9/3Kc7cCAQ6Hx93333adasWf2+/hlnnKFbbrml833HRE/xRsLAgLQ0tWvnpnoVs5wNAAAA4ImGhgY99thj+tjHPrbX9o7Jj4466iitWLFCv/jFL/p9j5tvvlmrVq3SUUcdpSOOOEK33XbbQMvuE3POJeRGAzFnzhy3atUqr8tADz54a6ceuOV1LblqtibNzPe6HAAAACCh1q5dq5kzZ3pdxrDS08/MzF5xzs3pfiwtrBiQQFVQ5jMVTM31uhQAAAAAIwyBFQMSqApp/KRspaYzfxcAAACAwUVgRb+F2yLauqFWRdPzvC4FAAAAwAhEYEW/bfuwTuG2iIqYcAkAAACj2HCYF2ioONifFYEV/RaoCkqSikrzPK0DAAAA8Ep6erp27txJaO0D55x27tzZ41quvWHgIfotUB1SXkGmMnNTvS4FAAAA8ERJSYk2bdqk7du3e13KsJCenq6SkpI+H09gRb+4iFOgKqhpx4z3uhQAAADAMykpKZo6darXZYxYdAlGv+za0qCWxna6AwMAAACIGwIr+iVQFZIkFc9gwiUAAAAA8UFgRb8EqoLKzE1V7rgMr0sBAAAAMEIRWNEvNVVBFU3Pk5l5XQoAAACAEYrAioNWt6tZ9btaWH8VAAAAQFwRWHHQOtZfLZ6e52kdAAAAAEY2AisOWqAqpJT0JI0tyfa6FAAAAAAjGIEVB62mKqiiaX75fIxfBQAAABA/BFYclOaGNu2qaWD8KgAAAIC4I7DioGypjq6/WlSa520hAAAAAEY8AisOSqA6KF+SacLUXK9LAQAAADDCEVhxUGrWhTT+kBylpCZ5XQoAAACAEY7Aij5rbw1r2we1LGcDAAAAICEIrOizbR/UKhJ2TLgEAAAAICEIrOizmiomXAIAAACQOARW9FmgKqgxRVlKz07xuhQAAAAAowCBFX0SiThtqQ6pmO7AAAAAABKEwIo+2bm5Xq3NYRUx4RIAAACABCGwok8CHeNXaWEFAAAAkCAEVvRJoDqo7DFpyslP97oUAAAAAKMEgRUH5JxTYF1QRdPzZGZelwMAAABglCCw4oDqdjarIdSqolK6AwMAAABIHAIrDqimKihJKp6R52kdAAAAAEYXAisOKFAVUlpmsvKLsrwuBQAAAMAoQmDFAQWqgios9ct8jF8FAAAAkDgEVuxXU12rdm9pZPwqAAAAgIQjsGK/AtXR9VeLp+d5WwgAAACAUYfAiv0KVAWVlOzThMm5XpcCAAAAYJQhsGK/aqpCmjAlR0kpPCoAAAAAEosUgl61tYS148M6FdEdGAAAAIAHCKzo1db1IUUijgmXAAAAAHiCwIpeBapDkonACgAAAMATBFb0qmZdUGOLs5WWmeJ1KQAAAABGIQIrehQJR7Rlfa2Kp9O6CgAAAMAbBFb0aMemerW3hJlwCQAAAIBnCKzoUaAqJEkqooUVAAAAgEfiFljNLN3MXjKz183sLTP7YWz7PWb2rpm9aWa/NTMGSA5BNVVB5YxNV/aYdK9LAQAAADBKxbOFtUXS6c65oyXNlrTYzOZJukfS4ZLKJGVIujSONaAfnHMKVAVVTHdgAAAAAB5KjteFnXNOUn3sbUrsyznnHuo4xsxeklQSrxrQP6FtTWqqa6M7MAAAAABPxXUMq5klmdlqSdskPeace7HLvhRJn5P0SDxrwMGrqQpKEhMuAQAAAPBUXAOrcy7snJutaCvq8WY2q8vuX0t62jn3TE/nmtllZrbKzFZt3749nmWim0B1SOlZKRpTmOl1KQAAAABGsYTMEuycC0paIWmxJJnZf0gaL+nr+znnN865Oc65OePHj09EmYgJrAuqaLpfZuZ1KQAAAABGsXjOEjzezPJirzMkLZL0jpldKulMSZ92zkXidX/0T0OoRaHtTSoqzfO6FAAAAACjXNwmXZJUJOkuM0tSNBj/xTn3gJm1S/pA0vOxFry/O+d+FMc6cBA611+dwYRLAAAAALwVz1mC10g6poft8QzJGKBAdVDJKT6Nn5TjdSkAAAAARrmEjGHF8BGoCqlgWq6Sknk0AAAAAHiLVIJOrc3t2rGxjvGrAAAAAIYEAis6bXk/JOekYtZfBQAAADAEEFjRKVAVkplUMC3X61IAAAAAgMCKPQJVQY2blKPUdObFAgAAAOA9AiskSeH2iLaur1XRdJazAQAAADA0EFghSdr+YZ3a2yJMuAQAAABgyCCwQlJ0/KokWlgBAAAADBkEVkiSaqqC8o/PUJY/zetSAAAAAEASgRWSXMRpS3VIRTPyvC4FAAAAADoRWKHdWxrV3NCmolK6AwMAAAAYOgisUKA6KEkqnp7naR0AAAAA0BWBFaqpCiojJ0X+CRlelwIAAAAAnQisUKAqpOLpeTIzr0sBAAAAgE4E1lGufnez6nY2q4juwAAAAACGGALrKMf6qwAAAACGKgLrKBeoCiolLUnjSrK9LgUAAAAA9kJgHeVqqkIqnJYrXxKPAgAAAIChhZQyirU0tmlnTT3jVwEAAAAMSQTWUSxQHZKcCKwAAAAAhiQC6ygWqA7J5zMVTM31uhQAAAAA2AeBdRQLVAU1fnKOUlKTvC4FAAAAAPZBYB2l2tvC2rqhVkWlLGcDAAAAYGgisI5S2z6oU6TdMX4VAAAAwJBFYB2lAlVBSaKFFQAAAMCQRWAdpQJVIY0pzFRGTqrXpQAAAABAjwiso5CLOAWqQ3QHBgAAADCkEVhHoZ01DWptalfRdLoDAwAAABi6CKyjUMf41WJaWAEAAAAMYQTWUShQFVSWP1U5Y9O9LgUAAAAAekVgHWWcc6qpCqloRp7MzOtyAAAAAKBXBNZRpm5nsxqCLSoqzfO6FAAAAADYLwLrKBOoDkmSimcw4RIAAACAoY3AOsoEqoJKTU9SfnG216UAAAAAwH4RWEeZmqqQCkvz5PMxfhUAAADA0EZgHUWa69u0O9DA+qsAAAAAhgUC6ygSqA5KYv1VAAAAAMMDgXUUCVSF5Es2TZiS43UpAAAAAHBABNZRpKYqqILJuUpOSfK6FAAAAAA4IALrKNHWGtb2D+sYvwoAAABg2CCwjhLb1tcqEnYqYvwqAAAAgGGCwDpKBKqDkkmF02hhBQAAADA8EFhHiZqqkMYWZyk9K8XrUgAAAACgTwiso0AkHNGW6pCKSvO8LgUAAAAA+ozAOgrs3NygtpYwEy4BAAAAGFYIrKNATVVQkphwCQAAAMCwQmAdBQJVQWXnpyknP93rUgAAAACgzwisI5xzToGqkIppXQUAAAAwzBBYR7jQ9iY11rbSHRgAAADAsENgHeECVSFJYsIlAAAAAMMOgXWEC1QFlZaZrPzCLK9LAQAAAICDQmAd4QLVIRVNz5P5zOtSAAAAAOCgEFhHsMbaVgW3NqqolO7AAAAAAIYfAusIFqgOSpKKZ+R5WgcAAAAA9AeBdQQLVIWUlOLT+ENyvC4FAAAAAA4agXUEC1QFVTAlV0nJ/JoBAAAADD8kmRGqtbld2zfWs5wNAAAAgGGLwDpCbV1fKxdxKp6e53UpAAAAANAvBNYRKlAVlJlUOI0WVgAAAADDE4F1hKqpCmlsSbZSM5K9LgUAAAAA+oXAOgKFwxFtXR9SEd2BAQAAAAxjBNYRaMeH9WpvjTB+FQAAAMCwRmAdgQLVQUlSUSnjVwEAAAAMXwTWEahmXVC549KVlZfmdSkAAAAA0G8E1hHGOadAdYjuwAAAAACGPQLrCBPc2qjm+jYmXAIAAAAw7MUtsJpZupm9ZGavm9lbZvbD2PapZvaimVWZ2Z/NLDVeNYxGgaqQJKloOuNXAQAAAAxv+12k08y+vr/9zrkb97O7RdLpzrl6M0uR9KyZPSzp65J+4Zz7k5ndJukLkv77IOtGL2qqgsrISVFeQabXpQAAAADAgByohTXnAF+9clH1sbcpsS8n6XRJf41tv0tSRX8KR88CVUEVlebJzLwuBQAAAAAGZL8trM65Hw7k4maWJOkVSdMl/UpStaSgc649dsgmSRMHcg/s0RBsUe2OZpV9pMTrUgAAAABgwPo0htXMppnZ/Wa23cy2mVmlmU070HnOubBzbrakEknHSzq8r4WZ2WVmtsrMVm3fvr2vp41qNVVBSWLCJQAAAAAjQl8nXfo/SX+RVCSpWNK9kv7Y15s454KSVkiaLynPzDpadkskbe7lnN845+Y45+aMHz++r7ca1QJVISWn+jRuUrbXpQAAAADAgPU1sGY6537vnGuPff1BUvr+TjCz8WaWF3udIWmRpLWKBtdPxA67WFJlvyrHPgLVQRVO8yspidWKAAAAAAx/fU02D5vZtWY2xcwmm9m3JT1kZvlmlt/LOUWSVpjZGkkvS3rMOfeApH+T9HUzq5I0VtIdA/0QkFqa2rVzU72KSlnOBgAAAMDIsN9Jl7q4MPb9i7HvHVPQfkrRmX/3Gc/qnFsj6Zgetr+v6HhWDKIt74fknFQ0I8/rUgAAAABgUPQ1sB4h6QpJJysaUJ+R9N/OueZ4FYaDE6gKynymgim5XpcCAAAAAIOir4H1Lkm1km6Ovf8XSXdrT8srPBaoCmn8pGylpvf1VwoAAAAAQ1tf080s59wRXd6vMLO341EQDl64LaKtG2o16xSWtAUAAAAwcvR10qVXzWxexxszO0HSqviUhIO17cM6hdsiKmb9VQAAAAAjSF9bWI+T9JyZfRh7f4ikd83sDUnOOXdUXKpDnwSqgpKkQmYIBgAAADCC9DWwLo5rFRiQQFVQeQWZysxN9boUAAAAABg0fQqszrkP4l0I+sdFnALVIU07ZrzXpQAAAADAoOrrGFYMUbsCDWppbGf8KgAAAIARh8A6zAWqQ5KkoumMXwUAAAAwshBYh7madUFl5qYqd1yG16UAAAAAwKAisA5zgeqgiqbnycy8LgUAAAAABhWBdRir29Ws+l0tdAcGAAAAMCIRWIexjvVXmXAJAAAAwEhEYB3GaqpCSklP0tiSbK9LAQAAAIBBR2AdxgJVQRVN88vnY/wqAAAAgJGHwDpMNTe0aVdNA+NXAQAAAIxYBNZhakvn+qt53hYCAAAAAHFCYB2maqqC8iWZCqbkel0KAAAAAMQFgXWYClSFNGFyjpJTk7wuBQAAAADigsA6DLW3hrXtg1oVleZ5XQoAAAAAxA2BdRja9kGtImGnohl5XpcCAAAAAHFDYB2GaqpiEy5NY4ZgAAAAACMXgXUYClQFlV+cpfTsFK9LAQAAAIC4IbAOM5GI05bqkIpKaV0FAAAAMLIRWIeZnZvr1docZv1VAAAAACMegXWYCXSMX51OCysAAACAkY3AOswEqoLKHpOm3LEZXpcCAAAAAHFFYB1GnHMKVAXpDgwAAABgVCCwDiO1O5rVEGplwiUAAAAAowKBdRgJVAclScUz8jytAwAAAAASgcA6jATWBZWWmaz8oiyvSwEAAACAuCOwDiOB6pAKS/0yn3ldCgAAAADEHYF1mGiqa9XuLY2MXwUAAAAwahBYh4lAdXT91WJmCAYAAAAwShBYh4maqqCSkn2aMDnX61IAAAAAICEIrAPknNOKD1co4iJxvU+gKqQJU3KUlMKvDAAAAMDoQPoZoJU1K/XVFV/Vra/dGrd7tLWEtePDOhXRHRgAAADAKEJgHaCTik/Sx2d8XP/7xv/qb+/9LS732Lo+pEjEMX4VAAAAwKiS7HUBw52Z6bvzvqstDVv0/174fyrKKtKJE08c1HsEqkOSSYXTGL8KAAAAYPSghXUQpPhS9PNTf67SvFJ9/Z9f13u73xvU69esC2rsxGylZaYM6nUBAAAAYCgjsA6S7NRs/Wrhr5SVnKUrHr9C2xq3Dcp1I+GItqyvVTHrrwIAAAAYZQisg6gwq1C/+uivVNdapy8/8WU1tDUM+Jo7NtWrvSWsohl5Ay8QAAAAAIYRAusAtbSHVRNsUns4uqzN4fmH6+en/lzrdq/Tt/75LbVH2gd0/UBVSJJUVJo30FIBAAAAYFhh0qUBeidQp/JfrVSSz1SYm66JeRkqzsvWnOwv6JnNv9GV//gPXTX73zRxTIZy0g9+DGpNVVC549KVPSYtDtUDAAAAwNBFYB2gorx0/eT8WaoJNqkm2KzNwSat+mC3toRK5Rt7qp7Vcj3++3a17TpFOenJsUCb0fm9OC+98/WEnDQlJ+1p9HbOKVAV1CFHjPXwEwIAAACANwisAzQhJ12fOWHyPtvDEaettR/R9567Ri/rIVXMmqWMtmNUE2zS5mCzXvlgt0JNbXud09FKW5yXHg21ySnKqmtTbbZP726pU3Feer9aaQEAAABgODLnnNc1HNCcOXPcqlWrvC6jX5rbm3Xpo5fqnV3v6PYzbtfsCbM799W3tCsQbNLmWOtstJU29j7UpPytbTqjIUV35DRrV1L099S1lbYz2HZpte3eSgsAAAAAQ52ZveKcm7PPdgJr/O1q3qXPPvRZ1bfW656z79Gk3El9Ou/xO9/W+jU7dMxXZykQ6hpoY69DTQo27r+VtrgzzO55n0srLQAAAIAhpLfASpfgBMhPz9evF/5an334s7riiSv0+7N+r7z0vAOet6U6pIkz8jRnSn6vxzS0tCsQiobYzbub9mqlffXD3XpwTUDtkb3/USInLVkTx/TcSlucl6ECWmkBAAAADAEE1gSZ4p+im0+7WZc+eqmuWnGV/veM/1VqUmqvxzeEWhTa3qQjF0zc73Wz0pI1fUKOpk/I6XF/OOK0o74l1u24aa/JoTbvjoba7q20PlOslTajS7CllRYAAABAYhFYE+jYgmP1k5N/om8//W19b+X3dN2C6+SznlsyO9dfneEf0D2TfKaC3HQV5Kbr2EPG9HhM11bavcbRBpv02odBPfRGQG3hfVtpu7bQFudlqGQMrbQAAAAABg+BNcHOmnqWNtdv1k2v3qSS7BJ99div9nhcoCqo5BSfxk/queV0MB2olTbSpZV2c7dW2ppgk1ZvDGr3flppu7fQdrTa0koLAAAAYH8IrB74wqwvaFPdJv3vG/+rkpwSfWzGx/Y5JlAdUsG0XCUle99K6fOZJuSma0Juuo7ppZW2sbV9r5mOOyaH2hxs1OqNQT385v5baYvyMpSTlqzUZJ/Skn1KS07qfJ3a4/u9t3V9n5rsU5LPEvGjAQAAABBHBFYPmJm+O++7CjQE9KPnf6TCzEKdOPHEzv2tTe3asbFOx501xbsiD1JmarKmT8jW9AnZPe6P7DWWtnmvbsc1oSat2RRSQ2u7WtojGoyJq5N9tlfYTUvxKTXJt+f7fgJxWopPaUk+paUk7X1Oik+pSUl7h+YejklL2nM/H8EZAAAA6DcCq0dSfCm64dQbdNEjF+nr//y67j7rbh065lBJ0pb1ITknFU/P87bIQbR3K23vxznn1B5xammPqLU9opb2sFraImoNR2Lfo+9bOt9H1NIW7nL8nvO6v+9+TLCxda9t0dfhzteDISXJemwd7gzJe4XdpB6PSevl3J7C9tisVE3ITR+U2gEAAACvEVg9lJ2arV8v/LU+8+Bn9OUnvqx7zr5HEzInKFAVkplUMC3X6xITzsyUkmRKSfJJad7V4ZxTW9j1EHx7CsDhLoG392N6u05DQ3uP53W8PxifnDNJ13/iqDj9VAAAAIDEIrB6rDCrUL/66K908cMX6ytPfEV3Lr5Tgaqgxk3KUWo6vx6vmJlSk02pHo8hds5FW5H70oLcFlFxXoan9QIAAACDiUQ0BByef7h+furPdeWTV+pbT31bZes/oSMXFHtdFoYAM4t1/03yuhQAAAAg4byfghaSpAUlC/SdE76jd97doHBbREWlA1t/FQAAAACGOwLrEHLhYRdqSeYnJUnPRB71uBoAAAAA8BaBdYiZ3nyUWnPqdePbP9NjHzzmdTkAAAAA4BkC6xDiIk5bqmt15JHTdPT4o3XtM9fq9e2ve10WAAAAAHiCwDqE7N7SqOaGNk06NF83n36zJmRO0Fef/Ko21m70ujQAAAAASDgC6xASqA5KkopK85Sfnq9fL/y1wi6sK564QqGWkLfFAQAAAECCEViHkJqqoDJyU+WfEF1Lc4p/im4+7WZtrt+srz75VbWGWz2uEAAAAAASh8A6hASqQiou9cvMOrcdW3CsfnLyT/Tqtlf1vZXfU8RFPKwQAAAAABInboHVzCaZ2Qoze9vM3jKzq2LbZ5vZC2a22sxWmdnx8aphOKnf3ay6nc0qmp63z76zpp6lq469Sg+vf1i3vnZr4osDAAAAAA8kx/Ha7ZK+4Zx71cxyJL1iZo9J+pmkHzrnHjazs2PvPxLHOoaFQFV0jGrRdH+P+78w6wvaVLdJ//vG/2pSziSdP+P8RJYHAAAAAAkXt8DqnAtICsRe15nZWkkTJTlJubHD/JJq4lXDcFJTFVRKWpLGlWT3uN/M9N1531WgIaAfPf8jFWQV6MTiExNcJQAAAAAkTkLGsJrZFEnHSHpR0tck/ZeZbZT0c0nXJqKGoS5QFVLhtFz5knr/laT4UnTDqTdoat5UfeOpb+i93e8lsEIAAAAASKy4B1Yzy5b0N0lfc87VSrpc0tXOuUmSrpZ0Ry/nXRYb47pq+/bt8S7TUy2NbdpZU9/j+NXuslOz9euFv1Zmcqa+/MSXta1xW/wLBAAAAAAPxDWwmlmKomH1Hufc32ObL5bU8fpeST1OuuSc+41zbo5zbs748ePjWabnAtUhyalPgVWSCrMKdevCWxVqCekrT3xFjW2N8S0QAAAAADwQz1mCTdHW07XOuRu77KqRdGrs9emS1sWrhuEiUBWSz2cqmJp74INjZo6dqZ+f+nO9u/tdfevpb6k90h7HCgEAAAAg8eLZwnqSpM9JOj22hM3q2KzAX5R0g5m9Lumnki6LYw3DQqA6qPGTc5SSmnRQ551Scoq+e8J39fSmp3XdS9fJORenCgEAAAAg8eI5S/CzkqyX3cfF677DTXtbWFs31Oqoj5T06/wLD7tQm+o26Xdv/U6Tcibp4iMvHuQKAQAAAMAb8VyHFX2w7YM6Rdpdn8ev9uRrx31Nm+o36YZVN6g4u1iLJi8avAIBAAAAwCMEVo8FqoKSpKLp/n5fw2c+/fTkn2pb4zZd+8y1mpA5QUePP3qQKgQAAAAAbyRkHVb0LlAV0pjCTGVkpw7oOunJ6br59Js1PmO8vvrkV7WxduMgVQgAAAAA3iCweshFnALVoQF1B+4qPz1f//3R/1bYhXXFE1co1BIalOsCAAAAgBcIrB7aWdOg1qZ2FQ+gO3B3U/xTdNNpN2lz/WZdteIqtYZbB+3aAAAAAJBIBFYP7Rm/mjeo1z2u4Dj9+KQf65Wtr+jfV/47y90AAAAAGJaYdMlDgaqgsvLSlDM2fdCvffa0s1XTUKObXr1JJTkluvKYKwf9HgAAAAAQTwRWjzjnVFMVUtF0v8x6W652YL4w6wvaVLdJv1nzG5Vkl+j8GefH5T4AAAAAEA8EVo/U7WxWQ7BFxYPcHbgrM9N3531XgYaAfvT8j1SQVaATi0+M2/0AAAAAYDAxhtUjgeroDL4DWX+1L1J8Kfr5qT/X1Lyp+sZT39C63eviej8AAAAAGCwEVo/UVAWVmpGs/OLsuN8rJzVHv174a2UkZ+iKJ67QtsZtcb8nAAAAAAwUgdUjgaqQCqf55fPFZ/xqd4VZhfrVwl8p1BLSV574ihrbGhNyXwAAAADoLwKrB5rr27Q70KDiGfHtDtzdzLEz9fNTf653d7+rbz39LbVH2hN6fwAAAAA4GARWDwSqg5KkotK8hN/7lJJT9N0TvqunNz2t6166jjVaAQAAAAxZzBLsgZqqkHzJpglTcjy5/4WHXaiNdRt151t3alLOJF185MWe1AEAAAAA+0Ng9UCgKqiCyblKTknyrIarj7tam+s364ZVN6g4u1iLJi/yrBYAAAAA6AldghOsrTWs7R/UxX05mwPxmU8/PfmnKhtfpmufuVZrtq/xtB4AAAAA6I7AmmDb1tcqEnEqmp7ndSlKT07XLaffovEZ43Xlk1dqY91Gr0sCAAAAgE4E1gSrqQpKJhVO87aFtUN+er7++6P/rbAL64rHr1CoJeR1SQAAAAAgicCacIHqkMYWZyk9K8XrUjpN8U/RTafdpM31m3XViqvUGm5N6P2dc2p64021796d0PsCAAAAGNoIrAkUCUe0pTrkyXI2B3JcwXH68Uk/1itbX9G/r/z3hCx341pbFbxvmdYvKdeGCy7QulNO1aYrr1TdE0/ItSY2NAMAAAAYepglOIF2bm5QW0tYRTOGRnfg7s6edrY212/Wza/drJKcEl15zJVxuU+4tla7//xn7f79H9S+bZvSZsxQ4Q9+oNb16xV64AHVPfa4kvLylHvOOfJXlCt91iyZWVxqAQAAADB0EVgTqGZdUJKGZAtrh0vLLtWm+k36zZrfqCS7ROfPOH/Qrt22ebN23f17Be+9V5HGRmXOn6ein/xYWSef3BlIJ3zrm2pYuVKhykoF771Xu++5R6mlpfKXl8t/3rlKKSoatHoAAAAADG0E1oFyLvrlO3Dv6kB1UDn56crJT09AYf1jZvrevO8pUB/Qj57/kQqzCjW/eP6Artn89tva+dvfqfbhhyVJuWefrbGfX6r0I47Y9/7Jyco+9VRln3qqwrW1qn3kEYUql2v7jTdq+y9+ocx5J8hfXq7cRYvky8oaUF0AAAAAhjZLxFjFgZozZ45btWqV12X0bNs70h1nSCXHSSXHS5PmShPnSBl5ex3mnNOd/7ZSJYeP0aJLjvSm1oNQ11qnix+5WIH6gO4+627NGDPjoM53zqnh2We1847fqvGFF+TLzFTehRcq/6LPKaW4+KDraf3wQ4WW369QZaXaNm6UZWYqd9Ei+SvKlXn88bKkpIO+JgAAAIChwcxecc7N2Wc7gXWAdlZLz90ibXpZ2vqWJCfJpPGHSSVzpUknSJOOVzA8Uff84CWd+i+HadYpE72uuk+2NGzRvzz4L0ryJemes+/RhMwJBzzHtbYq9MCD2vW736ll3TolT5ig/Is+p7wLL1RSbu6Aa3LOqenVVxVaVqnahx9WpL5eyYWF8i9ZIn/5EqWVlg74HgAAAAASi8CaCM210uZXouF140vR781BSdLatnP05M5L9amz3tDYWWXRVtj0gQe4eFu7c60ufuRiTcmdojsX36nMlMwej9tnIqVDD1X+JZ+X/+yzZampcakt0tys+iefVLCyUg3PrpTCYaWXlUW7DJ9ztpLHjInLfQEAAAAMLgKrFyIRaWeVtOklPflgm94PjNcXxn1OZhFJJk2YuVcrrMZOl4bgbLhPb3paVz55pRZMXKCbTrtJSb493W+7T6SUdeJ85X/+EmWdfFJCZ/Zt375doQcfVKhyuVrWrpVSUpR96inyl5cr+9RT5YtTaAYAAAAwcARWj93zHy8oryBT51wyWdq0qksr7CqpJRQ9KGNMNMB2joU9TkrL8bbwmD+98yf95MWf6FOHfUrfOeE7an77be367e9U+8gjkvY/kVKiNb/7rkLLKhV64H6Ft+9Qkt+v3HPOlr+iQullZSyRAwAAAAwxBFYPNda26nffflbzP1aqY8+YvPfOSETa8Z606aVogN34krTj3eg+80kTjoi2vpYcH/2eP82zVtgbXv65Vt//O31l7STlvvHBgCdSijfX3q6G559X6L5lqnviCbmWFqVOnRpdImfJeUOyZgAAAGA0IrB6qPq1bXrkf97Ux799nAqn+Q98QtNuadMre0Ls5lekltrovsyxsVbYudEAW3yslJYd1/ojra2qfeBB7fzd79S6bp125kjJnyzX3Mu+MygTKSVCuK5Odf/4h0LLKtW4apVkpszjj5e/okI5ixYpKZslcgAAAACvEFg99Oxf1unNZzbri784RUnJB16vdR+RsLT93ViAfTn6fcd70X2WJBUcER0H29GVeMzUQWmF7ZxI6e7fq337dqUdeqhyLv6svp7yd62tXaffnvlbHTX+qAHfJ9FaN25UaPlyhSqXq+3DD2UZGcpZ9FH5y8uVNW8eS+QAAAAACUZg9dC9//myklOTdP43jh28izbuio2F7dIK21of3Zc5LtaNuEsrbGrPs/v2JDqR0t0K3vvXHidS2tW8S5958DNqbG/UH87+gyblTBq8z5VAzjk1vbZaoWXLokvk1NUpuaBA/iXnyV9errTp070uEQAAABgVCKweaW1u1+1ff0bHnnmI5pXHcY3QSFjatnbvVtidVdF9liQVztq7FTZv8j6tsE1vvbVnIiUz5Z59lsZ+/vNKnzlzn9utD63XZx/6rPLT8/WHs/8gf1ofujoPYZGWFtWvWKHQskrVP/NMdImcI4+Uv6IiukROfr7XJQIAAAAjFoHVIxvX7tLym1brvCuP1iFHjk3szRt2Rmcj7myFfVVqa4juy5ogTTpebuIcNWzN1M77V6rxxZfly8raM5FSUdF+L79qyypd9thlOnr80fqfRf+j1KSRsXRM+86dqn3gAQUrK9Xy9lopOVnZp8SWyDntIyyRAwAAAAwyAqtHXrz/fb3y0AZdeuMpSs1I9raYcLu07W1p00uKrH9RtU+9oF2vNKkllKLkjLDy5/iVd9YCJc04MdqV2D/pgGNhH3z/QV3zzDU6Z9o5+s+T/3PELRnT/O57Ci2vVO3y+9W+fbt8fr9yzz5LeeXlSj/66BH3eQEAAAAv9BZYPU5QI1+gKqSxJdneh1VJSkpWOGuKdr/2onb//l21b29X2vTDVLz0BOVObZMFXpXW/lFac0f0+OzCaPfhjiV1imZLKel7XfKcaeeopr5GN792s0qyS/SVY76S+M8VR+mHHar0b31LE77+dTU897xClZUK3bdMwT/+SamTJ8tfUS7/kiVKmTjR61IBAACAEWcIpKiRKxyOaOv6kGae5P16nz1NpFT0n/+prJNO3LuVMNwubX0z2pV440vR7sRr74/u86VIRUfFxsLGJnTyl+jSsku1qX6T/mfN/2hi9kSdP+N8bz5kHFlSkrIXnKzsBScrXF+vun88qtCyZdp+083aftPN0SVyysuVc+YZSsqO7zJDAAAAwGhBl+A42rq+Vn+9fpXO/OIsTT9ugic1HMxESr2q37YnvG58Wap5VWpvju7LKZYmzVXbxOP05Z3P6eXgu/r1R/9b84vnx+cDDTGtmzar9v7lCi2rVOsHH8jS05Xz0Y/KX1GhrPkskQMAAAD0BWNYPfDaYx/qub9Vaen1JynLn5aw+zrn1PDMM9r529+p8YUXDmoipT4Jt0lb3ti7FTb4oerMdFFxobakpOrucadqxtSF0VbYXO9bmOPNOaem1asVqqxU7UMPK1Jbq+QJE5R73rnyl5cr/dBDvS4RAAAAGLIIrB546L/XaGdNgz73/xLT2hhpbVXt/Q9o152/U8u6KiUXFCj/oouUd+EFSsrJie/N67ZIG19S4IOn9JmtTyg53KZ7agIaH45IuSV7j4UtPEpKHrkz7UZaW1W/4imFli2LLpHT3q70I46Qv6Jcueeco+SxCZ4tGgAAABjiCKwJ5pzTb7/1rKbMGquFS4+I673CtbXa/ac/a/fvf6/27duVdthhGnvJ55V71lkyD5ZgeXvn21r6yFJNyZigOwvPUObm16KtsaGN0QOS0qTiY/YOsTmFCa8zEdp37lTtgw8pVFmp5rfekpKSlL1ggfwVFdElctIS1/IOAAAADFUE1gTbvaVB//eDF3Xa5w7XEXGadGnfiZROVP4ll+w7kZIHnt70tK588kotmLhAN512k5J8SVJtTawLcawrcWC1FG6NnuCfJPlLpPQ8Kd0vZeRFX2fE3ne+7rI/JfOAy+4MJS3r1kVnGV5+v9q3bZMvN1e5Z50lf3m5Mo6Z7fnvDAAAAPAKgTXB3n62Riv+8I7+5QcnaExh1qBeu+mtt7Trjt+q9h//2DOR0iWXKP3wwwf1PgP1p3f+pJ+8+BN96rBP6TsnfGffQNbeIgXWRMfAbn4lOrlTc1BqCknNIakltP8b+FL2H2j3F3jTciWfb5A/cd+4cFgNL7ygUGWl6h57XK6pSSmTD5G/PLpETmpJiSd1jWrhNqm1IfolSX6WKQIAAEgk1mFNsJqqoDJyUpRXkDko1+ucSOmO36rxxRfly8pS/sUXK/9znx2ciZTi4FOHf0qb6zfrzrfu1KScSbroyIv2PiA5LdoteNLcni8QCUeDa3NQagp2ex173/G6KSg17pJ2vb/nWBfuvTjzRUNrnwPvmL33J/X/Px1LSlL2SScp+6STFK5vUN2jjypUWakdN9+iHTffosw5c+SvKFfO4sUskdOVc9HZqVsbpdZ6qa1xT8hsbYi9r4/ub+vYHjtmr/cd53Z53dHSL0mT5klf+Id3nxMAAACdCKxxEqgKqqg0b8DdPHuaSGnCt76VmImUBsHVx12tzfWb9fNVP9fE7IlaOHlh30/2JUmZ+dGvg+VcNIx0DbQHCrx1W/a8Drfs//qp2Qfustzb/pT0zsskZWcp72PnK+9j56tt82aF7n9AoWXLFPjev2vL//txbImccmXNny9LHib/uUbCe4fJ/QXL7mFyf0GzrUFykb7X4UuRUrP2fKVkRn9v2RNi77Ok1Mwur2Pvc2ldBQAAGCqGyf8BDy8NwRbV7mhW2Uf637UzHApp95//stdESsU/u165ixd7MpFSf/nMp5+e/FNtbdyqa565Rndk3qGjxh8V/xubSWk50S9NOvjz25r2DbTdA2/Xbbs3SIHY+9b6/V87Ka3HQJuSkadxh+Zp7PfPUfPmBoVWvqvQP1eo9sEHlTQ2X/5zzpL/4xco/bDDDv7z9KS9tZeWx4MJmj0Ey/amg6sjJTMWJmOBMiUWIjPz9w6aqZl7v+4eNLuem5olJaUMzs8JAAAAnmEMaxysW7VVj97+lj5xzRwVTMk9qHM7JlLafe9f5TomUvrCJco60fuJlAZiZ9NOffahz6qxvVF/OPsPmpTTjxA5XITbuoTdkNS8u/dW3X1afWsl7flvMhKW6mvSFdqQofqadMmZ0vIj8s9MlX/WGCWPG7t3C65zfQ+akba+fybzdQmEfQiLnUEza9/Q2fXclEzPxhIDAABg6GAMawIFqkJKTkvS+El9H3/Y9OZb2vXbPRMp+c85W/mf//yQm0ipv8ZmjNWvP/prffahz+qKx6/QH87+g/xpfq/Lio+kFClrXPTrYEUiUkttZ4j1NYeU2xxUblNQ7dsDql35pkLPV2nbypC2Pbdd2VNr5Z/ulF1YL197MBYsu4XJlCwpu7BvQbO3YJmcNqxmZAYAAMDIQGCNg0B1UIVTc+VL2n/LkYtEohMp/fZ3e0+kdNHnlFI48tYlneqfqptOu0mXPXaZvrbia/qfRf+j1KTh0705IXy+aEtpRp40Zu9dyZLyF0v5klqqqhSqXK7Q8uWqf3SrfDljlbv4M/KfX6GMY44Z1q3xAAAAQAe6BA+ylqZ23f71pzX3nKk6/typPR7TMZHSzt/9Vq1V1UouLFT+RRcp74JPDIuJlAbqwfcf1DXPXKNzp52rn578U8LVALhwWI0vvqhQZaVqH30sukTOpEnRJXLKlyh10gjueg0AAIARgy7BCbLl/ZDkpKLp+3Z33WcipcMPj06kdNZZspTRM0HMOdPOUU19jW5+7WaV5JToy7O/7HVJw5YlJSnrxBOVdeKJKvz+91X72GMKLavUjl/9SjtuvVUZc46Tv7xcuYsXj4p/DAEAAMDIQmAdZIF1QZnPVDh1T2Bt3bRZu+6+S8G//i06kdJJJ6nouv8c9hMpDcSlZZdqU/0m3fb6bZqYPVEV0yu8LmnY82VlKa+iQnkVFWqrqelcImfLv39fW3/8E+UsPF3+8nJlnXTS8FkiBwAAAKMa/9c6yALVIY2flK2UtKQRP5HSQJiZvjfve6qpr9EPn/uhCrMKNa9ontdljRgpxcUa96+XaexlX1Tzm28qdN8y1T74oGofelhJ48bJf+658leU8ywCAABgSGMM6yAKt0X0v1f/U4eVStNW3xWdSCk7W3mfvFD5nxuZEykNVF1rnS56+CJtadiic6edK5/5ZGYyWfR1x/eu23p57bPoJFc+88mn/Zwjk9ne1+88r9vr7seaWee1e9q21+ue6jrANfe6vnySHdznyUrJ6rxfd661VfVPP61QZaXqnvqn1NamtMMOk7+iQv5zz1Hy+PEJ+I0DAAAA++ptDCuBdZBEWltV/fuH9ejLOSp78zcqSt46qiZSGohAfUBfXfFVBRoCiriI5KSIItHXkiIu+trJyTnX+Rr7SvGlaGL2RE3KmaSSnBJNypnU+TUxe6LSk9MlSe27d6v2oYcUqlyu5jVrJJ9PWSefJH95uXIWLpQvPd3jTwIAAIDRhMAaJ+FQSLv/9Gft+sPv9X76MaourdAnFjZoQsXiUTWRkhecc3KKBdgur/cKuortc27P6x7O6W1b14Dc2+te93eE7h4C+IHq6R7W+/J5Ii6inU07tbFuY+dXY3vjXj+zCRkT9gmyJbtMeStWq+WhR9Ue2CJfdrZyz1osf3m5Mo47btSOswYAAEDiMEtwnLS8/762/+IXyjrpJLVM/Zjy2tJVcMHpXpc1KnTtFot9Oee0u2X3XgF2U90mbarbpOdqntP2pu17Dp4g5VyapQXbpurE11s1bfkyBe/9qyJF45V+7mIVf/zTypjS8zJNAAAAQLzQwjoIWtavV+rkKbrjm89o2jHjdfrnZnpdEnBATe1N2lS3qTPIbqzbqI310dc7dm3SsWvbdOqbTrM2OPkkrZ+cpvfnH6KGBbNVWFja2e24JLtEmSmZXn8cAAAADGO0sMZR2tSp2rm5Xi2N7Sqenud1OUCfZCRnaMaYGZoxZsY++8KRsLY2btXGuo1at/5N6dGnNeGpt7TwT+vUdu86vXyo6c5ZpjVTTeEk07iMcXu6GGeX7NXtOD89n27FAAAA6BcC6yAJVAUlSUXT/fs/EBgGknxJKs4uVnF2sVR0gnTiF+ScU/ObbylUuUwnPfCATlwbUjgvW1tOnKE1c/K1RnV6IfCCtjVu2+tamcmZ+0wC1fG6KKtIyT7+GAIAAEDP+D/FQVJTFVKmP1W54zK8LgWICzNTRtksZZTNUsG3v636Z59V6L5lSnrsKU18qE0Vhx4qf/lnlHbWR7Uts32vsbMb6zbq/dD7enrT02qLtHVeM8mSVJRVtPckUF2CLV2NAQAARjfGsA6Su65dqYKpfi2+bJbXpQAJ1b57t+oeeUShZZVqev316BI5J54of0WFchaeLl/Gnn/EibiItjVu22sSqK6htra1dq9r56fn97hEz6ScSRqbPpauxgAAACMEy9rEUd2uZt39nee04JMzdNRpk7wuB/BMy/vrFVpeqdDy5WqvCciXlaWcxWfKX16uzDlzZL79z+gcaglpU/2mfcLsprpN2tKwZa/1dzOSMzrXnO3eQlucVayUJJaVAgAAGC4IrHH03ktb9Nhv39aF35mr8YfkeF0O4DkXiajx5VUKVVaq7pFHFGlsVMrEifKXL5F/yRKlTply0NdsDbdqc/3mfZbo2Vi3UZvqN6kl3NJ5rM98Ksoq6myZLcneu4U2OzV7ED8tAAAABorAGkdP/d+7eu+lLbr0xlPk89FFEegq0tiouieeUGhZpRqee05yThmzZ8tfUa7cs85Skn/gE5VFXETbG7d3ts5273IcbAnudfyYtDHRJXm6dTUuyS7RhMwJdDUGAABIsIQHVjObJOluSQWSnKTfOOduiu27UtKXJYUlPeic+/b+rjXUA+sff/SisvPSdN5XZ3tdCjCktW3dqtr771dw2TK1VlXLUlKUffrp8peXK3vBybKU+HTjrWut22e87Kb6aAttoCGgiIt0HluQWaAlpUtUPr1ck3Mnx6UeAAAA7M2LwFokqcg596qZ5Uh6RVKFogH2u5LOcc61mNkE59y2/VxqSAfW5oY23fGNZ3TCkmmac/YUr8sBhgXnnJrffluhykrVPvCgwrt2KSk/X7nnniN/ebnSjzgiYa2cbeE21TTUaFPdJn1Y96Ge3vS0nqt5ThEX0TETjlF5abnOnHIm3YgBAADiyPMuwWZWKelWSV9UtLX18b6eO5QDa8263Vr2i9Uq/9psTTx0jNflAMOOa2tT/TPPKlRZqfonn5Rra1PajOnyl5cr97wlSimYkPCatjVu0wPvP6BlVcu0PrRe6Unp+ujkj6p8ermOLzxePtv/5FEAAAA4OJ4GVjObIulpSbNi3yslLZbULOmbzrmXezjnMkmXSdIhhxxy3AcffBD3OvurrSUsX7IpKYn/iQUGIhwKqfbhh6NL5KxeHV0iZ/58+SvKlbNwoXyZiV2X1TmnN3a8ocqqSj28/mHVtdWpKKso2mW4tFyTcpkVHAAAYDB4FljNLFvSPyX9xDn3dzN7U9IKSV+VNFfSnyVNc/spZCi3sAKIj9YNGxRavlyhZZVqq6mRLzNTOWeeKX9FhTLnHniJnMHW3N6sFRtXqLKqUs/VPCcnp2MnHKuK6RU6Y8oZykrJSmg9AAAAI4kngdXMUiQ9IOkfzrkbY9sekXS9c25F7H21pHnOue29XYfACoxeLhJR46qOJXL+oUhDg5KLi+RfskT+JeVKmzY14TVtadiiB95/QJVVldpQu0EZyRlaNHmRykvLNadwDl2GAQAADpIXky6ZpLsk7XLOfa3L9i9JKnbOfd/MDpX0hKRDaGEFcCCRpibVPfGkQpWVali5UopElH70UcqrqIgukZOXl9B6nHN6ffvrqqyu1CPrH1F9W70mZk/UktIlWlK6RCU5JQmtBwAAYLjyIrCeLOkZSW9I6lgz4juSHpf0W0mzJbUqOob1yf1di8AKoLu2rdtU+8ADCi1bppZ166JL5HzkI/JXlCt7wQJZampC62lqb9KTHz6pyqpKvRB4QU5OcwrmqGJ6hRZNXqTMlMSOvwUAABhOPJ8leCAIrAB645xTy9q1ClVWKvTAgwrv3KmkMWOUe05siZxZRyZsiZwOWxq2aHn1clVWVerDug+VkZyhMyafoYrpFTqu4LiE1wMAADDUEVgBjHiurU31K1dGl8h54km51lalTi+Vv7xc/vPOU0phYWLrcU6rt69WZVWlHtnwiBraGlSSXaIl06NdhidmT0xoPQAAAEMVgRXAqBIOhVT7yD8UqqxU06uvSmbKmj9P/vJy5SxalPAlchrbGvXEh0+osrpSLwZelCSdUHiCyqeXa+EhC+kyDAAARjUCK4BRq/WDDxSqXK5QZaXaNm+WZWYq94wz5K8oV+bxxyd8iZya+prOLsOb6jcpMzlTZ045UxXTK3TMhGPoMgwAAEYdAiuAUc9FImp69VWFKitV+/AjitTXK7moSP7zzpO/olxp06Ylth7n9Oq2V7Wsapn+seEfampv0qScSSovLdeS0iUqyi5KaD0AAABeIbACQBeR5mbVPfFEdImcZ2NL5Bx1lPzlS5R79tlKHjMmofU0tjXq8Q8fV2VVpV7a8pJMphOK9nQZzkjOSGg9AAAAiURgBYBetG3bptoHH4oukfPuu1JKirJPPUV5FRXKPuWUhC+Rs6luk+6vvl+V1ZXaXL9Z2SnZnV2Gjx5/NF2GAQDAiENgBYA+aH7nHYWWVSr0wAMK79ihJL8/ukRORbnSy8oSGhYjLqJXtr6iZVXL9NgHj6mpvUmTcyervLRc55Wep8KsxM56DAAAEC8EVgA4CK69XQ2xJXLqHn8iukTOtGnRJXKWnKeUosSOL21oa9BjHzymyqpKrdq6SibT/OL5Ki8t1+mHnK705PSE1gMAADCYCKwA0E/h2lrV/uMfCi2rVNMrr0hmyjzhBPnLy5V7xiL5srISWs/G2o1a/v5yLa9arpqGGuWk5Gjx1MUqn16uo8YdRZdhAAAw7BBYAWAQtH74oULL748ukbNxoywjQ7lnLJK/vFyZJ5wgS0pKWC0RF9HLW15WZVWlHvvgMTWHmzXVP1XlpeU6d9q5KsgqSFgtAAAAA0FgBYBB5JxT02uvKXTfMtU+8ogidXVKLizcs0ROaWlC66lvrddjHzymZVXL9Oq2V+Uzn+YXz1dFaYVOO+Q0pSWlJbQeAACAg0FgBYA4iTQ3q37FCoWWVar+2WelcFjps2ZFuwyfc7aS8/MTWs+HtR+qsrpSy6uXa0vDFuWk5ujsqWervLRcs8bNosswAAAYcgisAJAA7Tt2KPTAAwpVLlfL2rVScrKyTz1V/vIlyv7IR+RL4BI5ERfRi4EXVVldqcc/eFwt4RaV+ktVPj3aZXh85viE1QIAALA/BFYASLDmd99VqHK5QvcvV3j7Dvn8fuWefZbyKiqUflRiJ0eqa63Toxse1bKqZVq9fbV85tNJxSepYnqFPjLpI0pNSuxaswAAAF0RWAHAI669XQ3PP6/QskrVPf64XEuLUqdMkb+iXP7zzlPKxIkJrWdDaIOWVy9XZXWltjVuU25qrs6eerYqZlToiPwj6DIMAAASjsAKAENAuK5OdbElchpjf651LJGTc8YZSspO3BI54UhYLwZe1LLqZXrywyfVEm7R9LzpqpheoXOmnaNxGeMSVgsAABjdCKwAMMS0btqk0PLl0SVyPvhQlp6unEXRJXKy5s9L6BI5ta21emT9I6qsrtSa7WuUZElaMHGByqeX69SSU5WSlJKwWgAAwOhDYAWAISq6RM5qhSorVfvww4rU1ip5wgT5l5wnf3m50mbMSGg974fe1/Kq5bq/+n5ta9qmvLS8aJfh6RU6PP9wugwDAIBBR2AFgGEg0tKi+hVPKbRsmeqfeSa6RM4RR8hfUaHcc89J6BI54UhYzweeV2VVpZ788Em1Rlp16JhDVV5arnOmnaOxGWMTVgsAABjZCKwAMMy079yp2gcfVGhZpZrffju6RM6CBfKXlyv7tI/Il5aWsFpCLaHOLsNv7HhDyZasBSXRLsOnTDyFLsMAAGBACKwAMIw1v/detMvw8vvVvn27fLm5yj37LPnLy5Uxe3ZCu+lWB6tVWVWp+9+/XzuadmhM2hidM+0cVUyv0GH5hyWsDgAAMHIQWAFgBHDhsBqef0GhykrVPfaYXHOzUiYfIn95ufxLypVakrglctoj7Xqu5jlVVlVqxcYVaou06fD8w3X6IaerMLNQ4zLGdX6NSR+jZF9ywmoDAADDC4EVAEaYcH296v7xqEKVlWp86SVJUubcufJXlCvnzDOVlJ2dsFqCzUE9vOFhLataprd3vr3PfpNpTPqYvULs2PSxGpsxdq9t4zLGKTc1l4mdAAAYZQisADCCtW7arNr7lyu0rFKtH3wQXSLnox+NLpFz4vyELpHT1N6knU07taNpx57vzdHvXbftaNqh1kjrPuen+FKiQTY9Fmx7CLVjM8ZqbPpYZaZkJuxzAQCA+CGwAsAo4JxT8+uvK1hZqdqHHlYkFFLy+PHKPe88+SvKlX7ooV6X2Mk5p7q2un1CbE/BdlfzLjnt+/dVVkrWfltrO4Jvfka+UnxMDAUAwFBFYAWAUSbS2hpdIqeyUvVPPy21tyvtiJnKKy9X7jnnKHncOK9L7LP2SLuCLcEeA+3Opp3a0bxne11rXY/XGJM2pvdQmzGus0XXn+anSzIAAAlGYAWAUax91y7VPviQQsuWqfmtt6SkJGWffLL851co+7TTErpETry1hFv2abHd633znvct4ZZ9zk/2JWts+ti9wmzH++5fdEkGAGBwEFgBAJKklnXrFFq+XKHl96t961b5cnKUe9ZZ8leUK+OYY0ZN66JzTvVt9XuF2q5jbbuPwY24yD7XyEjO2Gciqd7G27JWLQAAvSOwAgD24sJhNbzQsUTO43JNTUo55BD5y5fIX16u1JISr0scMsKRcGeX5O5dkLu34Na21vZ4jby0vH1abvfplpwxTnlpefKZL8GfEAAAbxFYAQC9Ctc3qO6xx6JL5Lz4ouScMuYcJ395uXIXL1ZSTo7XJQ4breHWvQJsbzMk72jaoeZw8z7nJ1lSj5NI9TT+NjM5c9S0iAMARjYCKwCgT9pqahRafr9Cy5apdcMGWVqachYulL+iXFknnihLTva6xBHBOafG9sb9zo7ctaty2IX3uUZGcoby0/P3O4lUx7bUpFQPPiUAAH1DYAUAHBTnnJrfeEOhZctU++BDCodCSho/Tv5zY0vkHHaY1yWOGhEX2btLctdg27x30A22BHu8Rm5qbu+ttemxsbYZYzUmbYySfIlbtxcA0D+t4VY1tDWovq1ejW2Nqm+rV0NbQ4/bkixJ35jzDa9L3i8CKwCg3yKtrar/5z+jS+Q89c/oEjmHHy5/ebn8556j5PHjvS4RMW3hNu1s3tnz2rbdJpVqam/a53yf+TpbbTvWse2ta3J2SjZdkgHgILSF2zoDZUe47PrVl/DZ8dUWaevTPTOTM1WQVaDlFcvj/OkGhsAKABgU7bt3R5fIqaxU8xtvSElJyjr5JOWVlyv79NPlS0/3ukT0UWNbY5/G2u5s2ql2177P+WlJaT0G287lgLqE27SkkbN0EoDRpS3S1mNg7AySrfVqaG9QQ2tD5/feAmlrpLVP98xIzlBWSpayU7KVmZK51/eslKx9vnran52SrYzkjGHTa4bACgAYdC3V1QpVLldo+XK1b9kiX3a2cs9arILvfpfgOoJEXES1LbU9dkHuHmx3t+zu8Ro5KTl9mkiKLskABkN7pL3PLZj7297Q1tDjmt09yUjOUGZyprJTszu/ZyVnKSs1a6/vve3PTo2GzczkzFH55yCBFQAQNy4cVuNLLym0rFIt69dryp//RFfRUaot0qZdTbu0ozk2YdR+uiY3tDXsc77PfBqTNqbXUNt1aaDc1FyeM2AECUfCe1oqDxAiD7S/p1nYe5KelH7QLZc97c9KyVKyj0kJB4LACgBICOccIQJ90tjW2Pt4226TSrVH9u2SnOJL6TnYpu/bNTkjOcODTwiMfOFIWI3tjfsEyYMJlx1fPY2r70mqL7WzNfJgQmb37ZkpmUrxpcT5J4S+6i2w8s8AAIBBRVhFX2WmZCozJVOTcibt9zjnnGpba/cNts17gm1NfY3WbF+j3c275bTvP8Znp2TvE2y7ttZ2bMtPz6eVBCNexEXU2LZvyOwIlH0Jlx3n9DVkpvhS9gmQY9PHanLO5J5bMHvrPpuSpZQkQuZowp/IAABgSDMz+dP88qf5NS1v2n6PbY+0a3fz7v3Ojvzurne1smml6tvq972XTGPSx/Q6kVTXL7okI5EiLqKm9qYDtlbWtx64+2xje2Of7pnsS95nEp8x6WM0KWfSQXefZS1o9BeBFQAAjBjJvmSNzxyv8ZkHXmqpub35gLMjf1D7gXY07ehxZs9kX/I+XZB7W+M2MyUzHh8XQ5xz7oAhs6/LmDS2NfbYe6C7ZEveZ5Iff7pfE3MmHvTYTEImhgICKwAAGJXSk9M1MXuiJmZP3O9xzjnVtdXtd3bkQENAb+x4Q7tbdiviIvtcIzM5c7+ttR0tuvkZ+Yyp81hHyGxs77ZcSR/HYe4VMtsbe3weukuypH0CY25qroqyig5ubGZqtlJ9qbT8Y0QhsAIAAOyHmSk3NVe5qbma5t9/l+RwJKzdLbt7n0iqeYeqglV6IfCC6lrrerzGmLQxe69lm95z0PWn+eUzXzw+8rDjnFNzuPmgZ5LdZ39sHc2+hEyf+XoMjAVZBQc1u2x2SrbSktIImUAvCKwAAACDJMmX1BkoD9Nh+z22JdzSYzfkrpNKbdy2UTuadvS4DmSyJSs/I7/HZX+6fw3FLsnOObVGWvcaczmQZUzCLnzAe5qsxyA5IWNCNETuZ33M7uekJ6UTMoEEILACAAB4IC0pTcXZxSrOLt7vcc45NbQ19Dg7csfX9sbtWrtzrXY27+yxdTAjOaPXmZG7B94DzcDaGm7tfbKfju6z7dH3+3Sr7fa93e27XFF3JutcgqRrYByXMa6zpbK3Fszu2zKSMwiZwDBDYAUAABjCzEzZqdnKTs3WFP+U/R4bjoQVbAnu1QW5ewvu+6H39fLWlxVqCfV4DX+av3M8bXukfZ8Wzp7WxO1JVsreE/9kpWYpPz1/71bMPozNTE9Op+szMIoRWAEAAEaIJF9S52zFB9IabtWu5l37jLXtCLa7mncp1ZeqvOy8HgNl926zXbvPZiRnEDIBDAoCKwAAwCiUmpSqwqxCFWYVel0KAPSKf/oCAAAAAAxJBFYAAAAAwJBEYAUAAAAADEkEVgAAAADAkERgBQAAAAAMSQRWAAAAAMCQRGAFAAAAAAxJBFYAAAAAwJBEYAUAAAAADEkEVgAAAADAkERgBQAAAAAMSQRWAAAAAMCQRGAFAAAAAAxJBFYAAAAAwJBEYAUAAAAADEkEVgAAAADAkERgBQAAAAAMSQRWAAAAAMCQZM45r2s4IDPbLukDr+s4gHGSdnhdBEY9nkMMBTyHGCp4FjEU8BxiKBgOz+Fk59z47huHRWAdDsxslXNujtd1YHTjOcRQwHOIoYJnEUMBzyGGguH8HNIlGAAAAAAwJBFYAQAAAABDEoF18PzG6wIA8RxiaOA5xFDBs4ihgOcQQ8GwfQ4ZwwoAAAAAGJJoYQUAAAAADEkE1j4ws9+a2TYze7PLtnwze8zM1sW+j4ltNzO72cyqzGyNmR3rXeUYScxskpmtMLO3zewtM7sqtp1nEQllZulm9pKZvR57Fn8Y2z7VzF6MPXN/NrPU2Pa02Puq2P4pnn4AjChmlmRmr5nZA7H3PIdIKDPbYGZvmNlqM1sV28bfzUgoM8szs7+a2TtmttbM5o+U55DA2jd3Slrcbds1kp5wzs2Q9ETsvSSdJWlG7OsySf+doBox8rVL+oZz7ghJ8yR92cyOEM8iEq9F0unOuaMlzZa02MzmSbpe0i+cc9Ml7Zb0hdjxX5C0O7b9F7HjgMFylaS1Xd7zHMILpznnZndZNoS/m5FoN0l6xDl3uKSjFf1zcUQ8hwTWPnDOPS1pV7fN5ZLuir2+S1JFl+13u6gXJOWZWVFCCsWI5pwLOOdejb2uU/QPooniWUSCxZ6p+tjblNiXk3S6pL/Gtnd/Fjue0b9KWmhmlphqMZKZWYmkcyTdHntv4jnE0MDfzUgYM/NLOkXSHZLknGt1zgU1Qp5DAmv/FTjnArHXWyQVxF5PlLSxy3GbYtuAQRPrynaMpBfFswgPxLphrpa0TdJjkqolBZ1z7bFDuj5vnc9ibH9I0tiEFoyR6peSvi0pEns/VjyHSDwn6VEze8XMLott4+9mJNJUSdsl/S42ROJ2M8vSCHkOCayDwEWnWma6ZSSEmWVL+pukrznnarvu41lEojjnws652ZJKJB0v6XBvK8JoY2bnStrmnHvF61ow6p3snDtW0W6WXzazU7ru5O9mJECypGMl/bdz7hhJDdrT/VfS8H4OCaz9t7Wj6Tz2fVts+2ZJk7ocVxLbBgyYmaUoGlbvcc79PbaZZxGeiXU5WiFpvqJdipJju7o+b53PYmy/X9LOxFaKEegkSUvMbIOkPynaFfgm8RwiwZxzm2Pft0m6T9F/xOPvZiTSJkmbnHMvxt7/VdEAOyKeQwJr/y2XdHHs9cWSKrtsvyg2+9Y8SaEuTfFAv8XGWt0haa1z7sYuu3gWkVBmNt7M8mKvMyQtUnRM9QpJn4gd1v1Z7HhGPyHpScci4Bgg59y1zrkS59wUSZ9S9Ln6jHgOkUBmlmVmOR2vJZ0h6U3xdzMSyDm3RdJGMzsstmmhpLc1Qp5D48/qAzOzP0r6iKRxkrZK+g9JyyT9RdIhkj6QdKFzblcsVNyq6KzCjZI+75xb5UHZGGHM7GRJz0h6Q3vGa31H0XGsPItIGDM7StHJG5IU/YfPvzjnfmRm0xRt6cqX9JqkzzrnWswsXdLvFR13vUvSp5xz73tTPUYiM/uIpG86587lOUQixZ63+2JvkyX9n3PuJ2Y2VvzdjAQys9mKTkCXKul9SZ9X7O9oDfPnkMAKAAAAABiS6BIMAAAAABiSCKwAAAAAgCGJwAoAAAAAGJIIrAAAAACAIYnACgAAAAAYkgisAIARy8wuMLO1ZrYi9v6PZrbGzK4+yOvkmdkVXd4Xm9lfB7ve/jKz2WZ29gDOrzCzIw7i+DlmdnN/7wcAQF+xrA0AYMQys0ck/dg596yZFUp61jk3vR/XmSLpAefcrMGucTCY2VJJc5xzX+nn+Xcq+vmGTAgHAECihRUAMAKY2WfN7CUzW21m/2NmSWb2fUknS7rDzP5L0qOSJsaOWWBmpWb2iJm9YmbPmNnhsWsVmNl9ZvZ67OtESddJKo2d+19mNsXM3owd/4KZHdmllqdiLZBZZvbbWF2vmVl5L7X/m5m9EbvXdbFts2PXXROrZUyXa18fu+Z7sc+RKulHkj4Zq++Tvd3bzG6K/VxkZmea2dOxz7dE0n/Fzi/tVt8FZvZmrL6nY9s+YmYPxF4/FDtvtZmFzOzi2M//v8zs5dhn+NfB+U0DAEabZK8LAABgIMxspqRPSjrJOddmZr+W9Bnn3I/M7HRJ33TOrTKzXynaijg7dt4Tkr7knFtnZidI+rWk0yXdLOmfzrnzzSxJUrakayTN6nLulC4l/FnShZL+w8yKJBXF7vdTSU865y4xszxJL5nZ4865hi61nyWpXNIJzrlGM8uP7bpb0pXOuX+a2Y8k/Yekr8X2JTvnjo91Af4P59xHYyG0s4W1t3tLulbSy2b2TOxznu2cqzaz5eq9hfX7ks50zm2OXWsvzrmzY/c8TtLvJC2T9AVJIefcXDNLk7TSzB51zq3v6XcIAEBvCKwAgOFuoaTjFA1ikpQhadv+TjCzbEknSro3do4kpcW+ny7pIklyzoUlhTpaOHvxF0Vbb/9D0eDaEfrOkLTEzL4Ze58u6RBJa7uc+1FJv3PONcbut8vM/JLynHP/jB1zl6R7u5zz99j3VyRN6aWmHu/tnFtrZl+U9LSkq51z1fv5XB1WSrrTzP7S5d57MbNxkn4v6ULnXMjMzpB0lJl9InaIX9IMSQRWAMBBIbACAIY7k3SXc+7agzjHJynY0WI6ELGWx51mdpSiLb1f6lLXx51z7w70Ht20xL6H1fvf4/u7d5mknZKK+3Iz59yXYi3Q50h6JdaSuudG0VboP0n6kXPuzS73v9I594++3AMAgN4whhUAMNw9IekTZjZBksws38wm7+8E51ytpPVmdkHsHDOzo7tc7/LY9qRYi2edpJz9XPLPkr4tye+cWxPb9g9JV1qsCdfMjunhvMckfd7MMjtqd86FJO02swWxYz4n6Z89nNtV9/p6vHfs5/INScdIOisWRHs6v5OZlTrnXnTOfV/SdkmTuh1ynaQ1zrk/dbv/5WaWErvGoWaWdYDPAADAPgisAIBhzTn3tqTvSXrUzNYoGgKL+nDqZyR9wcxel/SWomNJJekqSaeZ2RuKdrs9wjm3U9FxmG9adAKn7v4q6VOKdg/u8P8kpUhaY2Zvxd53r/0RScslrTKz1ZI6uvBerOgkSGskzVZ0UqX9WSHpiI5Jl3q6dyy83qHomN4aRceZ3m5m6Yq2kH4rNkFTabdr/5dFJ4V6U9Jzkl7vtv+bks7oMvHSEkm3S3pb0qux8/5H9OoCAPQDy9oAAAAAAIYkWlgBAAAAAEMSgRUAAAAAMCQRWAEAAAAAQxKBFQAAAAAwJBFYAQAAAABDEoEVAAAAADAkEVgBAAAAAEMSgRUAAAAAMCT9f25Gzuo1pGVeAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = mt_base[(mt_base.mem_backprop_depth > 0)]\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103: base. Memory transformer')\n",
    "\n",
    "num_mems = np.unique(df_.num_mem_tokens)\n",
    "for num_mem in num_mems:\n",
    "    slice = df_[df_.num_mem_tokens == num_mem].sort_values('effective context')\n",
    "    # plt.plot(slice['effective context'], slice['test ppl'])\n",
    "    slice.groupby('effective context').mean()['test ppl'].plot()\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'{m} mem' for m in num_mems])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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kmZYRUREREREpEpSYBUREREREZEqyffEu3hf7dq1rcTERG+XISIiIiIiIh6wevXqvZZlxRy5vVoE1sTERFatWuXtMkRERERERMQDjDFbjrZdS4JFRERERESkSlJgFRERERERkSpJgVVERERERESqpGpxDauIiIiIiIi3FBYWsn37dvLy8rxdSrUXGBhIQkICfn5+pdpfgVVEREREROQ4tm/fTlhYGImJiRhjvF1OtWVZFvv27WP79u00atSoVMdoSbCIiIiIiMhx5OXlUatWLYXVCjLGUKtWrTLNVCuwioiIiIiInIDCqnuU9XNUYBUREREREanihg4dSmxsLK1atfJ2KZVKgVVERERERKSKGzJkCIsXL/Z2GZVOgVVERERERKSK69KlC9HR0cfdZ8iQIYwcOZJOnTqRlJTE0qVLGTp0KM2bN2fIkCGH9vv888/p3Lkzbdu25bLLLiM7OxuAxMRExo0bR5s2bWjXrh0///wzPXv2pHHjxrz00kuefHvHpC7BIiIiIiIipfTwR+tYv9Ph1jFb1AvnwT4t3TJWRkYGP/74IwsXLqRv374sW7aMGTNm0L59e9asWUNCQgKPPfYYX375JSEhIUyaNIlnnnmGBx54AIAGDRqwZs0aRo8ezZAhQ1i2bBl5eXm0atWKG2+80S01loUCq4iIiIiIyEmiT58+GGNITk4mLi6O5ORkAFq2bElqairbt29n/fr1nHXWWQAUFBTQuXPnQ8f37dsXgOTkZLKzswkLCyMsLIyAgAD2799PZGRkpb4fBVYREREREZFSctdMqKcEBAQAYLPZDj0++LyoqAgfHx+6d+/OG2+8Ua7jK5uuYRUREREREakhOnXqxLJly9i4cSMAOTk5/PXXX16u6tgUWEVERERERKq4q666is6dO/Pnn3+SkJDAzJkzyzVOTEwMs2fP5qqrrqJ169Z07tyZP/74w83Vuo+xLMvbNZxQu3btrFWrVnm7DBERERERqYE2bNhA8+bNvV3GSeNon6cxZrVlWe2O3FczrCJVyIHsAooLnd4uQ0RERESkSlBgFalClr27kdcf/NHbZYiIiIiIVAkKrCJViD3FQe2EMG+XISIiIiJSJSiwilQReTmF7LfnEpcY7u1SRERERESqBAVWkSpizxYHAHGNFFhFRERERECBVaTKsKc4wECsZlhFRERERADw9XYBIlLC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MGfOHPr161euc4SHh9OoUSPeeecdACzL4tdff3VD9RWjwCriQfZUh2ZXRURERKRC7HY7Z599NqeddhodOnTgoosuolevXgCMHTuWL774glNOOYUvv/ySsWPHlvs88+fPZ+bMmZx22mm0bNmSDz/80F1vodyMZVneruGE2rVrZx3eulmkOjiQVcCsu7/nzIFNOL2Hmi6JiIiIVFcbNmygefPm3i7jpHG0z9MYs9qyrHZH7qsZVhEP0fWrIiIiIiIVo8Aq4iH2VAfGZohpGObtUkREREREqiUFVhEPsadkUis+BD9/H2+XIiIiIiJSLSmwiniA5bSwp2YRl6jlwCIiIiIi5aXAKuIB+/fkUnCgSNevioiIiIhUgAKriAccariUGOHlSkREREREqi8FVhEPsKc48A/0IapOsLdLEREREZFq7s8//6RNmzaHvsLDw5kyZQoADz30EPHx8YdeW7RokXeLdTNfbxcgcjKypzqITQzH2Iy3SxERERGRaq5p06asWbMGgOLiYuLj4xkwYMCh10ePHs1dd93lpeo8SzOsIm5WVFDMvu3ZargkIiIiIm731Vdf0bhxYxo2bFjqY5YuXcq5555Lv379SEpKYuzYscyfP58OHTqQnJzMpk2bAEhLS+OSSy6hffv2tG/fnmXLlgEls7iDBw/mnHPOoWHDhrz//vuMGTOG5ORkevXqRWFhoUfeK2iGVcTt0rZm4XRaargkIiIichJaMvsV9mzZ7NYxYxsm0XXI9aXa98033+Sqq67617bp06czd+5c2rVrx+TJk4mKivrPcb/++isbNmwgOjqapKQkhg8fzooVK5g6dSrTpk1jypQp3HbbbYwePZqzzz6brVu30rNnTzZs2ADApk2bWLJkCevXr6dz58689957PPnkkwwYMIBPPvmE/v37V/hzOBrNsIq4mT3V1XCpkRouiYiIiIj7FBQUsHDhQi677LJD20aOHMmmTZtYs2YNdevW5c477zzqse3bt6du3boEBATQuHFjevToAUBycjKpqakAfPnll4waNYo2bdrQt29fHA4H2dnZAPTu3Rs/Pz+Sk5MpLi6mV69e/zneEzTDKuJm9hQHYdGBBIf7e7sUEREREXGz0s6EesKnn35K27ZtiYuLO7Tt8McjRozg4osvPuqxAQEBhx7bbLZDz202G0VFRQA4nU6WL19OYGDgMY+3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O1dH9pmPwpTCPofL9rUFihYHEtl3KbCKiIiIyKBKiE2gMLWQwtT+t/kREdkVGhMhIiIiIiIiUUmBVURERERERKKSAquIiIiIiIhEJQVWERERERERiUoKrCIiIiIiIhKVFFhFREREREQkKimwioiIiIiISFRSYBUREREREZGopMAqIiIiIiIiUUmBVURERERERKKSAquIiIiIiIhEJQVWERERERERiUoKrCIiIiIiIhKVFFhFREREREQkKimwioiIiIiISFRSYBUREREREZGopMAqIiIiIiIiUUmBVURERERERKKSOeciXYcvZWZVwKZI10P22ligOtKVkFFD7UkGi9qSDCa1JxlMak8yWEZCW5ronMvueXBEBFYZHczsTefcEZGuh4wOak8yWNSWZDCpPclgUnuSwTKS25KGBIuIiIiIiEhUUmAVERERERGRqKTAKsPp3khXQEYVtScZLGpLMpjUnmQwqT3JYBmxbUlzWEVERERERCQqqYdVREREREREopICqwwaM/uDmVWa2fthxzLN7FkzW+c9ZnjHzczuMrNPzWyNmR0WuZpLtDGzQjN70cw+NLMPzOxy77jak+w2M0sws9fN7F2vPf3SOz7JzFZ57abUzOK84/He60+980UR/QASdcwsxszeMbNl3mu1JdkjZlZmZu+Z2Woze9M7pp91stvMbIyZLTWzj83sIzM7ZrS0JQVWGUwPAN/scWwe8LxzbirwvPca4FRgqvd1KXDPMNVRRoYO4Crn3IHA0cBlZnYgak+yZ1qBE5xzhwIzgG+a2dHAr4BfO+f2A2qBS7zrLwFqveO/9q4TCXc58FHYa7Ul2Rtfd87NCNtyRD/rZE/cCaxwzk0DDiX0b9SoaEsKrDJonHN/B2p6HD4b+KP3/I/AOWHHH3Qh/wTGmFn+sFRUop5zbotz7m3veT2hf3THofYke8BrFw3eS7/35YATgKXe8Z7tqbOdLQVONDMbntpKtDOz8cDpwO+914bakgwu/ayT3WJm6cBXgfsAnHNtzrntjJK2pMAqQy3XObfFe74VyPWejwM+D7tus3dMpBtvCN1MYBVqT7KHvCGcq4FK4FlgPbDdOdfhXRLeZrrak3d+B5A1rBWWaPYb4Bog6L3OQm1J9pwDnjGzt8zsUu+YftbJ7poEVAH3e9MVfm9myYyStqTAKsPGhZak1rLUssvMLAV4FLjCOVcXfk7tSXaHcy7gnJsBjAeOBKZFtkYyEpnZGUClc+6tSNdFRo3jnHOHERqieZmZfTX8pH7WyS6KBQ4D7nHOzQQa2Tn8FxjZbUmBVYZaRecQA++x0jv+BVAYdt1475gIAGbmJxRW/+Sce8w7rPYke8UbIvUicAyhIVCx3qnwNtPVnrzz6cC24a2pRKmvAGeZWRnwMKGhwHeitiR7yDn3hfdYCTxO6Bdq+lknu2szsNk5t8p7vZRQgB0VbUmBVYbak8CF3vMLgSfCjv/AW6XsaGBH2JAF2cd5c7zuAz5yzv1H2Cm1J9ltZpZtZmO854nASYTmRb8IzPYu69meOtvZbOAFp03LBXDOzXfOjXfOFQHnE2obF6C2JHvAzJLNLLXzOXAy8D76WSe7yTm3FfjczIq9QycCHzJK2pLp300ZLGb2F2AWMBaoAG4C/gosASYAm4A5zrkaL5D8ltCqwk3Axc65NyNQbYlCZnYcsBJ4j53zxK4lNI9V7Ul2i5kdQmixiRhCv6hd4py72cwmE+olywTeAb7nnGs1swTgIUJzp2uA851zGyJTe4lWZjYLuNo5d4bakuwJr9087r2MBf7snFtoZlnoZ53sJjObQWgxuDhgA3Ax3s88RnhbUmAVERERERGRqKQhwSIiIiIiIhKVFFhFREREREQkKimwioiIiIiISFRSYBUREREREZGopMAqIiIiIiIiUUmBVURERi0z+7aZfWRmL3qv/2Jma8zsyt18nzFm9m9hrwvMbOlg13dPmdkMMzttL8qfY2YH7sb1R5jZXXt6PxERkV2lbW1ERGTUMrMVwK3OuVfMLA94xTm33x68TxGwzDl30GDXcTCY2UXAEc65n+xh+QcIfb6oCeEiIiKgHlYRERkFzOx7Zva6ma02s/82sxgzuxE4DrjPzG4HngHGedccb2ZTzGyFmb1lZivNbJr3Xrlm9riZvet9HQssBqZ4ZW83syIze9+7/p9mNj2sLi95PZDJZvYHr17vmNnZ/dT9F2b2nnevxd6xGd77rvHqkhH23r/y3vMT73PEATcDJV79Svq7t5nd6X1fMLNTzOzv3uc7C7jdKz+lR/2+bWbve/X7u3dslpkt854v98qtNrMdZnah9/2/3cze8D7DjwbnT1pERPY1sZGugIiIyN4wswOAEuArzrl2M/sv4ALn3M1mdgJwtXPuTTP7T0K9iDO8cs8Dc51z68zsKOC/gBOAu4CXnXPnmlkMkALMAw4KK1sUVoVSYA5wk5nlA/ne/W4DXnDO/auZjQFeN7PnnHONYXU/FTgbOMo512Rmmd6pB4GfOudeNrObgZuAK7xzsc65I70hwDc5577hhdCuHtb+7g3MB94ws5Xe5zzNObfezJ6k/x7WG4FTnHNfeO/VjXPuNO+ehwP3A38FLgF2OOf+xczigX+Y2TPOuY19/RmKiIj0R4FVRERGuhOBwwkFMYBEoHKgAmaWAhwLPOKVAYj3Hk8AfgDgnAsAOzp7OPuxhFDv7U2Egmtn6DsZOMvMrvZeJwATgI/Cyn4DuN851+Tdr8bM0oExzrmXvWv+CDwSVuYx7/EtoKifOvV5b+fcR2b2Q+DvwJXOufUDfK5O/wAeMLMlYffuxszGAg8Bc5xzO8zsZOAQM5vtXZIOTAUUWEVEZLcosIqIyEhnwB+dc/N3o4wP2N7ZY7o3vJ7HbWZ2CKGe3rlh9TrPObd2b+/RQ6v3GKD/n+MD3ftgYBtQsCs3c87N9XqgTwfe8npSd94o1Av9MHCzc+79sPv/1Dn39K7cQ0REpD+awyoiIiPd88BsM8sBMLNMM5s4UAHnXB2w0cy+7ZUxMzs07P1+7B2P8Xo864HUAd6yFLgGSHfOrfGOPQ381LwuXDOb2Ue5Z4GLzSyps+7OuR1ArZkd713zfeDlPsqG61m/Pu/tfV+uAmYCp3pBtK/yXcxsinNulXPuRqAKKOxxyWJgjXPu4R73/7GZ+b332N/Mkr/kM4iIiPSiwCoiIiOac+5D4HrgGTNbQygE5u9C0QuAS8zsXeADQnNJAS4Hvm5m7xEadnugc24boXmY71toAaeelgLnExoe3OkWwA+sMbMPvNc9674CeBJ408xWA51DeC8ktAjSGmAGoUWVBvIicGDnokt93dsLr/cRmtNbTmie6e/NLIFQD+nPvQWapvR479sttCjU+8CrwLs9zl8NnBy28NJZwO+BD4G3vXL/jUZ1iYjIHtC2NiIiIiIiIhKV1MMqIiIiIiIiUUmBVURERERERKKSAquIiIiIiIhEJQVWERERERERiUoKrCIiIiIiIhKVFFhFREREREQkKimwioiIiIiISFRSYBUREREREZGo9P8BA4h8KUSD1M0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# df_ = mt_base[(mt_base.mem_backprop_depth > 0)]\n",
    "df_ = mt_base#[mt_base.num_mem_tokens == 25]\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103: base. Memory transformer')\n",
    "\n",
    "num_mems = np.unique(df_.num_mem_tokens)\n",
    "for num_mem in num_mems:\n",
    "    slice = df_[df_.num_mem_tokens == num_mem].sort_values('effective context')\n",
    "    # plt.plot(slice['effective context'], slice['test ppl'])\n",
    "    slice.groupby('effective context').mean()['test ppl'].plot()\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'{m} mem' for m in num_mems])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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BD5SAQAAOhJ/XQFAG7iw08pfbVXJqQrl3ZejtMzkS28EAACAy0JgBYA2eLtgv/ZtPKVrPzxGQ8Zmel0OAADowe655x4NGDBAOTk5DZafOXNGCxYs0NixY7VgwQIVFRV5VGHbEVgB4DLt33Jab/5tj8bNGKjJNw7zuhwAANDDLVmyRAUFBRct/+53v6v58+dr165dmj9/vr773e96UF37EFgB4DIUnyrXiie2qO/QdN3wyfEyM69LAgAAPdycOXPUp0+fi5Y///zzuvvuuyVJd999t/76179e1ObJJ5/UbbfdpgULFig7O1s///nP9cMf/lBXXXWVZs6cqTNnzkiSdu/erfz8fF199dWaPXu2tm/fLikSlh988EHNnDlTo0aN0po1a3TPPfdowoQJWrJkSbuPLaHdewCAHqK6KqRlj26SJC1amqPEJL/HFQEAgHjyvXXf0/Yz2zt0n+P7jNe/zvjXNm17/PhxDR4cueXeoEGDdPz48Sbbbd68We+++64qKio0ZswYfe9739O7776rhx56SE8//bS+9KUv6f7779cjjzyisWPH6s0339TnPvc5rVq1SpJUVFSk119/XS+88IIWL16stWvX6vHHH9f06dO1YcMGTZkypU31SwRWAGgV55xeemaHTh0q1c2fv1IZ/Xt5XRIAAECrmVmzI8NuvPFGBQIBBQIBZWRk6JZbbpEk5ebmauPGjSotLdVrr72mO++8s26bysrKuse33HKLzEy5ubkaOHCgcnNzJUmTJk3Svn37CKwAEGubXzqsHW8e04xbRiorp6/X5QAAgDjU1p7QWBk4cKCOHj2qwYMH6+jRoxowYECT7ZKTL9ztwOfz1T33+XyqqalROBxWZmamNmzY0OL29betv317cA0rAFzC0ffP6tU/7lJ2bl9NW5TtdTkAAACtsnjxYj311FOSpKeeekq33nprm/YTDAY1cuRIPfvss5IiI8/ee++9DquzJQRWAGhB2blKFfxiswJ9U3TTZybKfEyyBAAA4stdd92lWbNmaceOHRo2bJieeOIJSdLDDz+sFStWaOzYsVq5cqUefvjhNr/GM888oyeeeEJXXnmlJk2apOeff76jym+ROec65YXaY9q0aW79+vVelwGghwmFwnr+R+/q5IESffhfp6nv0HSvSwIAAHFm27ZtmjBhgtdldClNvWdm9rZzblrjtvSw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",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = mt_base[mt_base.mem_backprop_depth > 0]\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103: base. Memory transformer')\n",
    "\n",
    "num_mems = np.unique(df_.num_mem_tokens)\n",
    "for num_mem in num_mems:\n",
    "    slice = df_[df_.num_mem_tokens == num_mem].sort_values('mem_backprop_depth')\n",
    "    plt.plot(slice.mem_backprop_depth, slice['test ppl'])\n",
    "\n",
    "    # plt.scatter(slice['effective context'], )\n",
    "\n",
    "plt.xlabel('backprop depth')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'{m} mem' for m in num_mems])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_ = mt_base\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103: base')\n",
    "\n",
    "bpds = np.unique(df_.mem_backprop_depth)\n",
    "for bpd in bpds:\n",
    "    slice = df_[df_.mem_backprop_depth == bpd]\n",
    "\n",
    "    plt.scatter(slice['effective context'], slice['test ppl'])\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'bpd-{int(b)}' for b in bpds])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QvC9Sc6J/z8CwFZUazv8a9gAAJIkVXVVku+21j4w2r0AMPb4F00AYIepql/qX4q8W1X9WnozqteOclsAjFEWXQIAdqT9k3w2va/euS/J6f1VlAFgyFwSDAAAQCe5JBgAAIBOElgBAADopDFxD+u+++7bZsyYMdptAAAAMAJuu+22f2+t7bd5fUwE1hkzZmRgYGC02wAAAGAEVNUPt1R3STAAAACdJLACAADQSQIrAAAAnTQm7mEFAAAYD5566qncd999Wbt27Wi3MiomT56cgw46KJMmTdqm/QVWAACAneS+++7LC17wgsyYMSNVNdrt7FSttTz88MO57777cvDBB2/TMS4JBgAA2EnWrl2bF77whbtcWE2SqsoLX/jCIc0uC6wAAAA70a4YVjcY6mcXWAEAAHYhK1asyGGHHbbdx++xxx5brD/55JN585vfnJe+9KU56qijsmLFiu1+jw0EVgAAAIbtYx/7WPbee+/ceeedOfvss/Oe97xn2GMKrAAAAB117e0rM/+DX8rBf3h95n/wS7n29pU7ZNx169bllFNOycyZM3PiiSfm8ccfz4wZM3Luuedm1qxZOfLII3PnnXcmSe6+++7Mmzcvs2bNynnnnbfVMT/3uc/lbW97W5LkxBNPzA033JDW2rD6FFgBAAA66NrbV+a9n12WlY88kZZk5SNP5L2fXbZDQusdd9yRM844I8uXL8+ee+6ZSy+9NEkyderULFu2LGeeeWbOOuusJMmCBQty+umnZ9myZZk2bdpWx1y5cmWmT5+eJJk4cWKmTp2ahx9+eFh9CqwAAAAd9KEv3JEnnlq/Se2Jp9bnQ1+4Y9hjT58+PfPnz0+SnHrqqbnpppuSJCeffPLGx1tuuSVJcvPNN2+sn3baacN+76EQWAEAADro/keeGFJ9KDZfrXfD9uD61p5v8L73vS9z5szJnDlzkiQHHnhg7r333iS9S47XrFmTF77whcPqU2AFAADooAP2mjKk+lDcc889G2dQr7jiihx99NFJkquuumrj47x585Ik8+fPz5VXXpkkufzyyzeOcckll2TJkiVZsmRJkuQNb3hDLrvssiTJNddck2OOOWbYX+EjsAIAAHTQOa8/NFMmTdikNmXShJzz+kOHPfahhx6axYsXZ+bMmVm9enVOP/30JMnq1asze/bsLFq0KAsXLkySLFq0KIsXL86sWbOycuXW7599+9vfnocffjgvfelL8+EPfzgf/OAHh91nDXfVpp1h7ty5bWBgYLTbADpgzXXX5cGFH8m6Vasycdq0vOjsszL1+ONHuy0AgG2yfPnyzJw5c5v3v/b2lfnQF+7I/Y88kQP2mpJzXn9oTjj8wBHpbcaMGRkYGMi+++47IuNvsKXfQVXd1lqbu/m+E0e0E4AdaM1112XV+89PW7s2SbLu/vuz6v3nJ4nQCgCMSyccfuCIBdSxwCXBwJjx4MKPbAyrG7S1a/Pgwo+MTkMAAOPIihUrRnx2dagEVmDMWLdq1ZDqAACMbQIrMGZM3MoXVW+tDgDA2CawAmPGi84+KzV58ia1mjw5Lzr7rNFpCACAEWXRJWDM2LCwklWCAQB2DWZYgTFl6vHH5xe/dENmLv9OfvFLNwirAABDtGLFihx22GHbffwee+yxxfpXvvKVHHHEEZk4cWKuueaa7R5/MIEVAACAYXvxi1+cj3/843nrW9+6w8YUWAEAALpq6dXJwsOSC/bqPS69eocMu27dupxyyimZOXNmTjzxxDz++OOZMWNGzj333MyaNStHHnlk7rzzziTJ3XffnXnz5mXWrFk577zztjrmjBkzMnv27Oy2246LmQIrAABAFy29OrnuXcmae5O03uN179ohofWOO+7IGWeckeXLl2fPPffMpZdemiSZOnVqli1bljPPPDNnnXVWkmTBggU5/fTTs2zZskzbyd/OILACAAB00Q0XJU89sWntqSd69WGaPn165s+fnyQ59dRTc9NNNyVJTj755I2Pt9xyS5Lk5ptv3lg/7bTThv3eQyGwAgAAdNGa+4ZWH4Kq2uL24PrWnm/wvve9L3PmzMmcOXOG3c/WCKwAAABdNPWgodWH4J577tk4g3rFFVfk6KOPTpJcddVVGx/nzZuXJJk/f36uvPLKJMnll1++cYxLLrkkS5YsyZIlS4bdz9aMeGCtqglVdXtV/W1/++NVdXdVLen/zBnpHgAAAMacY89PJk3ZtDZpSq8+TIceemgWL16cmTNnZvXq1Tn99NOTJKtXr87s2bOzaNGiLFy4MEmyaNGiLF68OLNmzcrKlSu3OubXv/71HHTQQfn0pz+d3/u938srX/nKYfdZrbVhD/Ksb1D17iRzk+zZWvvNqvp4kr9trW3zF/PMnTu3DQwMjFSLAAAAO8Xy5cszc+bMbT9g6dW9e1bX3NebWT32/GT2SSPS24wZMzIwMJB99913RMbfYEu/g6q6rbU2d/N9J45kI1V1UJLjklyS5N0j+V4AAADjzuyTRiygjgUjfUnwR5Kcm+TpzeqXVNXSqlpYVc/f0oFV9btVNVBVAw899NAItwkAALBrW7FixYjPrg7ViAXWqvrNJA+21m7b7KX3Jnl5kl9Ksk+S92zp+Nban7fW5rbW5u63334j1SYAAAAdNZIzrPOTvKGqViS5MskxVfXJ1tqq1vNkkr9KcuQI9gAAAMAYNWKBtbX23tbaQa21GUnekuRLrbVTq2paklTvi3xOSPKtkeoBAACAsWtEF13aisurar8klWRJkneOQg8AAAB03Ih/D2uStNb+ubX2m/3nx7TWZrXWDmutndpae3Rn9AAAAEBvcaXDDjtsu4/fY489tlj/8Ic/nFe84hWZPXt2jj322Pzwhz/c7vfYYKcEVgAAAMa3ww8/PAMDA1m6dGlOPPHEnHvuucMeU2AFAADoqOt/cH1ed83rMvuy2XndNa/L9T+4foeMu27dupxyyimZOXNmTjzxxDz++OOZMWNGzj333MyaNStHHnlk7rzzziTJ3XffnXnz5mXWrFk577zztjrma1/72vzcz/1ckuTVr3517rvvvmH3KbACAAB00PU/uD4XfPWCrHpsVVpaVj22Khd89YIdElrvuOOOnHHGGVm+fHn23HPPXHrppUmSqVOnZtmyZTnzzDNz1llnJUkWLFiQ008/PcuWLcu0adO2afyPfexj+fVf//Vh9ymwAgAAdNCibyzK2vVrN6mtXb82i76xaNhjT58+PfPnz0+SnHrqqbnpppuSJCeffPLGx1tuuSVJcvPNN2+sn3baac859ic/+ckMDAzknHPOGXafAisAAEAHPfDYA0OqD0XvW0afuT24vrXnG7zvfe/LnDlzMmfOnI21f/qnf8oll1ySz3/+83n+858/7D4FVgAAgA7af/f9h1QfinvuuWfjDOoVV1yRo48+Okly1VVXbXycN29ekmT+/Pm58sorkySXX375xjEuueSSLFmyJEuWLEmS3H777fm93/u9fP7zn8+LXvSiYfeYCKwAAACdtOCIBZk8YfImtckTJmfBEQuGPfahhx6axYsXZ+bMmVm9enVOP/30JMnq1asze/bsLFq0KAsXLkySLFq0KIsXL86sWbOycuXKrY55zjnn5NFHH82b3vSmzJkzJ294wxuG3We11oY9yEibO3duGxgYGO02AAAAhmX58uWZOXPmNu9//Q+uz6JvLMoDjz2Q/XffPwuOWJDjXnLciPQ2Y8aMDAwMZN999x2R8TfY0u+gqm5rrc3dfN+JI9oJAAAA2+24lxw3YgF1LBBYAQAAyIoVK0a7hWdwDysAAACdJLACAADQSQIrAAAAnSSwAgAA0EkCKwAAwC5kxYoVOeyww7b7+D322GOL9f/1v/5XZs2alTlz5uToo4/Od77zne1+jw0EVgAAAIbtrW99a5YtW5YlS5bk3HPPzbvf/e5hjymwAgAAdNSa667L9485NstnviLfP+bYrLnuuh0y7rp163LKKadk5syZOfHEE/P4449nxowZOffcczNr1qwceeSRufPOO5Mkd999d+bNm5dZs2blvPPO2+qYe+6558bnjz32WKpq2H0KrAAAAB205rrrsur952fd/fcnrWXd/fdn1fvP3yGh9Y477sgZZ5yR5cuXZ88998yll16aJJk6dWqWLVuWM888M2eddVaSZMGCBTn99NOzbNmyTJs27VnHXbx4cQ455JCce+65+ehHPzrsPgVWAACADnpw4UfS1q7dpNbWrs2DCz8y7LGnT5+e+fPnJ0lOPfXU3HTTTUmSk08+eePjLbfckiS5+eabN9ZPO+20Zx3393//93PXXXflT/7kT3LxxRcPu0+BFQAAoIPWrVo1pPpQbH657obtwfWtPd/gfe97X+bMmZM5c+Y847W3vOUtufbaa4fdp8AKAADQQRO3cvnt1upDcc8992ycQb3iiity9NFHJ0muuuqqjY/z5s1LksyfPz9XXnllkuTyyy/fOMYll1ySJUuWZMmSJUmS73//+xtfu/766/OLv/iLw+5TYAUAAOigF519Vmry5E1qNXlyXnT2WcMe+9BDD83ixYszc+bMrF69OqeffnqSZPXq1Zk9e3YWLVqUhQsXJkkWLVqUxYsXZ9asWVm5cuVWx/yzP/uzvPKVr8ycOXPy4Q9/OJdddtmw+6zW2rAHGWlz585tAwMDo90GAADAsCxfvjwzZ87c5v3XXHddHlz4kaxbtSoTp03Li84+K1OPP35EepsxY0YGBgay7777jsj4G2zpd1BVt7XW5m6+78QR7QQAAIDtNvX440csoI4FAisAAABZsWLFaLfwDO5hBQAAoJMEVgAAADpJYAUAAKCTBFYAAAA6SWAFAADYhaxYsSKHHXbYdh+/xx57POvrn/nMZ1JV2RFfTSqwAgAAsEP85Cc/yaJFi3LUUUftkPEEVgAAgI763q0P5LI/ujmL3/mlXPZHN+d7tz6wQ8Zdt25dTjnllMycOTMnnnhiHn/88cyYMSPnnntuZs2alSOPPDJ33nlnkuTuu+/OvHnzMmvWrJx33nnPOu773//+vOc978nkyZN3SJ8CKwAAQAd979YHcuPl382jP3oySfLoj57MjZd/d4eE1jvuuCNnnHFGli9fnj333DOXXnppkmTq1KlZtmxZzjzzzJx11llJkgULFuT000/PsmXLMm3atK2O+Y1vfCP33ntvjjvuuGH3t4HACgAA0EG3fO6urPvp05vU1v306dzyubuGPfb06dMzf/78JMmpp56am266KUly8sknb3y85ZZbkiQ333zzxvppp522xfGefvrpvPvd786f/umfDru3wQRWAACADtows7qt9aGoqi1uD65v7fkG73vf+zJnzpzMmTMnP/nJT/Ktb30rr3nNazJjxox87Wtfyxve8IZhL7wksAIAAHTQHvs8f0j1objnnns2zqBeccUVOfroo5MkV1111cbHefPmJUnmz5+fK6+8Mkly+eWXbxzjkksuyZIlS7JkyZJMnTo1//7v/54VK1ZkxYoVefWrX53Pf/7zmTt37rD6FFgBAAA6aN4bD8nE520a2SY+b7fMe+Mhwx770EMPzeLFizNz5sysXr06p59+epJk9erVmT17dhYtWpSFCxcmSRYtWpTFixdn1qxZWbly5bDfeyiqtbZT33B7zJ07t+2I7/ABAAAYTcuXL8/MmTO3ef/v3fpAbvncXXn0R09mj32en3lvPCQvO2r/EeltxowZGRgYyL777jsi42+wpd9BVd3WWnvGdOzEEe0EAACA7fayo/YfsYA6FgisAAAAZMWKFaPdwjO4hxUAAIBOElgBAAB2orGwjtBIGepnF1gBAAB2ksmTJ+fhhx/eJUNray0PP/xwJk+evM3HuIcVAABgJznooINy33335aGHHhrtVkbF5MmTc9BBB23z/gIrAADATjJp0qQcfPDBo93GmOGSYAAAADpJYAUAAKCTBFYAAAA6SWAFAACgkwRWAAAAOklgBQAAoJMEVgAAADpJYAUAAKCTBFYA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",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = mt\n",
    "plt.figure(figsize=(16, 8))\n",
    "plt.title('Wt-103: base+large')\n",
    "\n",
    "bpds = np.unique(df_.mem_backprop_depth)\n",
    "for bpd in bpds:\n",
    "    slice = df_[df_.mem_backprop_depth == bpd]\n",
    "\n",
    "    plt.scatter(slice['effective context'], slice['test ppl'])\n",
    "\n",
    "plt.xlabel('effective context size')\n",
    "plt.ylabel('ppl')\n",
    "plt.legend([f'bpd-{int(b)}' for b in bpds])\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "3ad594eba56fa4d30e478d0eb2c02077805d7e655fd2c7b71fc86bcad8bf7b09"
  },
  "kernelspec": {
   "display_name": "Python 3.9.0 64-bit ('cudaenv': conda)",
   "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.0"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
