{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "c48057f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import pickle\n",
    "import re\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from sklearn.metrics import roc_auc_score\n",
    "from ood_metrics import fpr_at_95_tpr\n",
    "%config InlineBackend.figure_format='retina'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "bf044cda",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_checkpoint(path):\n",
    "  with open(path, \"rb\") as f:\n",
    "    checkpoint_dict = pickle.load(f)\n",
    "  return checkpoint_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "89a4764b",
   "metadata": {},
   "outputs": [],
   "source": [
    "agw_table = pd.read_csv('../sm_plotting/metrics.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "0b6daa12",
   "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>accuracy</th>\n",
       "      <th>dataset</th>\n",
       "      <th>ece</th>\n",
       "      <th>experiment</th>\n",
       "      <th>log_likelihood</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.907100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.059492</td>\n",
       "      <td>19187810</td>\n",
       "      <td>-0.306665</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>81</th>\n",
       "      <td>0.869900</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.027455</td>\n",
       "      <td>sgd-all-chains</td>\n",
       "      <td>-0.453798</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>162</th>\n",
       "      <td>0.884000</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.053437</td>\n",
       "      <td>mfvi</td>\n",
       "      <td>-0.361687</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>243</th>\n",
       "      <td>0.890700</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.028399</td>\n",
       "      <td>deep-ensemble-subset-chains</td>\n",
       "      <td>-0.336812</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>324</th>\n",
       "      <td>0.898700</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.066116</td>\n",
       "      <td>sgld</td>\n",
       "      <td>-0.331408</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>325</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.048652</td>\n",
       "      <td>sgld</td>\n",
       "      <td>-0.051609</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>406</th>\n",
       "      <td>0.898400</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.079493</td>\n",
       "      <td>sgld-momentum</td>\n",
       "      <td>-0.343637</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>407</th>\n",
       "      <td>0.999731</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.087765</td>\n",
       "      <td>sgld-momentum</td>\n",
       "      <td>-0.099440</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>488</th>\n",
       "      <td>0.902100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.039544</td>\n",
       "      <td>sgld-momentum_clr_noprec</td>\n",
       "      <td>-0.303256</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>489</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.007403</td>\n",
       "      <td>sgld-momentum_clr_noprec</td>\n",
       "      <td>-0.007495</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>570</th>\n",
       "      <td>0.892900</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.044525</td>\n",
       "      <td>sgld-momentum_clr_prec</td>\n",
       "      <td>-0.338153</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>571</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.003387</td>\n",
       "      <td>sgld-momentum_clr_prec</td>\n",
       "      <td>-0.003404</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     accuracy  dataset       ece                   experiment  log_likelihood\n",
       "0    0.907100  cifar10  0.059492                     19187810       -0.306665\n",
       "81   0.869900  cifar10  0.027455               sgd-all-chains       -0.453798\n",
       "162  0.884000  cifar10  0.053437                         mfvi       -0.361687\n",
       "243  0.890700  cifar10  0.028399  deep-ensemble-subset-chains       -0.336812\n",
       "324  0.898700  cifar10  0.066116                         sgld       -0.331408\n",
       "325  1.000000  cifar10  0.048652                         sgld       -0.051609\n",
       "406  0.898400  cifar10  0.079493                sgld-momentum       -0.343637\n",
       "407  0.999731  cifar10  0.087765                sgld-momentum       -0.099440\n",
       "488  0.902100  cifar10  0.039544     sgld-momentum_clr_noprec       -0.303256\n",
       "489  1.000000  cifar10  0.007403     sgld-momentum_clr_noprec       -0.007495\n",
       "570  0.892900  cifar10  0.044525       sgld-momentum_clr_prec       -0.338153\n",
       "571  1.000000  cifar10  0.003387       sgld-momentum_clr_prec       -0.003404"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "agw_table.loc[agw_table['dataset'] == 'cifar10']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "20130e97",
   "metadata": {},
   "outputs": [],
   "source": [
    "match_types_candidates = [\n",
    "    'None',\n",
    "#     'channel_wise_joint',\n",
    "#     'feature',\n",
    "#     'channel_wise_sep', # Need rerun\n",
    "    'channel_wise_sep',\n",
    "    'channel_wise_sep_cov_mean',\n",
    "    'channel_wise_sep_cov_mean_inputonly',\n",
    "    'channel_wise_sep_cov_mean_BA',\n",
    "    'spatial_joint',\n",
    "    'spatial_sep',\n",
    "    'spatial_sep_cov_mean',\n",
    "#     'spatial_joint',\n",
    "#     'spatial_joint_cov',\n",
    "#     'spatial_sep_cov_mean',\n",
    "    'batch_norm',\n",
    "    'None_sgd_3',\n",
    "    'None_sgd_ens',\n",
    "    'None_sgd_ens_large',\n",
    "    'batch_norm_sgd_3',\n",
    "    'batch_norm_sgd_ens',\n",
    "    'batch_norm_sgd_ens_large',\n",
    "    'channel_wise_sep_cov_mean_sgd_3',\n",
    "    'channel_wise_sep_cov_mean_sgd_ens',\n",
    "    'channel_wise_sep_cov_mean_sgd_ens_large',\n",
    "    \n",
    "#     'channel_wise_sep_cov_mean_BA'\n",
    "    # 'fft_spatial',\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "fb073fda",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_auroc(y_in, y_out):\n",
    "    entropy_in = - (y_in * np.log(y_in)).sum(-1)\n",
    "    entropy_out = - (y_out * np.log(y_out)).sum(-1)\n",
    "    entropy_in = -y_in.max(-1)\n",
    "    entropy_out = -y_out.max(-1)\n",
    "    y = np.concatenate([np.zeros(10000,), np.ones(10000,)])\n",
    "    score = np.concatenate([entropy_in, entropy_out])\n",
    "    return roc_auc_score(\n",
    "        y, score\n",
    "    )\n",
    "\n",
    "def compute_fpr95(y_in, y_out):\n",
    "    entropy_in = - (y_in * np.log(y_in)).sum(-1)\n",
    "    entropy_out = - (y_out * np.log(y_out)).sum(-1)\n",
    "    entropy_in = -y_in.max(-1)\n",
    "    entropy_out = -y_out.max(-1)\n",
    "    y = np.concatenate([np.zeros(10000,), np.ones(10000,)])\n",
    "    score = np.concatenate([entropy_in, entropy_out])\n",
    "    return fpr_at_95_tpr(\n",
    "        score, y\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "4b1e937b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.018775644\n"
     ]
    }
   ],
   "source": [
    "log_dir = '/home/ooo123/data/sm_sgd_result_log'\n",
    "dict_name = ['sgd_de_cifar10.pkl', 'sgd_de_cifar100.pkl', 'sgd_de_svhn_cropped.pkl']\n",
    "mtype = 'de_aug'\n",
    "logs_de_aug = []\n",
    "for d in dict_name:\n",
    "    logs_de_aug.append(load_checkpoint(os.path.join(log_dir, d)))\n",
    "cifar10_result = logs_de_aug[0]\n",
    "test_stat[mtype] = (cifar10_result['acc'],cifar10_result['nll'])\n",
    "print(cifar10_result['ece'])\n",
    "# auroc\n",
    "in_dist_pred = cifar10_result['prediction']\n",
    "cifar100_pred = logs_de_aug[1]['prediction']\n",
    "svhn_pred = logs_de_aug[2]['prediction']\n",
    "cifar100_auroc[mtype] = compute_auroc(in_dist_pred, cifar100_pred)\n",
    "cifar100_fpr95[mtype] = compute_fpr95(in_dist_pred, cifar100_pred)\n",
    "svhn_auroc[mtype] = compute_auroc(in_dist_pred, svhn_pred[:10000])\n",
    "svhn_fpr95[mtype] = compute_fpr95(in_dist_pred, svhn_pred[:10000])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08f79eea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "d294b69b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "None\n",
      "0.06803607\n",
      "channel_wise_sep\n",
      "0.08605127\n",
      "channel_wise_sep_cov_mean\n",
      "0.09234526\n",
      "channel_wise_sep_cov_mean_inputonly\n",
      "0.0674208\n",
      "channel_wise_sep_cov_mean_BA\n",
      "0.084262215\n",
      "spatial_joint\n",
      "0.0703764\n",
      "spatial_sep\n",
      "0.067916386\n",
      "spatial_sep_cov_mean\n",
      "0.06762212\n",
      "batch_norm\n",
      "0.06880096\n",
      "None_sgd_3\n",
      "0.11442857\n",
      "None_sgd_ens\n",
      "0.026496949\n",
      "None_sgd_ens_large\n",
      "0.032147445\n",
      "batch_norm_sgd_3\n",
      "0.11484189\n",
      "batch_norm_sgd_ens\n",
      "0.025723653\n",
      "batch_norm_sgd_ens_large\n",
      "0.03142343\n",
      "channel_wise_sep_cov_mean_sgd_3\n",
      "0.11731921\n",
      "channel_wise_sep_cov_mean_sgd_ens\n",
      "0.025329513\n",
      "channel_wise_sep_cov_mean_sgd_ens_large\n",
      "0.031860877\n"
     ]
    }
   ],
   "source": [
    "base_dir = '/home/ooo123/data/shift_match_log'\n",
    "test_stat = {}\n",
    "cifar100_auroc = {}\n",
    "cifar100_fpr95 = {}\n",
    "cifar100_fpr95 = {}\n",
    "svhn_auroc = {}\n",
    "svhn_fpr95 = {}\n",
    "for mtype in match_types_candidates:\n",
    "    ckpts = os.listdir(base_dir)\n",
    "    ctypes = ['cifar10', 'cifar100'\n",
    "              , 'svhn_cropped']\n",
    "    logs_shift_match = []\n",
    "    for ctype in ctypes:\n",
    "        for ckpt in ckpts:\n",
    "            if f'{mtype}.pkl' in ckpt:\n",
    "                if (ctype + '_') in ckpt:\n",
    "                    logs_shift_match.append(load_checkpoint(os.path.join(base_dir, ckpt)))\n",
    "    cifar10_result = logs_shift_match[0]\n",
    "    print(mtype)\n",
    "    test_stat[mtype] = (cifar10_result['acc'],cifar10_result['nll'])\n",
    "    print(cifar10_result['ece'])\n",
    "    # auroc\n",
    "    in_dist_pred = cifar10_result['prediction']\n",
    "    cifar100_pred = logs_shift_match[1]['prediction']\n",
    "    svhn_pred = logs_shift_match[2]['prediction']\n",
    "    cifar100_auroc[mtype] = compute_auroc(in_dist_pred, cifar100_pred)\n",
    "    cifar100_fpr95[mtype] = compute_fpr95(in_dist_pred, cifar100_pred)\n",
    "    svhn_auroc[mtype] = compute_auroc(in_dist_pred, svhn_pred[:10000])\n",
    "    svhn_fpr95[mtype] = compute_fpr95(in_dist_pred, svhn_pred[:10000])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "f50fe151",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\n",
      "\"19187810\": 0.9031999707221985,\n",
      "\"channel_wise_sep\": 0.9019999504089355,\n",
      "\"channel_wise_sep_cov_mean\": 0.9019999504089355,\n",
      "\"channel_wise_sep_cov_mean_inputonly\": 0.9023999571800232,\n",
      "\"channel_wise_sep_cov_mean_BA\": 0.9023999571800232,\n",
      "\"spatial_joint\": 0.8980000615119934,\n",
      "\"spatial_sep\": 0.902999997138977,\n",
      "\"spatial_sep_cov_mean\": 0.9025999903678894,\n",
      "\"batch_norm\": 0.9041000008583069,\n",
      "\"None_sgd_3\": 0.8394999504089355,\n",
      "\"None_sgd_ens\": 0.8711999654769897,\n",
      "\"None_sgd_ens_large\": 0.8833999633789062,\n",
      "\"batch_norm_sgd_3\": 0.8394999504089355,\n",
      "\"batch_norm_sgd_ens\": 0.8711999654769897,\n",
      "\"batch_norm_sgd_ens_large\": 0.8828999996185303,\n",
      "\"channel_wise_sep_cov_mean_sgd_3\": 0.8389999866485596,\n",
      "\"channel_wise_sep_cov_mean_sgd_ens\": 0.8712999820709229,\n",
      "\"channel_wise_sep_cov_mean_sgd_ens_large\": 0.8835999965667725,\n",
      "}\n"
     ]
    }
   ],
   "source": [
    "print('{')\n",
    "for k, v in list(test_stat.items()):\n",
    "    if k == 'None':\n",
    "        k = '19187810'\n",
    "    print(f'\"{k}\": {float(v[0])},')\n",
    "print('}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "f1a4414d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\n",
      "\"19187810\": -0.3202279806137085,\n",
      "\"channel_wise_sep\": -0.3406379520893097,\n",
      "\"channel_wise_sep_cov_mean\": -0.3481036126613617,\n",
      "\"channel_wise_sep_cov_mean_inputonly\": -0.3205242156982422,\n",
      "\"channel_wise_sep_cov_mean_BA\": -0.338232159614563,\n",
      "\"spatial_joint\": -0.33371803164482117,\n",
      "\"spatial_sep\": -0.3204018175601959,\n",
      "\"spatial_sep_cov_mean\": -0.3204392194747925,\n",
      "\"batch_norm\": -0.32004600763320923,\n",
      "\"None_sgd_3\": -0.7659789323806763,\n",
      "\"None_sgd_ens\": -0.43451908230781555,\n",
      "\"None_sgd_ens_large\": -0.3602153956890106,\n",
      "\"batch_norm_sgd_3\": -0.7662465572357178,\n",
      "\"batch_norm_sgd_ens\": -0.4348048269748688,\n",
      "\"batch_norm_sgd_ens_large\": -0.36011484265327454,\n",
      "\"channel_wise_sep_cov_mean_sgd_3\": -0.7966760396957397,\n",
      "\"channel_wise_sep_cov_mean_sgd_ens\": -0.44303521513938904,\n",
      "\"channel_wise_sep_cov_mean_sgd_ens_large\": -0.36081600189208984,\n",
      "}\n"
     ]
    }
   ],
   "source": [
    "print('{')\n",
    "for k, v in list(test_stat.items()):\n",
    "    if k == 'None':\n",
    "        k = '19187810'\n",
    "    print(f'\"{k}\": {-float(v[1])},')\n",
    "print('}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "f356539d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'None': 0.2987,\n",
       " 'channel_wise_sep': 0.266,\n",
       " 'channel_wise_sep_cov_mean': 0.2739,\n",
       " 'channel_wise_sep_cov_mean_inputonly': 0.2908,\n",
       " 'channel_wise_sep_cov_mean_BA': 0.2807,\n",
       " 'spatial_joint': 0.2794,\n",
       " 'spatial_sep': 0.271,\n",
       " 'spatial_sep_cov_mean': 0.2682,\n",
       " 'batch_norm': 0.2383,\n",
       " 'None_sgd_3': 0.6247999999999999,\n",
       " 'None_sgd_ens': 0.5308,\n",
       " 'None_sgd_ens_large': 0.4532,\n",
       " 'batch_norm_sgd_3': 0.3967,\n",
       " 'batch_norm_sgd_ens': 0.3585,\n",
       " 'batch_norm_sgd_ens_large': 0.281,\n",
       " 'channel_wise_sep_cov_mean_sgd_3': 0.98805,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens': 0.4412,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens_large': 0.3536,\n",
       " 'de_aug': 0.1561}"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "svhn_fpr95"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "88d374a0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'None': 0.4566,\n",
       " 'channel_wise_sep': 0.4787,\n",
       " 'channel_wise_sep_cov_mean': 0.4791,\n",
       " 'channel_wise_sep_cov_mean_inputonly': 0.464,\n",
       " 'channel_wise_sep_cov_mean_BA': 0.4797,\n",
       " 'spatial_joint': 0.4499,\n",
       " 'spatial_sep': 0.4534,\n",
       " 'spatial_sep_cov_mean': 0.4541,\n",
       " 'batch_norm': 0.4589,\n",
       " 'None_sgd_3': 0.5786,\n",
       " 'None_sgd_ens': 0.5308,\n",
       " 'None_sgd_ens_large': 0.4904,\n",
       " 'batch_norm_sgd_3': 0.5754,\n",
       " 'batch_norm_sgd_ens': 0.5217,\n",
       " 'batch_norm_sgd_ens_large': 0.4891,\n",
       " 'channel_wise_sep_cov_mean_sgd_3': 0.9968,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens': 0.6648,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens_large': 0.5238,\n",
       " 'de_aug': 0.3466}"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cifar100_fpr95"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "c0e69946",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'None': 0.8512962949999998,\n",
       " 'channel_wise_sep': 0.847886875,\n",
       " 'channel_wise_sep_cov_mean': 0.8471769450000001,\n",
       " 'channel_wise_sep_cov_mean_inputonly': 0.85104593,\n",
       " 'channel_wise_sep_cov_mean_BA': 0.8477065699999999,\n",
       " 'spatial_joint': 0.85331914,\n",
       " 'spatial_sep': 0.8544600550000001,\n",
       " 'spatial_sep_cov_mean': 0.8541479799999999,\n",
       " 'batch_norm': 0.8580869450000002,\n",
       " 'None_sgd_3': 0.78005486,\n",
       " 'None_sgd_ens': 0.8109893,\n",
       " 'None_sgd_ens_large': 0.8302342300000002,\n",
       " 'batch_norm_sgd_3': 0.78264627,\n",
       " 'batch_norm_sgd_ens': 0.816509775,\n",
       " 'batch_norm_sgd_ens_large': 0.8361727800000001,\n",
       " 'channel_wise_sep_cov_mean_sgd_3': 0.676377165,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens': 0.78617481,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens_large': 0.81901441,\n",
       " 'de_aug': 0.89210254}"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cifar100_auroc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "2a8e53bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'None': 0.874216255,\n",
       " 'channel_wise_sep': 0.9257771650000002,\n",
       " 'channel_wise_sep_cov_mean': 0.9212283800000001,\n",
       " 'channel_wise_sep_cov_mean_inputonly': 0.9082244449999999,\n",
       " 'channel_wise_sep_cov_mean_BA': 0.9197446950000001,\n",
       " 'spatial_joint': 0.9224571349999999,\n",
       " 'spatial_sep': 0.9208961050000001,\n",
       " 'spatial_sep_cov_mean': 0.922294505,\n",
       " 'batch_norm': 0.9360535750000001,\n",
       " 'None_sgd_3': 0.7128356999999999,\n",
       " 'None_sgd_ens': 0.77204528,\n",
       " 'None_sgd_ens_large': 0.787745755,\n",
       " 'batch_norm_sgd_3': 0.8390528300000001,\n",
       " 'batch_norm_sgd_ens': 0.8976895950000001,\n",
       " 'batch_norm_sgd_ens_large': 0.919971825,\n",
       " 'channel_wise_sep_cov_mean_sgd_3': 0.7038751000000001,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens': 0.857374125,\n",
       " 'channel_wise_sep_cov_mean_sgd_ens_large': 0.889815485,\n",
       " 'de_aug': 0.9609891399999999}"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "svhn_auroc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b4bbc3ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "mm = ['None_sgd_3', 'None_sgd_ens_large', 'None', 'channel_wise_sep_cov_mean_BA']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "0417840b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.780 & 0.830 & 0.851 & 0.848 & 0.579 & 0.490 & 0.457 & 0.480 \\\\'"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(' & '.join(\"{:.3f}\".format(cifar100_auroc[m]) for m in mm) + \" & \" + \n",
    " ' & '.join(\"{:.3f}\".format(cifar100_fpr95[m]) for m in mm) + \" \\\\\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "078c7803",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.713 & 0.788 & 0.874 & 0.920 & 0.625 & 0.453 & 0.299 & 0.281 \\\\'"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(' & '.join(\"{:.3f}\".format(svhn_auroc[m]) for m in mm) + \" & \" + \n",
    " ' & '.join(\"{:.3f}\".format(svhn_fpr95[m]) for m in mm) + \" \\\\\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7a2a2291",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.78005486\n",
      "0.8302342300000002\n",
      "0.8512962949999998\n",
      "0.8477065699999999\n"
     ]
    }
   ],
   "source": [
    "for m in mm:\n",
    "    print(cifar100_auroc[m])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d4995152",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'None': (array(0.9032, dtype=float32), 0.32022798),\n",
       " 'channel_wise_sep': (array(0.90199995, dtype=float32), 0.34063795),\n",
       " 'channel_wise_sep_cov_mean': (array(0.90199995, dtype=float32), 0.3481036),\n",
       " 'channel_wise_sep_cov_mean_BA': (array(0.90239996, dtype=float32),\n",
       "  0.33823216),\n",
       " 'spatial_sep': (array(0.903, dtype=float32), 0.32040182),\n",
       " 'spatial_sep_cov_mean': (array(0.9026, dtype=float32), 0.32043922),\n",
       " 'batch_norm': (array(0.9041, dtype=float32), 0.320046),\n",
       " 'None_sgd_3': (array(0.83949995, dtype=float32), 0.76597893),\n",
       " 'None_sgd_ens': (array(0.87119997, dtype=float32), 0.43451908),\n",
       " 'batch_norm_sgd_3': (array(0.83949995, dtype=float32), 0.76624656),\n",
       " 'batch_norm_sgd_ens': (array(0.87119997, dtype=float32), 0.43480483),\n",
       " 'batch_norm_sgd_ens_large': (array(0.8829, dtype=float32), 0.36011484),\n",
       " 'channel_wise_sep_cov_mean_sgd_3': (array(0.839, dtype=float32), 0.79667604),\n",
       " 'channel_wise_sep_cov_mean_sgd_ens': (array(0.8713, dtype=float32),\n",
       "  0.44303522),\n",
       " 'channel_wise_sep_cov_mean_sgd_ens_large': (array(0.8836, dtype=float32),\n",
       "  0.360816)}"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "148fbe85",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['channel_wise_sep_cov',\n",
       " 'channel_wise_sep_cov_mean',\n",
       " 'channel_wise_sep_cov_mean_BA',\n",
       " 'spatial_sep',\n",
       " 'spatial_sep_cov_mean',\n",
       " 'batch_norm']"
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list(test_stat.keys())[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 251,
   "id": "fc7b2b4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "ood_table = pd.DataFrame(columns=['Method', \n",
    "                                  r'Test acc $\\uparrow$', r'Test nll $\\downarrow$',\n",
    "                                  r'AUROC (CIFAR100) $\\uparrow$', r'AUROC (SVHN) $\\uparrow$'])\n",
    "method_list = [\n",
    "    'HMC',\n",
    "#     'feature',\n",
    "    'ShiftMatch (moment)',\n",
    "    'ShiftMatch (post activation)',\n",
    "    'ShiftMatch',\n",
    "    'ShiftMatch (moment, channel-joint)',\n",
    "    'ShiftMatch (channel-joint)',\n",
    "    'BatchNorm'\n",
    "]\n",
    "for i, key in enumerate(test_stat.keys()):\n",
    "    ood_table.loc[i] = [method_list[i],\n",
    "        float(test_stat[key][0]),\n",
    "        float(test_stat[key][1]),\n",
    "        float(cifar100_auroc[key]),\n",
    "        float(svhn_auroc[key])]\n",
    "ood_table = ood_table.drop([1,2,4,5,6])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "00797775",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import cm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "dc3cdf6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "blues = [\n",
    "    '#f7fbff','#deebf7','#c6dbef','#9ecae1','#6baed6','#4292c6','#2171b5','#08519c','#08306b'\n",
    "][-6:]\n",
    "red = [(254,240,217)]\n",
    "# pallete = ['red'] + [np.array(t).astype('float32') / 255 for t in blues]\n",
    "pallete = ['#b10026'] + blues"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "id": "603eb9ee",
   "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>Method</th>\n",
       "      <th>AUROC (CIFAR100) $\\uparrow$</th>\n",
       "      <th>AUROC (SVHN) $\\uparrow$</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>HMC</td>\n",
       "      <td>0.851296</td>\n",
       "      <td>0.874216</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>ShiftMatch (moment)</td>\n",
       "      <td>0.847887</td>\n",
       "      <td>0.925777</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>ShiftMatch (post activation)</td>\n",
       "      <td>0.847177</td>\n",
       "      <td>0.921228</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>ShiftMatch</td>\n",
       "      <td>0.847707</td>\n",
       "      <td>0.919745</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>ShiftMatch (moment, channel-joint)</td>\n",
       "      <td>0.854460</td>\n",
       "      <td>0.920896</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>ShiftMatch (channel-joint)</td>\n",
       "      <td>0.854148</td>\n",
       "      <td>0.922295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>BatchNorm</td>\n",
       "      <td>0.858087</td>\n",
       "      <td>0.936054</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               Method  AUROC (CIFAR100) $\\uparrow$  \\\n",
       "0                                 HMC                     0.851296   \n",
       "1                 ShiftMatch (moment)                     0.847887   \n",
       "2        ShiftMatch (post activation)                     0.847177   \n",
       "3                          ShiftMatch                     0.847707   \n",
       "4  ShiftMatch (moment, channel-joint)                     0.854460   \n",
       "5          ShiftMatch (channel-joint)                     0.854148   \n",
       "6                           BatchNorm                     0.858087   \n",
       "\n",
       "   AUROC (SVHN) $\\uparrow$  \n",
       "0                 0.874216  \n",
       "1                 0.925777  \n",
       "2                 0.921228  \n",
       "3                 0.919745  \n",
       "4                 0.920896  \n",
       "5                 0.922295  \n",
       "6                 0.936054  "
      ]
     },
     "execution_count": 215,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ood_table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "id": "42eb6bfb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACOYAAAJiCAYAAABpF18ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAABYlAAAWJQFJUiTwAADAjElEQVR4nOzde5xVdb0//tfAAAooNzmAinedAoU8eE28gJImpoBZWaF2wkpLrPyW6SnNW8Sp7JRaHpVjiSaZoWBioiGlHI73RC6KdwFzRG4KKNf5/eFv9oG4ODOwZzMzz+fjMY/Hmv15r896j6z92Mu9X/uzyqqqqqoCAAAAAAAAAABsVc1K3QAAAAAAAAAAADRGgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAEgjkAAAAAAAAAAFAE5aVuAADYtJkzZ2bFihVp3rx5WrVqVep2AAAAAADqZMWKFVmzZk1atWqVHj16lLodAKg3gjkAsA1bsWJF1q5dm7Vr12bVqlWlbgcAAAAAYIusWLGi1C0AQL0SzAGAbVjz5s2zdu3aNGvWLK1bty51OwAAAAAAdbJ8+fKsXbs2zZs3L3UrAFCvBHMAYBvWqlWrrFq1Kq1bt05FRUWp2wEAAAAAqJPnn38+S5cuTatWrUrdCgDUq2albgAAAAAAAAAAABojwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACgCwRwAAAAAAAAAACiC8lI3AACTJ0/OmDFjMn369CxZsiSdO3fO4YcfnjPPPDP77bffFs29fPny3H777Zk4cWJefvnlrFixIp07d87HP/7xDB06tMbzF7NHAAAAAAAAoHEqq6qqqip1EwA0XZdffnluu+22jY61bNkyV111VU4++eQ6zf3SSy/la1/7Wl5//fWNjrdo0SKXXnppTjvttJL1+GGef/75LF26NG3btk1FRUVRjgEAAAAAUGze6wSgqbJiDgAlM2rUqELgZcCAATnnnHPSrVu3zJw5MyNHjszs2bNz8cUXp3v37jnwwANrNfc777yTs88+O/PmzUuLFi1yzjnn5KSTTsqOO+6YF154Ib/85S/z+OOP59JLL83OO++cI444ot57BAAAAGrm0z+fUOoWGow7v3ViqVsAAADW0azUDQDQNC1cuDDXXXddkqRv37655ppr0rNnz3Ts2DF9+/bN6NGj07lz56xatSojR46s9fw333xz5s2blyT50Y9+lK9//evZfffd06FDhxxyyCG5+eabc+CBB2bNmjW58sors2bNmnrvEQAAAAAAAGjcBHMAKIlx48Zl2bJlSZILLrggZWVl6423b98+w4YNS5I8/fTTmTlzZq3mv/fee5Mk++6770ZvM9WiRYucd955SZKXX345jzzySL33CAAAAAAAADRugjkAlMSkSZOSJLvvvnt69Oix0ZoTTjhhg/qaWL58eV577bUkycEHH7zJuoMOOqgQtnnggQfqtUcAAAAAAACg8RPMAaAkZsyYkSTp1avXJmu6du2aLl26JEmmT59e47nffffdwvaOO+64ybpWrVpl++233+T8xewRAAAAAAAAaPwEcwCod5WVlYVbRHXv3n2ztbvuumuS5JVXXqnx/G3atClsv/POO5usW7FiRd57773C/FVVVfXWIwAAAAAAAND4CeYAUO8WLVpU2O7UqdNma6vHFy9eXOP527Ztm27duiVJnnjiiU3WPfnkk4Uwzvvvv5/ly5fXW48AAAAAAABA41de6gYAaHrWDcC0atVqs7XV49Wr19TUcccdl9GjR2f27Nm59957M3DgwPXGV69enWuuuWa9x5YtW1ZYbac+eqyNpUuX5sknnyza/AAAALAt6tOnT6lbaLC8jwAAANsGK+YAUO/WvWXU1qxd19lnn5327dsnSS688ML8+te/zuuvv57Fixfn8ccfz5e+9KU89dRT64VumjX7v5fF+ugRAAAAAAAAaNysmANAvatelSZJVqxYsdnalStXbrBPTXTp0iW/+tWvcu6552bx4sX5z//8z/znf/7nejUHHnhg9ttvv/z+979Pkuy444712mNttG3bNhUVFUWbHwAAAGhcrDYEbGuef/75LF26tNRtAEC9s2IOAPWuQ4cOhe0FCxZstrZ6vHr1m9ro06dPJkyYkK9+9avZb7/90rp167Ru3To9e/bMRRddlFtvvTWLFy8u9NSyZct67xEAAAAAAABovKyYA0C969KlS1q3bp3ly5dnzpw5m62dO3dukmTPPfes07E6deqUb3/72/n2t7+90fHp06cnSQ444ICS9QgAAAAAAAA0TlbMAaAkevbsmSSZNm3aJmsqKytTWVm5Xv3W9Nxzz2XevHlJkiOPPHKb7BEAAAAAAABouARzACiJfv36JUlee+21zJw5c6M19913X2G7f//+W72H//7v/06SbLfddjnllFO2yR4BAAAAAACAhkswB4CSGDx4cFq3bp0kufrqq1NVVbXe+OLFi3PTTTclSXr37r3VV6MZP358xo8fnyQ555xz0q5du22uRwAAAAAAAKBhE8wBoCQ6duyYc889N0ny8MMPZ/jw4Zk1a1YWLlyYKVOmZOjQoZk/f37Ky8tz4YUXbrD/2LFjU1FRkYqKiowdO3ajxzj99NPz85//PI8//njeeOONLFy4ME888UQuuuiifPe7301VVVU+/vGP58tf/nJRegQAAAAAAACatvJSNwBA03X22Wdn7ty5GTNmTCZOnJiJEyeuN96iRYtceeWV6dOnT53mr6yszPXXX5/rr79+o+MnnnhiRowYkRYtWpSsRwAAAAAAAKDxEswBoKQuu+yyHHPMMbn99tszY8aMLFmyJJ07d85hhx2Ws846KxUVFXWe+4ILLsikSZMyffr0vP3221m1alV22mmn9OnTJ0OGDMnhhx9e8h4BAAAAAACAxqusqqqqqtRNAAAb9/zzz2fp0qVp27atABAAAABN1qd/PqHULTQYd37rxFK3ALBR3usEoKlqVuoGAAAAAAAAAACgMRLMAQAAAAAAAACAIigvdQMAAAAAsK25qctBpW6hQRhW+USpWwAAAIBtmhVzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCMpL3QAAQG3c1OWgUrfQYAyrfKLULQAAAAAAADRpgjkAAMAW+fTPJ5S6hQbhzm+dWOoWAAAAAACoZ25lBQAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARVBe6gYAYPLkyRkzZkymT5+eJUuWpHPnzjn88MNz5plnZr/99qvTnN/73vdy11131bj+kEMOyejRo9d7bO7cuTn22GNrtP/UqVPTsWPHWvUIAAAAAAAANG5WzAGgpC6//PJ89atfzUMPPZT58+dn5cqVmTdvXu68886ceuqpGT9+fL30UdcAEAAAAAAAAMCmWDEHgJIZNWpUbrvttiTJgAEDcs4556Rbt26ZOXNmRo4cmdmzZ+fiiy9O9+7dc+CBB9Zq7ssvvzw/+MEPNlvz85//vLBKzimnnLLZ2htuuCEHHXTQJsfbtGlTq/4AAAAAAACAxk8wB4CSWLhwYa677rokSd++fXPNNdekrKys8Pv++++fk046KfPnz8/IkSMzZsyYWs3fsmXLtGzZcpPja9euzf33358k2WuvvdKrV6/NzrfddtsJ3wAAAAAAAAC14lZWAJTEuHHjsmzZsiTJBRdcUAjlVGvfvn2GDRuWJHn66aczc+bMrXr8KVOm5K233kqSDB48eKvODQAAAAAAAJAI5gBQIpMmTUqS7L777unRo8dGa0444YQN6reWcePGJUmaNWuWk08+eavODQAAAAAAAJAI5gBQIjNmzEiSzd5CqmvXrunSpUuSZPr06Vvt2MuWLcuDDz6YJDn00EPTtWvXGu+7cuXKrdYHAAAAAAAA0LiVl7oBAJqeysrKwm2sunfvvtnaXXfdNZWVlXnllVe22vHvv//+vPfee0mSQYMG1WifK664IvPmzcvy5cvTsmXL7LHHHjnyyCNzxhln1CrYAwAAAAAAADQdgjkA1LtFixYVtjt16rTZ2urxxYsXb7Xj33333UmS1q1b5xOf+ESN9nnhhRcK2ytXrszs2bMze/bs3H777bnyyiszcODArdbfxixdujRPPvlkUY+xrevTp0+pW2iwmvq5Q/F4XtaN5yTAts3rW914faNYPCfrzvMSAAC2DYI5ANS75cuXF7ZbtWq12drq8eoVdrbUP/7xjzz++ONJkk984hNp3br1JmubNWuWvn37ZuDAgenZs2e6deuWVq1a5fXXX8+ECRMyatSoLF++PN/5znfSrl279O3bd6v0CAAAAAAAADQOgjkA1Luqqqqi1NbE+PHjs3bt2iQffhurnXfeOaNGjdrg8X333Tfnn39+jjnmmJxxxhl5//33c8UVV2TChAlp3rz5Vu23Wtu2bVNRUVGUuWn8fMMUti2ekwA0Rl7fYNvjeQlsa55//vksXbq01G0AQL1rVuoGAGh62rRpU9hesWLFZmtXrly5wT5bYty4cUmSrl275tBDD92iuXr37p2hQ4cmSV599dVMmzZti/sDAAAAAAAAGg/BHADqXYcOHQrbCxYs2Gxt9Xj79u23+LjTpk3LSy+9lCQ55ZRT0qzZlr8M9uvXr7A9c+bMLZ4PAAAAAAAAaDwEcwCod126dEnr1q2TJHPmzNls7dy5c5Mke+655xYft3q1nOSDYM7W0KlTp8L2u+++u1XmBAAAAAAAABoHwRwASqJnz55JstnbP1VWVqaysnK9+rpatWpV7r333iTJAQcckL333nuL5qv29ttvF7Z32GGHrTInAAAAAAAA0DgI5gBQEtW3gHrttdc2eQuo++67r7Ddv3//LTre3/72tyxatChJMmjQoC2aa10PPPBAYXtLw0MAAAAAAABA4yKYA0BJDB48uHA7q6uvvjpVVVXrjS9evDg33XRTkqR3795bHHqpvo1VixYtMnDgwBrt8+abb252/NFHH83vfve7JMkee+yRXr16bVGPAAAAAAAAQOMimANASXTs2DHnnntukuThhx/O8OHDM2vWrCxcuDBTpkzJ0KFDM3/+/JSXl+fCCy/cYP+xY8emoqIiFRUVGTt27GaPtWTJkjz00ENJkqOPPjodOnSoUY+DBg3Keeedl7vvvjsvvPBCFi1alEWLFmXatGkZMWJEvvzlL2flypUpLy/PJZdckmbNvKwCAAAAAAAA/6e81A0A0HSdffbZmTt3bsaMGZOJEydm4sSJ6423aNEiV155Zfr06bNFx5kwYUJWrlyZpHa3sVq9evVG+1pXu3btctVVV+WII47Yoh4BAAAAAACAxkcwB4CSuuyyy3LMMcfk9ttvz4wZM7JkyZJ07tw5hx12WM4666xUVFRs8TGqb2PVvn37HH300TXeb8SIEXniiSfyzDPPpLKyMosXL86qVavSrl277LPPPunbt28+/elP13gFHgAAAAAAAKBpEcwBoOT69euXfv361WqfIUOGZMiQITWqHTNmTF3ayoABAzJgwIA67QsAAAAAAADQrNQNAAAAAAAAAABAYySYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARSCYAwAAAAAAAAAARVBe6gYAYPLkyRkzZkymT5+eJUuWpHPnzjn88MNz5plnZr/99tsqx3jppZfy+9//PlOmTMmbb76ZtWvXZqeddso+++yTQw89NJ/73Oey3XbblbRHAAAAAAAAoHERzAGgpC6//PLcdttt6z02b9683HnnnRk/fnyuuuqqnHzyyVt0jOuuuy6//vWvs2rVqvUef/311/P6669n0qRJOe6447LrrruWrEcAAAAAAACg8RHMAaBkRo0aVQi8DBgwIOecc066deuWmTNnZuTIkZk9e3YuvvjidO/ePQceeGCdjvGTn/wkN910U5LkiCOOyBe/+MX06NEjzZs3z7x58/LMM89k7NixJe0RAAAAAAAAaJwEcwAoiYULF+a6665LkvTt2zfXXHNNysrKCr/vv//+OemkkzJ//vyMHDkyY8aMqfUxpkyZUgjlfPnLX853v/vd9cY7d+6cj33sYznzzDNL1iMAAAAAAADQeDUrdQMANE3jxo3LsmXLkiQXXHBBIfBSrX379hk2bFiS5Omnn87MmTNrfYwf/ehHSZKePXvm//2//7dN9ggAAAAAAAA0XoI5AJTEpEmTkiS77757evTosdGaE044YYP6mnriiSfy4osvJkm+9KUvpVmz2r/kFbtHAAAAAAAAoHETzAGgJGbMmJEk6dWr1yZrunbtmi5duiRJpk+fXqv5//a3vyVJmjVrln79+hUer6qqyurVq7eJHgEAAAAAAIDGTTAHgHpXWVlZuEVU9+7dN1u76667JkleeeWVWh3j2WefTZLsscceadu2bf74xz/m05/+dA444IDsv//+OeKII3LBBRdsMkxTHz0CAAAAAAAAjZtgDgD1btGiRYXtTp06bba2enzx4sW1OsYbb7yRJOnSpUu++c1v5uKLL86zzz6bVatWpaqqKm+//Xb+9Kc/5bTTTstvf/vbkvQIAAAAAAAANG7lpW4AgKZn+fLlhe1WrVpttrZ6vHr1mppaunRpkuSJJ57IqlWrsu++++bCCy/MQQcdlNWrV2fKlCn58Y9/nH/84x8ZMWJE9thjjxx99NH12mNtLF26NE8++WTR5m8I+vTpU+oWGqymfu5QPJ6XdeM5CbBt8/pWN17fKBbPybrzvAQAgG2DFXMAqHdVVVVFqV3X2rVrkySrVq1Kly5dcuutt+bII4/M9ttvnx122CEnnHBCbrnllrRu3TpVVVX52c9+Vu89AgAAAAAAAI2bFXMAqHdt2rQpbK9YsWKztStXrtxgn5po3bp1Fi5cmCQ588wz0759+w1qdtttt5x66qkZPXp0nn/++cyZMyfdu3evtx5ro23btqmoqCja/DRuvmEK2xbPSQAaI69vsO3xvAS2Nc8//3xhpXMAaEqsmANAvevQoUNhe8GCBZutrR7fWLCmpsfY3BtR6469+OKL9dojAAAAAAAA0LgJ5gBQ77p06ZLWrVsnSebMmbPZ2rlz5yZJ9txzz1odY++99y5s77jjjpusa9euXWF73W9r1EePAAAAAAAAQOMmmANASfTs2TNJMm3atE3WVFZWprKycr36mjrggAMK24sXL95k3bpj/xzgKXaPAAAAAAAAQOMmmANASfTr1y9J8tprr2XmzJkbrbnvvvsK2/3796/V/Mcee2zKysqSJI8//vgm6x599NHC9kc+8pF67REAAAAAAABo3ARzACiJwYMHF24VdfXVV6eqqmq98cWLF+emm25KkvTu3bvWq9F069Ytxx13XJLklltuyYIFCzaoeemll3L33XcnSQ455JB06dKlXnsEAAAAAAAAGjfBHABKomPHjjn33HOTJA8//HCGDx+eWbNmZeHChZkyZUqGDh2a+fPnp7y8PBdeeOEG+48dOzYVFRWpqKjI2LFjN3qM73znO2nbtm3efvvtnH766bn//vuzYMGCvPXWW7nrrrtyxhln5P3330/Lli3z3e9+d6v3CAAAAAAAADRt5aVuAICm6+yzz87cuXMzZsyYTJw4MRMnTlxvvEWLFrnyyivTp0+fOs2/++6757rrrsv555+f1157LcOHD9+gpnXr1vnpT3+aAw44oCQ9AgAAAAAAAI2XYA4AJXXZZZflmGOOye23354ZM2ZkyZIl6dy5cw477LCcddZZqaio2KL5DzvssPzpT3/KzTffnMmTJ+cf//hHqqqqsssuu+TII4/MWWedla5du5a0RwAAAAAAAKBxEswBoOT69euXfv361WqfIUOGZMiQITWq7dy5c7773e9u9HZVNVWXHgEAAAAAAICmrVmpGwAAAAAAAAAAgMZIMAcAAAAAAAAAAIpAMAcAAAAAAAAAAIpAMAcAAAAAAAAAAIpAMAcAAAAAAAAAAIqgvNQNAFB6c+fOzVNPPZX58+fnvffey+c///l07Nix1G0BAAAAAAAANGiCOQBN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MS+88ELWrFnzofuUlZVl5syZW3zscePGZdmyZUmSCy64oBDKqda+ffsMGzYsI0aMyNNPP52ZM2emR48edT7eX//610yYMCG77LJLvvGNb+QrX/nKFvUPAAAAAAAA8GGalboBAErjueeeyymnnJJf/vKXmTVrVlavXp2qqqoa/WwNkyZNSpLsvvvumwzcnHDCCRvU18Xy5ctz2WWXJUm+//3vZ/vtt6/zXAAAAAAAAAA1ZcUcgCZo2bJl+drXvpY333wzzZo1S//+/dOpU6fccccdKSsryznnnJMlS5bk2WefzbRp01JWVpYDDzwwH//4x7daDzNmzEiS9OrVa5M1Xbt2TZcuXVJZWZnp06fX+Vi/+MUvMm/evBx33HHp379/nedJkpUrV6Zly5ZbNAcAAAAAAADQNAjmADRBd9xxRyGUc/311+eoo47KCy+8kDvuuCNJMnz48ELts88+m+985zt55plnMmjQoHzmM5/Z4uNXVlYWbmPVvXv3zdbuuuuuqayszCuvvFKnY82YMSOjR49O69at8/3vf79OcyTJFVdckXnz5mX58uVp2bJl9thjjxx55JE544wz0rVr1zrPCwAAAAAAADRebmUF0ARNnjw5ZWVl6d+/f4466qjN1h5wwAH57W9/mx133DFXXHFFXnjhhS0+/qJFiwrbnTp12mxt9fjixYtrfZw1a9bkBz/4QdasWZPzzjsv3bp1q/Uc1V544YUsX748yQer5syePTujRo3KJz/5ydx77711nhcAAAAAAABovKyYA9AEvfjii0mST37ykxsdr6qqSllZWeH3Ll26ZOjQofnlL3+Z2267LT/84Q+36PjVAZckadWq1WZrq8erV9ipjd/85jeZMWNGKioqcsYZZ9R6/2bNmqVv374ZOHBgevbsmW7duqVVq1Z5/fXXM2HChIwaNSrLly/Pd77znbRr1y59+/at9TFqaunSpXnyySeLNn9D0KdPn1K30GA19XOH4vG8rBvPSYBtm9e3uvH6RrF4Ttad5yUAAGwbrJgD0AQtWbIkSbLzzjsXHmvRokVh+7333ttgn0MOOSRJMnXq1C0+flVVVVFq1zV37txcc801KSsry2WXXZby8tpnUXfeeeeMGjUqQ4YMSUVFRXbccce0atUq++67b84///yMHj062223XdasWZMrrrgia9asqVOvAAAAAAAAQONkxRyAJqhFixZZs2ZNWrZsWXisTZs2he233nore+yxx3r7VNe+9dZbW3z8dY+1YsWKzdauXLlyg31q4oc//GHee++9fPazn82BBx5Y+yZroHfv3hk6dGhuvPHGvPrqq5k2bVrRjtW2bdtUVFQUZW4aP98whW2L5yQAjZHXN9j2eF4C25rnn38+S5cuLXUbAFDvrJgD0AR17do1SbJw4cLCYzvttFO23377JMmMGTM22OeVV17Zasfv0KFDYXvBggWbra0eb9++fY3nf/DBB/Pwww+nU6dOueCCC+rUY03169evsD1z5syiHgsAAAAAAABoWARzAJqg6pVXXnjhhcJjZWVlOeCAA1JVVZXbb799vfoVK1bk5ptvTpLstttuW3z8Ll26pHXr1kmSOXPmbLZ27ty5SZI999yzxvNX77NgwYIccsghqaio2ODnscceS5LMmzev8NhVV11V67+lU6dOhe1333231vsDAAAAAAAAjZdgDkATdPDBB6eqqipTpkxZ7/FBgwYlSZ588sl84QtfyK233pobbrghp512Wp577rmUlZVlwIABW6WHnj17JkmmTZu2yZrKyspUVlauV7+tefvttwvbO+ywQwk7AQAAAAAAALY15aVuAID6d9xxx+WKK67Io48+mn/84x/p1q1bkmTw4MG5884789RTTxV+1rX77rvnS1/60lbpoV+/fnn88cfz2muvZebMmenRo8cGNffdd19hu3///jWe++STT86hhx662Zp///d/z4wZM9K5c+fceOONSZKOHTvW+BjVHnjggcL2thoeAgAAAAAAAEpDMAegCerSpUseffTRrF27Nm3bti08XlZWlhtuuCE/+tGPcs8992TVqlVJkmbNmqV///754Q9/mDZt2myVHgYPHpxrr702y5cvz9VXX50bb7wxZWVlhfHFixfnpptuSpL07t27VqGXjh07fmjIpvrvaNmyZT760Y9utObNN99M165dNznHo48+mt/97ndJkj322CO9evWqcY8AAAAAAABA4yeYA9BEtWvXbqOPt23bNj/60Y/y7//+73n11VezZs2a7Lbbbmnfvv1WPX7Hjh1z7rnn5qc//WkefvjhDB8+POeee266dOmSWbNm5cc//nHmz5+f8vLyXHjhhRvsP3bs2Fx00UVJkhEjRmTIkCFbtb/kg1t7HXzwwTn22GPTs2fP7LTT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mANASV1++eW57bbb1nts3rx5ufPOOzN+/PhcddVVOfnkk+s09+mnn5558+ZtjTYBAAAAAAAAak0wB4CSGTVqVCGUM2DAgJxzzjnp1q1bZs6cmZEjR2b27Nm5+OKL07179xx44IF1Ps6OO+6Y/fffP+3atct9991XpzluuOGGHHTQQZscb9OmTV3bAwAAAAAAABopwRwASmLhwoW57rrrkiR9+/bNNddck7KyssLv+++/f0466aTMnz8/I0eOzJgxY2p9jO9///vZY489sueee6asrCyPPvponYM52223nfANAAAAAAAAUCvNSt0AAE3TuHHjsmzZsiTJBRdcUAjlVGvfvn2GDRuWJHn66aczc+bMWh+jf//+2WuvvTaYGwAAAAAAAKA+COYAUBKTJk1Kkuy+++7p0aPHRmtOOOGEDeoBAAAAAAAAGgrBHABKYsaMGUmSXr16bbKma9eu6dKlS5Jk+vTp9dLXh1m5cmWpWwAAAAAAAAAaiPJSNwBA01NZWVm4jVX37t03W7vrrrumsrIyr7zySn20tklXXHFF5s2bl+XLl6dly5bZY489cuSRR+aMM85I165dS9obAAAAAAAAsG2yYg4A9W7RokWF7U6dOm22tnp88eLFxWzpQ73wwgtZvnx5kg9WzZk9e3ZGjRqVT37yk7n33ntL2hsAAAAAAACwbbJiDgD1rjrgkiStWrXabG31ePUKO/WpWbNm6du3bwYOHJiePXumW7duadWqVV5//fVMmDAho0aNyvLly/Od73wn7dq1S9++fYvWy9KlS/Pkk08Wbf6GoE+fPqVuocFq6ucOxeN5WTeekwDbNq9vdeP1jWLxnKw7z0sAANg2COYAUO+qqqqKUru17bzzzhk1atQGj++77745//zzc8wxx+SMM87I+++/nyuuuCITJkxI8+bNS9ApAAAAAAAAsC0SzAGg3rVp06awvWLFis3Wrly5coN9thW9e/fO0KFDc+ONN+bVV1/NtGnTcuCBBxblWG3btk1FRUVR5qbx8w1T2LZ4TgLQGHl9g22P5yWwrXn++eezdOnSUrcBAPWuWakbAKDp6dChQ2F7wYIFm62tHm/fvn0xW6qzfv36FbZnzpxZwk4AAAAAAACAbY1gDgD1rkuXLmndunWSZM6cOZutnTt3bpJkzz33LHpfddGpU6fC9rvvvlvCTgAAAAAAAIBtjWAOACXRs2fPJMm0adM2WVNZWZnKysr16rc1b7/9dmF7hx12KGEnAAAAAAAAwLZGMAeAkqi+BdRrr722yVtA3XfffYXt/v3710tftfXAAw8UtrfV8BAAAAAAAABQGoI5AJTE4MGDC7ezuvrqq1NVVbXe+OLFi3PTTTclSXr37l2S0Mubb7652fFHH300v/vd75Ike+yxR3r16lUfbQEAAAAAAAANhGAOACXRsWPHnHvuuUmShx9+OMOHD8+sWbOycOHCTJkyJUOHDs38+fNTXl6eCy+8cIP9x44dm4qKilRUVGTs2LEbPcabb76Zv//974WfF198sTD2+uuvrzf2+uuvb7D/oEGDct555+Xuu+/OCy+8kEWLFmXRokWZNm1aRowYkS9/+ctZuXJlysvLc8kll6RZMy+rAAAAAAAAwP8pL3UDADRdZ599dubOnZsxY8Zk4sSJmThx4nrjLVq0yJVXXpk+ffrUaf4//OEPufbaazc69utf/zq//vWvC78PHjw4P/7xj9erWb169Ub7Wle7du1y1VVX5YgjjqhTjwAAAAAAAEDjJZgDQElddtllOeaYY3L77bdnxowZWbJkSTp37pzDDjssZ511VioqKkrW24gRI/LEE0/kmWeeSWVlZRYvXpxVq1alXbt22WeffdK3b998+tOfTocOHUrWIwAAAAAAALDtEswBoOT69euXfv361WqfIUOGZMiQIZutOe+883LeeefVua8BAwZkwIABdd4fAAAAAAAAaNqalboBAAAAAAAAAABojARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCARzAAAAAAAAAACgCMpL3QAATJ48OWPGjMn06dOzZMmSdO7cOYcffnjOPPPM7Lfffls8/+zZs/Pb3/42U6dOzfz589OuXbvsv//+Of3003P00UdvEz0CAAAAAAAAjY8VcwAoqcsvvzxf/epX89BDD2X+/PlZuXJl5s2blzvvvDOnnnpqxo8fv0Xzjxs3LqeeemruvPPOzJs3LytXrsz8+fPz0EMP5Stf+UquuOKKkvcIAAAAAAAANE6COQCUzKhRo3LbbbclSQYMGJCxY8dm6tSpGTVqVPbbb7+sXLkyF198cZ5++uk6zf/000/n3//937Ny5crst99+GTVqVKZOnZqxY8dmwIABSZJbb701//3f/12yHgEAAAAAAIDGSzAHgJJYuHBhrrvuuiRJ3759c80116Rnz57p2LFj+vbtm9GjR6dz585ZtWpVRo4cWadj/PjHP86qVavSuXPnjB49On379k3Hjh3Ts2fPXHPNNenbt2+S5Nprr83ChQtL0iMAAAAAAADQeAnmAFAS48aNy7Jly5IkF1xwQcrKytYbb9++fYYNG5bkg5VvZs6cWav5Z8yYkb///e9JkmHDhqV9+/brjZeVleWCCy5Ikixbtmyjt6Mqdo8AAAAAAABA4yaYA0BJTJo0KUmy++67p0ePHhutOeGEEzaor+38SfLJT35yozU9evTIbrvtliT5y1/+Uu89AgAAAAAAAI2bYA4AJTFjxowkSa9evTZZ07Vr13Tp0iVJMn369DrN36VLl8IcG9O7d+8k2ehqN8XuEQAAAAAAAGjcBHMAqHeVlZWFW0R17959s7W77rprkuSVV16p1TFefvnlWs2/dOnSVFZW1muPAAAAAAAAQOMmmANAvVu0aFFhu1OnTputrR5fvHhxnY5R0/n/+Rj10SMAAAAAAADQuJWXugEAmp7ly5cXtlu1arXZ2urx6tVrauq9995LkrRs2XKzddttt91G+6qPHmtixYoVST5Y0efJJ5/c6vM3JG3btk2SHPm320rcScPx/PPPJ/ng/IFiqH5eXnXi3iXupGHwnARoGFx31o7XN4rNNWfteV4C27rq9zwBoKkQzAGg3lVVVRWldmPKysrqNH999rg5a9asKdrcDY03FGHb43kJQGPk9Q22LZ6TAI2P9zwBaGoEcwCod23atClsf9i3I1auXLnBPjWx/fbbZ9WqVR86/7rjrVu3rtcea6JVq1ZZsWJFmjdv/qEr9wAAAAAAbKtWrFiRNWvWeJ8TgCZHMAeAetehQ4fC9oIFCzZbWz3evn37Wh/jnXfeqfH8/3yM+uixJnr06LHV5wQAAAAAAADqR7NSNwBA09OlS5fC6jRz5szZbO3cuXOTJHvuuWetjlFdX9P527Rpky5dutRrjwAAAAAAAEDjJpgDQEn07NkzSTJt2rRN1lRWVqaysnK9+trOv+4cG/PMM89scv5i9wgAAAAAAAA0boI5AJREv379kiSvvfZaZs6cudGa++67r7Ddv3//Os3/z/Osa+bMmXn99dc3OX+xewQAAAAAAAAaN8EcAEpi8ODBhVtFXX311amqqlpvfPHixbnpppuSJL179671ajQHHHBAevXqlSS56aabsnjx4vXGq6qq8rOf/SxJ0rp165xyyin13iMAAAAAAADQuAnmAFASHTt2zLnnnpskefjhhzN8+PDMmjUrCxcuzJQpUzJ06NDMnz8/5eXlufDCCzfYf+zYsamoqEhFRUXGjh270WN873vfS3l5eebPn5+hQ4dmypQpWbhwYWbNmpXhw4fnkUceSZKce+656dix41bvEQAAAAAAAGjayqr++ev/AFCPLr300owZM2ajYy1atMiVV16ZQYMGbTA2duzYXHTRRUmSESNGZMiQIRud46677soPfvCDrFq1aqPjn/vc53LZZZcVpUcAAAAAAACgaSsvdQMANG2XXXZZjjnmmNx+++2ZMWNGlixZks6dO+ewww7LWWedlYqKii2af/DgwenRo0d+85vf5H//938zf/78tGvXLj179szpp5+efv36lbxHAAAAAAAAoHGyYg4AAAAAAAAAABRBs1I3AAAAAAAAAAAAjZFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFIFgDgAAAAAAAAAAFEF5qRsAAIAt8f/+3//LPffckyQZMGBArr322g/dZ+jQoXnssceyyy67ZNKkSR9a/73vfS933XVXkuT5558vPD527NhcdNFFG9Q3a9Ysbdq0ya677pqDDz44n/vc57L33nvX9E9Kkjz33HMZP358pk6dmn/84x9ZunRp2rdvn9133z1HHXVUhgwZks6dO9d4vjfffDPjx4/PlClT8tprr2XhwoVp1qxZOnTokI985CM54ogjMnDgwHTo0KFWff6zWbNmZfDgwenWrVvuv//+tGzZsig9rfvf/pZbbsmhhx66yfEPc+yxx+ZXv/rVZmvqcp5trfOjqqoqL7/8cqZNm1b4ef7557Nq1aokyV/+8pfsuuuuH9pPtcmTJ2fMmDGZPn16lixZks6dO+fwww/PmWeemf32269oc3zzm9/Mfffdl+9///sZOnRojfvdWv7+979n9erVOeigg+r92ABQW65xa2ZbusZ99dVXM2bMmDz66KOZM2dO3n///ey4447p1KlTunfvnkMOOSSHHHJIPvrRj6asrCxJctFFF2Xs2LFp1qxZHnrooXTt2rVG/SxatChHHnlkVq1alU996lP56U9/muTDr5H/WW2vqf/jP/4jp5xySo3m29g1qutBAACaKsEcAAAarGXLluUvf/lL4ffJkydn8eLFad++femaSrJ27dq8++67mTVrVmbNmpXbb789P/jBD/LZz372Q/d9//33c+WVV+aPf/xj1q5du97Y/PnzM3/+/DzxxBO5/vrrc/755+ess87a7HyrV6/Of/7nf+aWW27JihUrNhh/77338sYbb2TSpEn5yU9+krPOOivf+ta3avX3rmvkyJGpqqrK1772tU2Gcuq7py21tc+z2p4f8+bNy4knnlinY/2zyy+/PLfddtsG8995550ZP358rrrqqpx88slFmeMb3/hG7r///lx33XUZPHhw2rZtu+V/UA3dfffdueiii7J27dpccskl+cIXvlBvxwaA2nKN2/CucX/zm9/kpz/9aSE4XW3BggVZsGBBZs+eXfg3nTp1ajp27JgkGTRoUMaOHZu1a9fmnnvuydlnn12jfiZMmFA41uaCMlvbddddl5NOOinNmzev0/6uBwEAaKoEcwAAaLDuv//+LF++vPD7qlWrcu+995bkTdYbbrih8M3L1atX5/XXX899992X3/72t1m1alV++MMf5iMf+Uh69+69yTmWLl2as88+O0899VSSpGfPnhk6dGj69OmTHXbYIW+//XYeeeSRjBo1KvPnz8+IESMyd+7cfP/739/ofO+//36+/vWv55FHHkmS7LLLLvn85z+fww47LF26dElZWVkqKyszderUjBs3LrNnz871119f5w8t/vrXv2bq1KnZZZddMmTIkG2ip2T9f5uNKS/f/P8WbY3zbGucH0nSpUuX9OrVK4sWLcoTTzxR4+MnyahRowqBmgEDBuScc85Jt27dMnPmzIwcOTKzZ8/OxRdfnO7du+fAAw/c6nPss88+Of7443PfffflhhtuyLe//e1a9V9X634IkyRXXHFFysrK8vnPf75ejg8AteUat2Fd444bNy4jRowo9HLGGWfkkEMOSdeuXbNq1arMmTMnTzzxRCZOnJgZM2ast+8hhxySXXbZJfPmzcv48eNrHMwZN25ckqRz5875+Mc/Xqe/qy5ee+213H333Tn11FPrtL/rQQAAmqpmpW4AAADq6u67706SdO/evbCMfvWb1PVtu+22S5s2bdKmTZu0a9cuBxxwQL773e/mO9/5TpIPvmH8m9/8ZrNz/PCHPyx8YPHFL34xf/jDHzJ48ODstttu6dChQ/bdd9986UtfyoQJEwqhh9GjR+cPf/jDRue74oorCh9YDB48OH/+858zbNiw7L///uncuXN22mmn9OzZM8OGDSt8oNC6des6/zf49a9/nST53Oc+lxYtWmwTPSXr/9ts7KdVq1ab3X9rnGdbcn60b98+1113XR555JH87W9/y7XXXpvDDjusVsdfuHBhrrvuuiRJ3759c80116Rnz57p2LFj+vbtm9GjR6dz585ZtWpVRo4cWbQ5qm9ZMHr06CxdurRWf0Nd/POHMMkHtwa7/PLLc/vttxf9+ABQF65xG9Y17i9+8Yskya677pq77rorZ511Vnr06JGOHTumS5cuOeigg/K1r30tY8eOzR133LFeL2VlZfnUpz6VJJk9e3aee+65D+3n1VdfzTPPPJMk+dSnPlXn1Wtqq3v37kmSX/3qVxusDFQbrgcBAGiKBHMAAGiQ/vGPf+Txxx9P8sHy7dVLuD/zzDN59dVXS9jZ+r74xS8W3nyv/kBiY6ZMmZJ77rknSXLUUUfl+9///ibfZN9xxx1zww03pHPnzkmSH/3oR3nnnXfWq3n00Udz5513JvkgRDFixIhN3loqSZo1a5YhQ4bkjjvuqPkft44XXnghTz/99HofLvyz+u5payj2eVaT86Nt27Y57rjjCv/edTFu3LgsW7YsSXLBBRekrKxsvfH27dtn2LBhSZKnn346M2fOLMoc//qv/5pdd901y5cvz5/+9Kc6/z01se6HMIccckjh8YMPPjhVVVW57LLL8vvf/76oPQBAbbnGbVjXuK+++mrmzZuXJDnttNPSrl27zc7Xu3fvbLfddus9NmjQoMJ2TQJY69asu2+xff3rX0+SzJ07N2PHjq3zPK4HAQBoigRzAABokMaNG1f41uPJJ5+ck08+uRAUqP6W8bagvLy88O3SBQsWbLLu5ptvTvLBt2a///3vbxB6+Gc77rhjzj///CTJ8uXLM2bMmPXGb7rppsJ8l1566YfOV23fffetUd0/q35D++CDD063bt02WlPfPW0NxT7Panp+bKlJkyYlSXbffff06NFjozUnnHDCBvVbe46ysrKcdNJJSVLUwNWDDz5Y+BDmmGOOyc9//vPC2FVXXZXjjz8+VVVVufTSSzNhwoSi9QEAteUat2Fd4y5cuLCw3aZNmzodY8899yzcCuyee+5Zb2WXjRk/fnyS5KMf/WgqKirqdMy6OPjggwurNl5//fVZuXJlneZxPQgAQFMkmAMAQINU/U3RAw88MLvvvnu6detW+Bbk+PHjU1VVVcr21lPdy6a+Qbt06dL8z//8T5IP3vDefffdazTvwIEDC99UfvDBBwuPL1u2rDDfoYcemt12263OvdfU/fffnyQ58sgjNzpeip62hvo4zz7s/NgaZsyYkSTp1avXJmu6du2aLl26JEmmT59elDmS/ztHZsyYkTlz5tSg+9rr06dP9t133xxzzDG55ppr1vsmffPmzXP11VfnE5/4RPbee+8ceuihRekBAOrCNW7DusZd92+fMmVKnY9TvTLS/PnzM3Xq1E3WPfHEE5k7d+56+9Sn6tDUG2+8sclbjdWE60EAAJoawRwAABqcadOm5eWXX07ywTeJq1W/OT1v3rzCLQBKbdWqVYU3m/fee++N1jzzzDNZs2ZNkqy3xPqHad26dXr27JkkmTlzZt5///3CfKtXr07ywYcgxfbaa6/lrbfeSpIccMABG62p7562hvo4z2pyfmypysrKwi2oqr/Zvim77rprkuSVV17Z6nNU23///VNeXp4kRXuedujQIbfccssGH8JUKy8vz9VXX51bb701nTp1KkoPAFBbrnE/0JCucffaa6907do1SfLQQw/l3//93/PSSy/V+lgDBw5MixYtkmz+dlbVq+U0b968sOpMffrXf/3X9O3bN0nyX//1X1mxYkWd5nE9CABAUyOYAwBAg1O9jH+LFi3yyU9+svD48ccfn+233369mlK79dZb89577yVJvvCFL2y0pvpbr0ntwxl77bVXkg8+HKmsrNxgvurxYqp+M72srCz777//Rmvqu6d1vf/++1m2bNlGf6r/bTamPs6zmpwfW2rRokWF7Q/70KF6fPHixVt9jmrbbbdd4XYSxfxwsX379hv9EKZaixYt0qFDh6IdHwBqyzXu/2ko17hlZWX57ne/W/j9zjvvzIknnph+/fpl+PDhueGGG/LUU08VAkqb0r59+xxzzDFJkgceeGCj16grV67Mn//85yTJEUcckc6dO292zs1dA1f/1OV2VNWr5lRWVm5wq7Gacj0IAEBTU17qBgAAoDZWrVqVCRMmJEmOPvro9d5Ibdu2bY499tj86U9/yv33359LLrkk2223Xb30Vf3Gd5KsXr06c+bMyYQJE/Lb3/42SXLWWWfl+OOP3+i+S5YsKWzvsMMOtTrujjvuuME86wYiajtfXVR/K7h9+/abPF5997Sur3zlK5sc22WXXTJp0qQNHt/a59mWnB9bavny5YXtVq1abba2ery61605x7q6d++eWbNmZfbs2ZudCwCaCte462so17jJB6vdlJWV5Uc/+lHmz5+f5INbPb3xxhuFW2H9y7/8S84444yceeaZmwyKDBo0KA888ECWL1+eBx54YL1Vk5Jk8uTJhf8WgwYN+tD+N3cNvCV69eqVfv365aGHHsqNN96Yz372s3U6H10PAgDQlAjmAADQoPz1r38trN5Rvaz/uk455ZT86U9/ytKlS/OXv/wlAwcOrJe+NvXGd+vWrfOrX/0qRx99dI3mKSsr25pt1YuFCxcmSdq1a1fiTraerX2eba3zoy6qqqq2uHZrzLGu6nNl3ZV4AKApc4277anNNe6JJ56YY489Ng8++GAmT56cp59+unCrryR566238tOf/jQPPfRQRo0aVVgBaV3VgaxFixZl3LhxGwRzqm9xVR3UKqXhw4dn8uTJmT9/fn73u9/l3/7t32o9h+tBAACaEreyAgCgQalevr9du3aF5d7Xte6y7tvCUv/Lly/PiBEj8tZbb22yZt03+995551azb9uffU3i9u3b1947N13363VfHVRkw8t6rundd1yyy15/vnnN/qzsdVykvo7z2pyfmypNm3aFLZXrFix2drq2xmsu8/WmmNd1edK9bkDAE2da9z1NZRr3HW1atUqAwcOzE9+8pM8+OCDeeyxx/KrX/0qJ510Upo3b54kefLJJ/Ozn/1so/u3aNEiJ554YpJk6tSphdV3kg9WC/rrX/+a5INbm9VkhZrNXQNX/4wYMaJGf9s/69GjR4477rgkyY033rje6oo15XoQAICmRDAHAIAGY/HixZk8eXKS5F//9V/z0ksvZdasWev9zJ49OwcddFCSZMqUKXn77bc3mKe8/IOFI6sDBB+muq56v41Z943vJ598MnfccUfhzepXXnklF1xwQdauXbvRfXfZZZfC9osvvlijnqpVL7HfokWLdO3adYP5Xn755VrNVyzbYk+bsrXOs3Vtyfmxpda9FcaCBQs2W1s9vu4HX1trjo1piN+eB4CtzTXuhhrKNe7mtGvXLscee2x+9rOf5de//nXhuucPf/jDJv+Nqm9RtWbNmtx7772FxydMmJBVq1atV1Nq5513XsrKyrJw4cLceuutdZ7H9SAAAE2BW1kBANBg3HvvvYU3pB966KE89NBDm61fs2ZN7rnnnnzpS19a7/EddtghSbJ06dIaHbf6G7vV39b9MG3btk3v3r1z7bXXZvjw4Zk4cWIee+yx3H333RkyZMgG9R/72MfSvHnzrFmzJo8//niNjpF88E3lGTNmJEk++tGPFr45W9f56qpjx45JkiVLlmyypr572hJb6zzblNqeH1uqS5cuad26dZYvX77eLRU2Zu7cuUmSPffcc6vPsa7qc2XdwA8ANFWucdfXkK5xa+roo4/OMccck4ceeijvv/9+Xn755XzkIx/ZoK5Xr17Za6+98vLLL2fcuHE566yzkiTjx49P8kE46eCDD97ifraGioqKnHDCCbnvvvsyatSofP7zn6/V/q4HAQBoSqyYAwBAgzFu3Litsk/37t2TJO+9914hRLA51d/Ird6vpsrKynLZZZelbdu2SZJrr7228KHLutq2bZvDDz88SfL444/ntddeq9H89957b957770kyYABAwqPt2nTJh//+MeTJI8++mhef/31WvVdW9UfWixevHiTNfXd05bYWufZh6np+bE19OzZM0kybdq0TdZUVlamsrJyvfqtPUe16g9iqs8dAGjKXOOuryFd49bG3nvvXdiu/vs25pRTTkmSzJw5My+++GJef/31PP3000mSk08+eZtaYea8885Ls2bNsnjx4txyyy212tf1IAAATYlgDgAADcKrr76aZ555Jkny1a9+tbCk/qZ+vvvd7yZJZs2aleeff369uapvA5AkkyZN2uxxn3vuucybN2+D/WqqY8eOhW8zz5s3L3ffffdG684888wkSVVVVa688soPnfedd97JL37xiyRJ69at85nPfGa98S9/+cuF+S677LJUVVXVqN/a3mYgSfbZZ58kH7y5vrlvFNdnT3W1Nc+zmqjp+bGl+vXrlyR57bXXMnPmzI3W3HfffYXt/v37F2WOatUfpO27774f0jkANG6ucdfXEK9xa+rNN98sbP/Lv/zLJutOOeWUNGv2wdv248aNK6yWUz22Ldl7770zcODAJMnNN9+cd999t8b7uh4EAKApEcwBAKBBuOuuuwrb1W/+bs7AgQMLb2j/8wcFRx55ZLp27ZokueGGGworfPyzVatWZeTIkUk++GbwaaedVpfWc9ZZZ6Vdu3ZJkhtvvDFr1qzZoOaoo44q/F1/+9vfcsUVV2y0LvngA4uvfvWrmT9/fpLke9/7Xtq3b79ezeGHH57BgwcnSR555JFcfPHFWbly5SZ7rKqqyt13373Bhx81Uf1hTlVVVZ599tlN1tVnT3W1Nc+zmqrJ+bGlBg8enNatWydJrr766g0+xFq8eHFuuummJEnv3r03utrN1pgj+eAb4i+88EKSbDO3YgCAUnGN+38a4jXu66+/np///OcfuqrOrFmz8sADDyRJ9thjj+yyyy6brO3WrVvhGulPf/pTIZjTu3fvzd4qtFS+8Y1vpHnz5nnnnXdy66231mgf14MAADQ1gjkAAGzzqqqqcs899yT54BuVFRUVH7pP165dC2+m33PPPet9AFBeXp5LLrkkSTJ//vycdtppue222/LKK6/knXfeyT/+8Y9MnDgxX/jCF/I///M/SZJhw4bV+Y3wtm3bFr4t/Nprr2XChAkbrbv88svzsY99LEly66235rTTTsvdd9+dOXPmZPHixXnxxRfzm9/8JieeeGKeeuqpJMnnP//5fPazn93ofJdeemnh9gFjx47NCSeckFGjRmXmzJlZsGBBFixYkJkzZ+bmm2/OoEGDcuGFF2bZsmW1/vt23333wrd+N3ebo/rsqS629nlWUzU5P1588cX8/e9/L/ys+43rWbNmrTe2cOHCDfbv2LFjzj333CTJww8/nOHDh2fWrFlZuHBhpkyZkqFDh2b+/PkpLy/PhRdeuNE+t8YcSTJjxozCfycfxADQlLnGbfjXuO+//36uv/76HHXUUfn2t7+du+++Oy+++GIWLVqUhQsX5tlnn80vfvGLfOELX8iKFSuSJN/85jc/9NiDBg1KkrzxxhuFW4Bta6vlVNtjjz0KvdX09mKuBwEAaGrKS90AAAB8mMcee6yw1P5JJ51U4/0GDhyYxx57LPPnz8///M//5MgjjyyMHXvssRk5cmQuueSSVFZW5vLLL9/kPGeeeWa+9a1v1f0P+P/n+O1vf5slS5bkv/7rv3LSSSelrKxsvZq2bdvmN7/5TS6//PLcddddmTFjxiYDDq1bt843vvGNwnL+G7P99tvnxhtvzNVXX51bb7018+bNy3/8x39ssr5169b5t3/7tzr9fccff3xGjx6dRx55pBDeKHVPtVWM86ymPuz8uOyyy/LYY49tdN9vfOMb6/0+YsSIDBkyZIO6s88+O3Pnzs2YMWMyceLETJw4cb3xFi1a5Morr0yfPn022efWmOPhhx9OkvTs2TPdu3ffZB0ANHaucTfU0K5xW7ZsmRYtWmTFihW59957c++9925yru222y4XXnhhPvnJT9bouJdffnnee++9JB9cY9VkRaVSOffcc3PPPfdk1apVNap3PQgAQFNjxRwAALZ548aNK2zX5g3pE044IS1atEiy8dsMDRo0KA8++GDOPffcfOxjH0v79u1TXl6etm3bZt99983pp5+ecePG5eKLL07z5s236G9o27ZtzjrrrCTJCy+8UFjK/p9tv/32GTFiRO6+++7827/9Wz760Y+mffv2adGiRTp37pw+ffrkm9/8Zu6///7NfmBRrUWLFrnwwgszceLEfOtb38ohhxySLl26pFWrVtluu+2y8847p3///rnkkksyefLknHfeeXX6+6q/0fzUU09l7ty520RPtVWs86wmanp+bKnLLrss119/fY4++ujstNNOadGiRXbeeecMGTIkf/zjHwvfzi7mHH/605+SpF5vUQYA2yLXuA3/GnePPfbI//7v/+bnP/95Tj/99HzsYx9Lx44d06JFi7Rs2TI77bRTDjnkkAwfPjx//vOf8/n/r737Dm+qbMMAfidNundpKatMy96r7D0KyJKhDFH2UBHZioKCCoLAhyJ7qojIktGWUkYpo4wyyi67lFLo3ivj+yPmQGnSJm3StOX+XZeXNGc9Jycn73NOnvO+w4bptF0bGxt069ZN+Ltjx465hvUqTipVqqSxMFwb5oNERERE9LYRKZVKpamDICIiIiKiku/999/HlStXMG3aNEycONHU4VAxFBISgmHDhsHa2hpBQUGwtbU1dUhEREREeWKOa1jMB4mIiIjobcQec4iIiIiIyCAmTZoEAPj777+RlZVl4mioOPr9998BACNHjuSPMERERFQiMMc1LOaDRERERPQ2YmEOEREREREZRIcOHdCqVStERkZiz549pg6Hipn79+/jyJEjcHJywvjx400dDhEREZFOmOMaDvNBIiIiInpbsTCHiIiIiIgMZtasWRCLxVi/fj2fKKYcVq9eDYVCgcmTJ/PpaCIiIipRmOMaBvNBIiIiInpbiZRKpdLUQRARERERERERERERERERERERlTbsMYeIiIiIiIiIiIiIiIiIiIiIyAhYmENEREREREREREREREREREREZAQszCEiIiIiIiIiIiIiIiIiIiIiMgIW5hARERERERERERERERERERERGQELc4iIiIiIiIiIiIiIiIiIiIiIjICFOURERERERERERERERERERERERsDCHCIiIiIiIiIiIiIiIiIiIiIiI2BhDhERERERERERERERERERERGREbAwh4iIiIiIiIiIiIiIiIiIiIjICFiYQ0RERERERERERrV3717UrFkTNWvWxPnz500dDhERERERERFRkWFhDhERERERERGREUVERAhFKer/goKCdFr2zJkzuZaNiIgwcsRERERERERERGQoLMwhIiIiIiIiIipie/fuNeh8hjBy5EjUrFkTnTt3LrJtEhERERERERGVdhJTB0BERERERERE9LawtLRERkYGAgICkJiYCAcH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ZcpUU4dkMG5uZTFu3ERTh0FExQxzjpJDJpMhOTkZDg6OaNnSC598MhUSidTUYRmEtbU1xo6dYOowiKgUY2EOERERURELDr5s6hCIiIiIiIioGOrQoRPOnr1k6jCIiIhy8fSsiXPnQkwdBhFRiSQ2dQBERERERERERERERERERERERKURC3OIiIiIiIiIiIiIiIiIiIiIiIyAhTlEREREREREREREREREREREREbAwhwiIiIiIiIiIiIiIiIiIiIiIiNgYQ4RERERERERERERERERERERkRGwMIeIiIiIiIiIiIiIiIiIiIiIyAhYmENEREREREREREREREREREREZAQszCEiIiIiIiIiIiIiIiIiIiIiMgIW5hARERERERERERERERERERERGQELc4iIiIiIiIiIiIiIiIiIiIiIjICFOURERERERERERERERERERERERsDCHCIiIiIiIiIiIiIiIiIiIiIiI5AYc+VOTjbGXH2RiY9PNXUIgg0b1mLTpvXo1etdfPPNt3otGxJyCVOmjIe7ezns33841/Ts7Gz8/vtWHDnii+fPI5GVlQUACA6+bJDYSxMvryYAgL17D6F8+fJG2cbjx48wfPgQNGjQEGvWbDTKNsgw/Px8sGDBPAwfPhKffjrN1OEQEREREREREREREREREVExYdTCHNJOJpPBz88HAQFHcO/ePSQmJsDKygrOzi6oUKEiGjVqgmbNmqNOnbpFFtPSpYtx4MA+ABBiUQsMPIGwsLto0qQZmjZtpnUd6oIVAGjbtj2WLVuZ5zZnzfoCp06dFP42ZBGQrjEXV2vW/Aq5XI6PPx5n6lDeaocOHcDz55Ho0KETPD1rapynW7ce2LhxHXbv3oWhQ4fBza1sEUdJRERERERERERERERERETFUZEU5vwVHFYUmzG4D7w8jbLe+Ph4fPHFp7h9+5bwmoWFBZRKJcLDn+DJk8c4e/Y0bG1tERBwymDbtbS0ROXKVeDq6pprWkpKMg4fPggA+PHHpejUqUuO6YGBJ+Hjo5qua5FLcPBZxMfHw8nJSeP0xMQEnD17Wp9d0EtBYi4ubty4jsDAE6hbtx5atGhp6nDeaocPH8SVKyEoV6681sIcMzMzfPjhx/jhh++wceN6fPnl10UcJRERERERERERERERERERFUdiUwfwNlqw4Cvcvn0L1tY2+OSTqTh8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CGtrK1OHQvl4+fIlPvpoNNq0aQeRSGTqcIiIiIiIiIiIiIiIiIiIqJhgYQ5RMSWRSDB69FhTh0E6aNSoMRo1amzqMIiIiIiIiIiIiIiIiIiIqJjhUFZEREREREREREREREREREREREbAwhwiIiIiIiIiIiIiIiIiIiIiIiNgYQ4RERERERERERERERERERERkREUujBHqVQaIg4iIiIiIiIiIiIiIiIiIiIiomLDEDUxehfmSCSSHH9nZmYWOggiIiIiIiIiIiIiIiIiIiIiouIkIyMjx99v1szoQu/CHCcnJwCASKT6+9q1K3pvlIiIiIiIiIiIiIiIiIiIiIioOAsNvQrgVY2MumZGH3oX5jRv3vy/jaq2umHDWpw/fw7p6ekc1oqIiIiIiIiIiIiIiIiIiIiISiylUon09HScP38OGzasBfCqRqZFixZ6r0/vPnbatWsHHx8fiMUiKJVKJCUl4+efl+q9YSIiIiIiIiIiIiIiIiIiIiKi4kwkAsRiVWFOu3bt9F5e7x5zGjRoIGzIzEwMsVgkdNlDRERERERERERERERERERERFTSqQtyzMxUpTXt2rVD/fr19V6P3j3miMVizJ49GwAQFBT0X1UQK3OIiIiIiIiIiIiIiIiIiIiIqPRp164dZs+eDbFY7/5vIFIqlcqCbFShUOD69esICgrChQsXEB8fD5lMVpBVEREREREREREREREREREREREVCxKJBE5OTmjRooXQU05BinKAQhTmEBERERERERERERERERERERGRdgUr5yEiIiIiIiIiIiIiIiIiIiIiojyxMIeIiIiIiIiIiIiIiIiIiIiIyAhYmENEREREREREREREREREREREZAQszCEiIiIiIiIiIiIiIiIiIiIiMgIW5hARERERERERERERERERERERGQELc4iIiIiIiIiIiIiIiIiIiIiIjICFOURERERERERERERERERERERERsDCHCIiIiIiIiIiIiIiIiIiIiIiI2BhDhERERERERERERERERERERGREbAwh4iIiIiIiIiIiIiIiIiIiIjICFiYQ0RERERERERERERERERERERkBP8H0opNye3p3oIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 305,
       "width": 1139
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_style(\"whitegrid\")\n",
    "fig, ax = plt.subplots(figsize=(12,4))\n",
    "df = ood_table.melt(id_vars='Method', var_name='Metric', value_name='value')\n",
    "\n",
    "sns.barplot(\n",
    "    x='Metric', y='value',hue='Method',\n",
    "    data=df,\n",
    "    ax=ax, palette=pallete, hue_order=method_list\n",
    ")\n",
    "ax.get_legend().remove()\n",
    "sns.set(font_scale=1.2)\n",
    "handles = ax.get_legend_handles_labels()\n",
    "legend = fig.legend(*handles, \n",
    "#            loc ='upper left',\n",
    "           loc ='lower center',\n",
    "           bbox_to_anchor=(0.5, -0.15),\n",
    "           fontsize=12,\n",
    "           ncol=6\n",
    "          )\n",
    "# ax.set_ylim(top=0.95)\n",
    "ax.set_yticks(np.arange(0,1,0.15))\n",
    "legend.get_frame().set_linewidth(2)\n",
    "legend.get_frame().set_edgecolor(\"k\")\n",
    "# plt.savefig('./standard_benchmark.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "9fd23139",
   "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>Method</th>\n",
       "      <th>Test acc</th>\n",
       "      <th>Test nll</th>\n",
       "      <th>AUROC (CIFAR100)</th>\n",
       "      <th>AUROC (SVHN)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>HMC</td>\n",
       "      <td>0.9032</td>\n",
       "      <td>0.320228</td>\n",
       "      <td>0.851296</td>\n",
       "      <td>0.874216</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Channel-wise moment</td>\n",
       "      <td>0.9022</td>\n",
       "      <td>0.348696</td>\n",
       "      <td>0.851301</td>\n",
       "      <td>0.926306</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Channel-wise covariance</td>\n",
       "      <td>0.9020</td>\n",
       "      <td>0.348104</td>\n",
       "      <td>0.847177</td>\n",
       "      <td>0.921228</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Channel-wise covariance (before activation)</td>\n",
       "      <td>0.9024</td>\n",
       "      <td>0.338232</td>\n",
       "      <td>0.847707</td>\n",
       "      <td>0.919745</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Spatial moment</td>\n",
       "      <td>0.9030</td>\n",
       "      <td>0.320402</td>\n",
       "      <td>0.854460</td>\n",
       "      <td>0.920896</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>Spatial covariance</td>\n",
       "      <td>0.9026</td>\n",
       "      <td>0.320439</td>\n",
       "      <td>0.854148</td>\n",
       "      <td>0.922295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>BatchNorm</td>\n",
       "      <td>0.9041</td>\n",
       "      <td>0.320046</td>\n",
       "      <td>0.858087</td>\n",
       "      <td>0.936054</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                        Method  Test acc  Test nll  \\\n",
       "0                                          HMC    0.9032  0.320228   \n",
       "1                          Channel-wise moment    0.9022  0.348696   \n",
       "2                      Channel-wise covariance    0.9020  0.348104   \n",
       "3  Channel-wise covariance (before activation)    0.9024  0.338232   \n",
       "4                               Spatial moment    0.9030  0.320402   \n",
       "5                           Spatial covariance    0.9026  0.320439   \n",
       "6                                    BatchNorm    0.9041  0.320046   \n",
       "\n",
       "   AUROC (CIFAR100)  AUROC (SVHN)  \n",
       "0          0.851296      0.874216  \n",
       "1          0.851301      0.926306  \n",
       "2          0.847177      0.921228  \n",
       "3          0.847707      0.919745  \n",
       "4          0.854460      0.920896  \n",
       "5          0.854148      0.922295  \n",
       "6          0.858087      0.936054  "
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "72632a3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "50f1a23f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Test acc $\\uparrow$', 'Test nll $\\downarrow$',\n",
       "       'AUROC (CIFAR100) $\\uparrow$', 'AUROC (SVHN) $\\uparrow$'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 133,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ood_table.columns[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 242,
   "id": "42ff7779",
   "metadata": {},
   "outputs": [],
   "source": [
    "pallete[1] = '#2171b5'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 265,
   "id": "2fe6fd26",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABuMAAAJHCAYAAACKKSveAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAABYlAAAWJQFJUiTwAACthUlEQVR4nOzdf1zV9f3//zsGomAKGB4pSE3jNDCZb/qhRSss3rPpRxNd5Qp1qesT74lzvotm2YZh5Fy2Zn5qBauNVNoM00o2nD/SuJgzIxkck/yRCltHFMEAE9Tz/cPvOYOAI+dwXh443q6Xi5e9PM/H6/l8nMvllc+d8zjP59PPZrPZBAAAAAAAAAAAAMDjeng7AQAAAAAAAAAAAMBXUYwDAAAAAAAAAAAADEIxDgAAAAAAAAAAADAIxTgAAAAAAAAAAADAIBTjAAAAAAAAAAAAAINQjAMAAAAAAAAAAAAMQjEOAAAAAAAAAAAAMAjFOAAAAAAAAAAAAMAgFOMAAAAAAAAAAAAAg1CMAwAAAAAAAAAAAAxCMQ4AAAAAAAAAAAAwCMU4AAAAAAAAAAAAwCAU4wAAAAAAAAAAAACD+Hs7AQAAjLB161bl5eWptLRUtbW1Cg8P1+jRozV9+nRFR0e71WdDQ4P+9re/6Z///KfKysp07Ngx1dTU6OzZswoNDVVMTIzGjRuncePGqUePtn/vUlFRobvvvrtD4+3YsUNhYWFu5QoAAAAAAACga/Cz2Ww2bycBAIAnLVq0SCtXrmyzrWfPnlq8eLEmTJjgcr/l5eX6P//n/1w0bsSIEXr11VfVv3//Vm0U4wAAAAAAAIDLCyvjOshisejMmTO64oorFBgY6O10AADt+Mtf/uIoxCUlJemxxx5TRESELBaLlixZovLyci1YsEBRUVEaOXKkS3336NFDI0aMUEJCgkaMGKGIiAgNGDBADQ0NOnz4sFatWqW///3vKikp0f/8z/9o9erV8vPza7e/1157TTfddFO77cHBwS7l11HMaQDQPZw5c0bnzp1TYGCgYmJivJ1Ol8ScBgDdA3Oac8xnANA9dGY+oxjXQWfOnNH58+d1/vx5NTU1eTsdAEAbTp06pTVr1kiS4uLitHz5ckcxLCEhQcOHD9f48eNVVVWlJUuWKC8vz6X+hw0bpr/85S+tXg8LC1NkZKRuv/12ZWRkaNWqVSouLtauXbt0yy23tNtfr169DCu4OcOcBgDdy5kzZ7ydQpfFnAYA3QtzWtuYzwCge3FnPqMY10FXXHGFzp8/rx49eigoKMjb6QAA2vD3v/9dp0+fliQ99NBDrValhYSEaNasWcrKylJxcbEsFovHf5U5ZcoUrVq1SpJUWlrqtBjnLcxpANA9NDQ06Pz587riiiu8nUqXxZwGAN0Dc5pzzGcA0D10Zj6jGNdBgYGBampqUlBQkMxms7fTAQC0obS0VJJkMpl0ww03tBkzduxYZWVlSZI2b97s8WKcv/9/ptauur0IcxoAdA/79u1TXV1dl51PugLmNADoHpjTnGM+A4DuoTPzWQ8D8gEAwCvKysokXdhOsj0DBw6UyWSS9J/inScVFBQ4rm+88cYO3dPY2OjxPAAAAAAAAAB0DayMAwD4BKvVqvr6eknSgAEDnMZGRkbKarXq0KFDHhn71KlTOnr0qP785z/r7bfflnRhBd6IESOc3vfss8+qsrJSDQ0N6tmzpwYPHqw77rhD06ZN08CBAz2SGwAAAAAAAADvohgHAPAJJ0+edFz37dvXaWz//v0lSTU1NW6P99Zbb+nZZ59t9XqvXr30wx/+UOnp6Rft44svvnBcNzY2qry8XOXl5Vq9erUyMzM1btw4t/MDAAAAAAAA0DVQjAMA+ISGhgbHdc+ePZ3G2vd1tq+k86Tvf//7mjJligICAtps79GjhxISEjRu3DjFxsYqIiJCgYGBOnLkiDZs2KCcnBw1NDTo8ccfV79+/ZSQkODxHO3q6uq0e/duw/oHAAAAAAAAwJlxAAAfYbPZDIltzwMPPKBPP/1Un376qbZv367XX39dd955p9atW6fJkyc7tqv8tquvvlo5OTlKTk6W2WxW3759FRgYqOuvv15z585Vbm6uevXqpXPnzunZZ5/VuXPnOp0rAAAAAAAAAO9hZRwAwCcEBwc7rhsbG53G2tub3+OqgIAAx+q34OBgDRgwQN/73veUmZmp3Nxc/fKXv9SwYcMUHx/vUr9xcXFKSUnR66+/ri+//FIlJSUaOXKk23k606dPH5nNZkP6BgB03r59+1RXV+ftNAAAAAAAncTKOACATwgNDXVcnzp1ymnsiRMnJEkhISEez2P+/Pnq3bu3bDabVq1a5VYfiYmJjmuLxeKp1AAAAAAAAAB4AcU4AIBPMJlMCgoKkiQdO3bMaWxFRYUkaciQIR7Po3fv3rr++uslSZ9//rlbffTv399x/fXXX3skLwAAAAAAAADeQTEOAOAzYmNjJUn79+9vN8ZqtcpqtbaI9zT7OW9+fn5u3X/8+HHH9ZVXXumRnAAAAAAAAAB4B8U4AIDPsG/vaLVadeDAgTZjCgoKHNdjxozxeA61tbUqLy+XJEVGRrrVx8aNGx3XRhUMAQAAAAAAAFwaFOMAAD5j0qRJ6t27tyQpNzdXNputRXtNTY2ys7MlSXFxcS4Xutor8NmdP39ezz77rJqamiRJ//3f/90q5quvvnLax86dOx1nzQ0ePFgjRoxwKUcAAAAAAAAAXQvFOACAzwgLC9P9998vSfr000+VlpamvXv3qrq6WkVFRUpJSVFVVZX8/f2Vnp7e6v78/HyZzWaZzWbl5+e3av/Vr36l+++/X3/84x9VUlKiqqoqnTp1SkeOHNF7772nqVOn6r333pN0odg3ceLEVn3cd999mjNnjt5991198cUXOnnypE6ePKmSkhJlZWVp5syZamxslL+/v5555hn16MFUDQAAAAAAAHRn/t5OAAAAT5o8ebIqKiq0adMmFRYWqrCwsEV7QECAMjMzFR8f71b/e/bs0Z49e5zG3HHHHXrhhRd0xRVXtGo7e/Zsm3k1169fPy1evFi33367WzkCAAAAAAAA6DooxgEAfM7MmTN12223adu2bSorK1Ntba3Cw8M1atQozZgxQ2az2a1+MzIyVFRUpJ07d+rgwYM6ceKEvv76awUFBSkiIkJxcXEaN26cRo8e3W4fWVlZ+uSTT7Rnzx5ZrVbV1NSoqalJ/fr107Bhw5SQkKApU6YoNDTU3bcPAAAAAAAAoAuhGAcA8Ek333yzHn74YZfuSU5OVnJycrvt1113na677jqlpKS4nVdSUpKSkpLcvh8AAAAAAABA98JBNAAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABmGbSi/w8/PzdgrwETabzdspOPBcw1O60nMN4PLDfAZPYk7rPvhvH57Ef/sAAHgW/18NnuLN/5/GyjgAAAAAAAAAAADAIKyM86LXB8R7OwV0U7OP7fZ2Cu2Kn5vr7RTQTe1+KcXbKQCAA/MZOoM5rfviMxo6o6t9TmMVATyJFZ8AugI+p8FdXeEzGivjAAAAAAAAAAAAAIOwMg4AAAAAAMBHsYoAndEVVhIAAOALWBkHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAG8fd2AgAAAAAAY23dulV5eXkqLS1VbW2twsPDNXr0aE2fPl3R0dGd6vvrr7/W6tWrtWXLFh08eFB1dXXq1auXrr32Wo0ePVoPPfSQrrnmGg+9EwAAAADofijGAQAAAIAPW7RokVauXNnitcrKSq1Zs0br16/X4sWLNWHCBLf6tlgsevTRR3Xs2LEWr9fV1clischisWjVqlV67rnn9IMf/MDt9wAAAAAA3RnbVAIAAACAj8rJyXEU4pKSkpSfn68dO3YoJydH0dHRamxs1IIFC1RcXOxy33V1dY5CXEBAgB555BG9++672rFjh9577z3NnTtXQUFBOn36tJ544gnt37/f028PAAAAALoFinEAAAAA4IOqq6u1YsUKSVJCQoKWL1+u2NhYhYWFKSEhQbm5uQoPD1dTU5OWLFnicv8FBQWOFXHz5s1Tenq6vvOd7ygsLEzR0dFKTU3V4sWLJUlNTU3685//7Lk3BwAAAADdCMU4AAAAAPBB69atU319vSRp/vz58vPza9EeEhKiWbNmSZKKi4tlsVhc6n/v3r2O6/a2ufz+97+vXr16SZIOHjzoUv8AAMB1fn5+/OGPR/4A8CyKcQAAwC3e/mDAH9/6A8DzNm/eLEkaNGiQYmJi2owZO3Zsq/iO6tmzp+O6vf+O/fz81KPHhY+d/fv3d6l/AAAAAPAV/t5OAAAAAADgeWVlZZKkESNGtBszcOBAmUwmWa1WlZaWutR/bGys4/qvf/2rHn744VYxW7ZsUUNDgyTpe9/7nkv9AwAA970+IN7bKaCbmn1st7dTAHwSxTgAANApfMhDZ/BBDzCG1Wp1bFEZFRXlNDYyMlJWq1WHDh1yaYx7771Xr776qvbv369f//rXOnXqlMaPHy+TyaTjx49r06ZNWr58uaQL21WOGzfOvTcDAAAAAN0cxTgAAAAA8DEnT550XF9se0h7e01NjUtj+Pv7680339S8efO0a9cuvfTSS3rppZdaxERHR2vevHmaOnWqS327qq6uTrt3U9xH18CzCF/Ecw0AQOdwZhwAAAAA+Bj71pCSFBgY6DTW3m5fSeeK8PBwvfjii7r33nvbbK+urta///1vnT592uW+AQAAAMBXsDIOAAAAAHyMzWYzJPbbCgoKlJ6errNnz+qRRx7RxIkTFRERoVOnTmnbtm363e9+p9dee01FRUXKzs5WWFiY22M506dPH5nNZkP6BlwVH88W3vA9nX2u9+3bp7q6Og9lAwBA98PKOAAAAADwMcHBwY7rM2fOOI1tbGxsdU9H7Ny5U/PmzdOZM2eUkZGh9PR03XDDDerXr5+ioqL00EMPKTc3V4GBgSorK9PixYtdfyMAAAAA4AMoxgEAAACAjwkNDXVcnzhxwmmsvT0kJMSlMV577TXZbDZFRUVpypQpbcZER0dr3Lhxki6somNVBAAAAIDLEcU4AAAAAPAxJpNJQUFBkqSjR486ja2oqJAkDRkyxKUxPvvsM0lSbGys/Pz82o0bPny4JOncuXM6ePCgS2MAAAAAgC+gGAcAAAAAPig2NlaSVFJS0m6M1WqV1WptEd9R9u0vnRXiAAAAAAAU4wAAAADAJyUmJkqSDh8+LIvF0mZMQUGB43rMmDEu9T9gwABJUllZmdO40tJSx/XVV1/t0hgAAAAA4AsoxgEAAACAD5o0aZJjq8ply5bJZrO1aK+pqVF2drYkKS4uzuWVcaNGjZIkHTlyRO+8806bMeXl5frggw8kSTExMbrqqqtcGgMAAAAAfAHFOAAAAADwQWFhYUpNTZUkbd++XWlpadq7d6+qq6tVVFSklJQUVVVVyd/fX+np6a3uz8/Pl9lsltlsVn5+fqv2WbNmKTAwUJK0cOFCLV26VPv27dOpU6d09OhRrVy5UikpKY7tLOfMmWPguwUAAACArsvf2wkAAAAAAIwxe/ZsVVRUKC8vT4WFhSosLGzRHhAQoMzMTMXHx7vc93XXXaff/va3evzxx1VXV6fs7GzHSrvm7MU+V7fBBAAAAABfQTEOAAAAAHxYRkaG7rrrLq1evVplZWWqra1VeHi4Ro0apRkzZshsNrvd95gxY7Rhwwa9/fbb+uijj/Tll1+qrq5OgYGBioyM1K233qqpU6dq6NChHnxHAAAAANC9UIwDAAAAAB+XmJioxMREl+5JTk5WcnLyReNMJpPS0tKUlpbmbnoAAAAA4NM4Mw4AAAAAAAAAAAAwiMdXxm3dulV5eXkqLS11bH8yevRoTZ8+XdHR0Z3q++uvv9bq1au1ZcsWHTx4UHV1derVq5euvfZajR49Wg899JCuueYaD70TAEB3tmvXLr344osenY8aGhr0t7/9Tf/85z9VVlamY8eOqaamRmfPnlVoaKhiYmI0btw4jRs3Tj16XPz3LkbOmQAAAAAAAAC6Bo8W4xYtWqSVK1e2eK2yslJr1qzR+vXrtXjxYk2YMMGtvi0Wix599FEdO3asxet1dXWyWCyyWCxatWqVnnvuOf3gBz9w+z0AALq/N954Qxs3bmzxmifmo4qKCj355JNttlmtVlmtVm3ZskV/+tOf9Oqrr6p///7t9mXknAkAAAAAAACg6/DYNpU5OTmOLxWTkpKUn5+vHTt2KCcnR9HR0WpsbNSCBQtUXFzsct91dXWOQlxAQIAeeeQRvfvuu9qxY4fee+89zZ07V0FBQTp9+rSeeOIJ7d+/31NvCwDQzaxdu9ZRiPP0fNSjRw+NGDFCqampevXVV7Vu3Trt2LFDmzZt0h/+8Afdc889kqSSkhL9z//8j2w2W5v9GDlnAgAAAAAAAOhaPLIyrrq6WitWrJAkJSQkaPny5fLz83P8ffjw4Ro/fryqqqq0ZMkS5eXludR/QUGBY0XcvHnzNHPmTEdbWFiYoqOjNXjwYM2bN09NTU3685//rAULFnjirQEAupHq6mrHHDNy5EiPz0fDhg3TX/7yl1avh4WFKTIyUrfffrsyMjK0atUqFRcXa9euXbrlllta5WjknAkAAAAAAACga/HIyrh169apvr5ekjR//nzHl4p2ISEhmjVrliSpuLhYFovFpf737t3ruG5vy67vf//76tWrlyTp4MGDLvUPAPAN69at0+nTpyVJ06ZN8/h81BFTpkxxXJeWlraZo5FzJgAAAAAAAICuxSPFuM2bN0uSBg0apJiYmDZjxo4d2yq+o3r27Om4/vaXls1f79HjwttxdkYPAMB32ecXk8mkoUOHthnTmfmoI/z9/7PoPDAwsFW70XMmAAAAAAAAgK7FI8W4srIySdKIESPajRk4cKBMJpOktlcKOBMbG+u4/utf/9pmzJYtW9TQ0CBJ+t73vudS/wAA32Cfj4YNG9ZuTGfmo44oKChwXN94442t2o2eMwEAAAAAAAB0LZ0+M85qtTq224qKinIaGxkZKavVqkOHDrk0xr333qtXX31V+/fv169//WudOnVK48ePl8lk0vHjx7Vp0yYtX75c0oXtKseNG+femwEAdFvN56MBAwY4jXV3PmrPqVOndPToUf35z3/W22+/LenC6rZvF9wuxZwJAAAAAL5q69atysvLU2lpqWpraxUeHq7Ro0dr+vTpio6O7lTfX3/9tVavXq0tW7bo4MGDqqurU69evXTttddq9OjReuihh3TNNdd46J0AAC43nS7GnTx50nF9se0h7e01NTUujeHv768333xT8+bN065du/TSSy/ppZdeahETHR2tefPmaerUqS717aq6ujrt3r3b0DGAjuJZhC9y97k+fPiw47pv375OY92dj5p766239Oyzz7Z6vVevXvrhD3+o9PT0Vm2XYs50BXMauhKeRfginmsAADxn0aJFWrlyZYvXKisrtWbNGq1fv16LFy/WhAkT3OrbYrHo0Ucf1bFjx1q8XldXJ4vFIovFolWrVum5557TD37wA7ffAwDg8tXpbSrtW0NKbZ+N05y93b4qwBXh4eF68cUXde+997bZXl1drX//+986ffq0y30DALq/M2fOOK6bnzXals7MRxfz/e9/X1OmTFFAQECrtks1ZwIAAACAL8nJyXEU4pKSkpSfn68dO3YoJydH0dHRamxs1IIFC1RcXOxy33V1dY5CXEBAgB555BG9++672rFjh9577z3NnTtXQUFBOn36tJ544gnt37/f028PAHAZ6PTKOJvNZkjstxUUFCg9PV1nz57VI488ookTJyoiIkKnTp3Stm3b9Lvf/U6vvfaaioqKlJ2drbCwMLfHcqZPnz4ym82G9A24Kj4+3tspAB53KZ7rzsxHdg888IAmTZok6ULB7PPPP9dbb72ldevW6YMPPtAzzzyjBx54wO1xPZHjxTCnoSthToMv6uxzvW/fPtXV1XkoGwAAuqfq6mqtWLFCkpSQkKDly5fLz8/P8ffhw4dr/Pjxqqqq0pIlS5SXl+dS/wUFBY4VcfPmzdPMmTMdbWFhYYqOjtbgwYM1b948NTU16c9//rMWLFjgoXcHALhcdHplXHBwsOO6+aqEtjQ2Nra6pyN27typefPm6cyZM8rIyFB6erpuuOEG9evXT1FRUXrooYeUm5urwMBAlZWVafHixa6/EQBAt9Z8brHPN+1xdz5qLiAgQMHBwQoODtaAAQP0ve99T6+99ppSUlJ09uxZ/fKXv2y1PdmlmDMBAAAAwJesW7fOsWPI/PnzHYU4u5CQEM2aNUuSVFxcLIvF4lL/e/fudVy3t83l97//ffXq1UuSdPDgQZf6BwBA8kAxLjQ01HF94sQJp7H29pCQEJfGeO2112Sz2RQVFaUpU6a0GRMdHa1x48ZJuvCLFn5BCgCXl+bz0alTp5zGujsfdcT8+fPVu3dv2Ww2rVq1qt0cjZozAQAAAMCXbN68WZI0aNAgxcTEtBkzduzYVvEd1fyYg28X+pq/3qPHha9RL3b+NwAAbel0Mc5kMikoKEiSdPToUaexFRUVkqQhQ4a4NMZnn30mSYqNjW13UpSk4cOHS5LOnTvHr1QA4DLTfD769qHb3+bufNQRvXv31vXXXy9J+vzzz9vN0ag5EwAAAAB8SVlZmSRpxIgR7cYMHDhQJpNJklRaWupS/7GxsY7rv/71r23GbNmyxXEG+Pe+9z2X+gcAQPJAMU76z6RVUlLSbozVapXVam0R31H2rbycFeIAALDPL84O1O7MfNRR586dk9T2vGX0nAkAAAAAvsJqtTq2qIyKinIaGxkZKUk6dOiQS2Pce++9GjZsmCTp17/+tf7f//t/OnLkiM6cOaPKykr96U9/0pNPPinpwnaV9p25AABwhb8nOklMTNSuXbt0+PBhWSyWNpeMFxQUOK7HjBnjUv8DBgxQZWWl45cw7Wn+y5err77apTEAAN2ffT6yWq06cOCAzGZzq5jOzEcdUVtbq/Lyckn/+TDYVo5GzZkAAAAA4CtOnjzpuL7Y9pD29pqaGpfG8Pf315tvvql58+Zp165deumll/TSSy+1iImOjta8efM0depUl/p2VV1dXauzxwFv4VmEL/Lmc+2RlXGTJk1ybLu1bNky2Wy2Fu01NTXKzs6WJMXFxbn8K/9Ro0ZJko4cOaJ33nmnzZjy8nJ98MEHkqSYmBhdddVVLo0BAOj+Jk2apN69e0uScnNzPT4fHThwwGn7+fPn9eyzz6qpqUmS9N///d9t5mjknAkAAAAAvsK+NaQkBQYGOo21t9tX0rkiPDxcL774ou69994226urq/Xvf/9bp0+fdrlvAAAkD62MCwsLU2pqqn7zm99o+/btSktLU2pqqkwmk/bu3avnn39eVVVV8vf3V3p6eqv78/Pz9Ytf/EKSlJWVpeTk5Bbts2bN0vvvv68zZ85o4cKFOnjwoCZMmKCIiAjV1tZq27Zt+t3vfufYznLOnDmeeFsAgG4mLCxM999/v/74xz/q008/9fh89Ktf/UpnzpzRuHHjNHLkSEVERCgwMFA1NTXas2eP3nrrLcc5p3FxcZo4cWKbOXZmzgQAAACAy8W3f7zoqdhvKygoUHp6us6ePatHHnlEEydOVEREhE6dOuX43vG1115TUVGRsrOzFRYW5vZYzvTp06fNHV4Ab4iPj/d2CoDHdfa53rdvn+rq6ty61yPFOEmaPXu2KioqlJeXp8LCQhUWFrZoDwgIUGZmpltv9rrrrtNvf/tbPf7446qrq1N2drZj1UBz9i8u2dILAC5fkydPVkVFhTZt2uTx+UiS9uzZoz179jiNueOOO/TCCy/oiiuuaLPdyDkTAAAAAHxFcHCw49r+I/z2NDY2trqnI3bu3Kl58+bJZrMpMzNTP/zhDx1t/fr100MPPaSbb75ZU6ZMUVlZmRYvXqwXXnjBpTEAAPBYMU6SMjIydNddd2n16tUqKytTbW2twsPDNWrUKM2YMaNTv+wYM2aMNmzYoLffflsfffSRvvzyS9XV1SkwMFCRkZG69dZbNXXqVA0dOtSD7wgA0B3NnDlTt912m7Zt2+bR+SgjI0NFRUXauXOnDh48qBMnTujrr79WUFCQIiIiFBcXp3Hjxmn06NEd6suoORMAAAAAfEFoaKjj+sSJE05j7e0hISEujfHaa6/JZrMpKipKU6ZMaTMmOjpa48aNU35+vgoKCpSRkaE+ffq4NA4A4PLm0WKcJCUmJioxMdGle5KTk1ttBdYWk8mktLQ0paWluZseAOAycfPNN+vhhx926Z6LzUfXXXedrrvuOqWkpHQ2PUnuzZkAAAAAcLkwmUwKCgpSQ0ODjh496jS2oqJCkjRkyBCXxrAfNRAbGys/P79244YPH678/HydO3dOBw8e1IgRI1waBwBweevh7QQAAAAAAAAAoC2xsbGSpJKSknZjrFarrFZri/iOsm9/6awQBwBAZ1GMAwAAAAAAANAl2XcTOXz4sCwWS5sxBQUFjusxY8a41P+AAQMkSWVlZU7jSktLHddXX321S2MAAEAxDgAAAAAAAECXNGnSJAUFBUmSli1bJpvN1qK9pqZG2dnZkqS4uDiXV8aNGjVKknTkyBG98847bcaUl5frgw8+kCTFxMToqquucmkMAAAoxgEAAAAAAADoksLCwpSamipJ2r59u9LS0rR3715VV1erqKhIKSkpqqqqkr+/v9LT01vdn5+fL7PZLLPZrPz8/Fbts2bNUmBgoCRp4cKFWrp0qfbt26dTp07p6NGjWrlypVJSUhzbWc6ZM8fAdwsA8FX+3k4AAAAAAAAAANoze/ZsVVRUKC8vT4WFhSosLGzRHhAQoMzMTMXHx7vc93XXXaff/va3evzxx1VXV6fs7GzHSrvm7MU+V7fBBABAohgHAAAAAAAAoIvLyMjQXXfdpdWrV6usrEy1tbUKDw/XqFGjNGPGDJnNZrf7HjNmjDZs2KC3335bH330kb788kvV1dUpMDBQkZGRuvXWWzV16lQNHTrUg+8IAHA5oRgHAAAAAAAAoMtLTExUYmKiS/ckJycrOTn5onEmk0lpaWlKS0tzNz0AANrFmXEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEH8vZ0AAABG2LVrl1588UWVlpaqtrZW4eHhGj16tKZPn67o6Gi3+rTZbNq9e7e2b9+u3bt36+DBgzp16pQCAwMVGRmp2267TT/60Y8UFRXVbh8VFRW6++67OzTejh07FBYW5lauAAAAAAAAALoGinEAAJ/zxhtvaOPGjS1eq6ys1Jo1a7R+/XotXrxYEyZMcLnfxx57TFu2bGn1elNTkz7//HN9/vnnWrVqlRYuXKgpU6a4nT8AAAAAAAAA30ExDgDgU9auXesoxCUlJemxxx5TRESELBaLlixZovLyci1YsEBRUVEaOXKkS33X19dLkm666Sb94Ac/0E033aQBAwaovr5eH330kX7729/q5MmTevrppxUeHq4777zTaX+vvfaabrrppnbbg4ODXcoPAAAAAAAAQNdDMQ4A4DOqq6uVl5cnSRo5cqSWL18uPz8/SVJCQoKGDx+u8ePHq6qqSkuWLHHEdtTo0aP1i1/8QjExMS1eDw0N1YMPPqhbb71VycnJamho0NKlSy9ajOvVqxcFNwAAAAAAAMDH9fB2AgAAeMq6det0+vRpSdK0adMchTi7kJAQzZo1S5JUXFwsi8XiUv+pqamtCnHNDRkyRJMnT5YkffHFF/rXv/7lUv8AAAAAAAAAfA/FOACAz9i8ebMkyWQyaejQoW3GjB07tlW8Jw0bNsxxbbVaPd4/AAAAAAAAgO6FYhwAwGeUlZVJalkQ+7aBAwfKZDJJkkpLSz2ew/Hjxx3XV155ZYfuaWxs9HgeAAAAAAAAALoGzowDAPgEq9Wq+vp6SdKAAQOcxkZGRspqterQoUMezcFms6mwsFDShS0xhwwZ4jT+2WefVWVlpRoaGtSzZ08NHjxYd9xxh6ZNm6aBAwd6NDcAAAAAAAAA3kExDgDgE06ePOm47tu3r9PY/v37S5Jqamo8msPatWu1b98+SdIDDzygK664wmn8F1984bhubGxUeXm5ysvLtXr1amVmZmrcuHEeze/b6urqtHv3bkPHADqKZxG+iOcaAAAAACBRjAMA+IiGhgbHdc+ePZ3GBgYGSpJjJZ0nHDhwQJmZmZKkiIgIzZ49u824Hj16KCEhQePGjVNsbKwiIiIUGBioI0eOaMOGDcrJyVFDQ4Mef/xx9evXTwkJCR7LEQAAAAAAAMClRzEOAOATbDabIbEdUV1drdTUVNXX1ysgIEBLly5t97y4q6++Wjk5Oa1ev/766zV37lzdddddmjZtmr755hs9++yz2rBhw0VX2LmrT58+MpvNhvQNuCo+Pt7bKQAe19nnet++faqrq/NQNgAAAAAAb+nh7QQAAPCE4OBgx3VjY6PTWHt783vcVV9fr0cffVRffvmlevTooeeff14333yz2/3FxcUpJSVFkvTll1+qpKSk0zkCAAAAAAAA8B6KcQAAnxAaGuq4PnXqlNPYEydOSJJCQkI6NWZjY6NSU1MdBbNf/vKXGj9+fKf6lKTExETHtcVi6XR/AAAAAAAAALyHYhwAwCeYTCYFBQVJko4dO+Y0tqKiQpI0ZMgQt8c7e/as5s6dq48//liSNH/+fD344INu99dc//79Hddff/21R/oEAAAAAAAA4B2cGQcA8BmxsbHatWuX9u/f326M1WqV1Wp1xLvDZrPpySef1ObNmyVJjz76qH7yk5+41Vdbjh8/7rhu7+w5AABcsXXrVuXl5am0tFS1tbUKDw/X6NGjNX36dEVHR3tkjAMHDujtt99WUVGRvvrqK50/f15XXXWVhg0bpltvvVUPPvigevXq5ZGxAAAAAKA7oRgHAPAZiYmJ2rVrl6xWqw4cOCCz2dwqpqCgwHE9ZswYt8bJyMjQe++9J0n60Y9+pJ///OfuJdyOjRs3Oq7dLRgCAGC3aNEirVy5ssVrlZWVWrNmjdavX6/FixdrwoQJnRpjxYoVeuWVV9TU1NTi9SNHjujIkSPavHmz7rnnHkVGRnZqHAAAAADojtimEgDgMyZNmqTevXtLknJzc2Wz2Vq019TUKDs7W5IUFxfnVqFr2bJlWr16tSRp4sSJeuaZZ1y6/6uvvnLavnPnTq1atUqSNHjwYI0YMcLlHAEAsMvJyXEU4pKSkpSfn68dO3YoJydH0dHRamxs1IIFC1RcXOz2GEuXLtXvfvc7NTU16fbbb9crr7yiDz/8UB999JHefvttLViwQDfccIOn3hIAAAAAdDsU4wAAPiMsLEz333+/JOnTTz9VWlqa9u7dq+rqahUVFSklJUVVVVXy9/dXenp6q/vz8/NlNptlNpuVn5/fqj0nJ0e///3vJUl33HGHFi5cqIaGBtXX17f55+zZs636uO+++zRnzhy9++67+uKLL3Ty5EmdPHlSJSUlysrK0syZM9XY2Ch/f38988wz6tGDqRoA4J7q6mqtWLFCkpSQkKDly5crNjZWYWFhSkhIUG5ursLDw9XU1KQlS5a4NUZRUZHjhy4zZ87UH/7wB40ZM0YDBw5UeHi4vvvd72r69Olat24dq+IAAAAAXLbYphIA4FMmT56siooKbdq0SYWFhSosLGzRHhAQoMzMTMXHx7vcd/MtvrZv366bbrrJaXxWVpaSk5NbvHb27Nk282quX79+Wrx4sW6//XaXcwQAwG7dunWqr6+XJM2fP19+fn4t2kNCQjRr1ixlZWWpuLhYFotFMTExLo3x3HPPSbqwrfL//u//eiZxAAAAAPAxFOMAAD5n5syZuu2227Rt2zaVlZWptrZW4eHhGjVqlGbMmNHmWXKXSlZWlj755BPt2bNHVqtVNTU1ampqUr9+/TRs2DAlJCRoypQpCg0N9VqOAADfsHnzZknSoEGD2i2yjR07VllZWY54V4pxn3zyifbv3y9J+vGPf8xqbgAAAABoB8U4AIBPuvnmm/Xwww+7dE9ycnKrlWzN2b/U7IykpCQlJSV1uh8AAC6mrKxMkpyePzpw4ECZTCZZrVaVlpa61P+2bdskST169FBiYqLjdZvNpnPnzsnfn4+bAAAAACBRjAMAAAAAn2O1Wh1bVEZFRTmNjYyMlNVq1aFDh1wa45///KckafDgwerTp4/eeecdrV69Wp9//rnOnj2r/v37a9SoUfrxj3+s4cOHu/dGAAAAAMAHUIwDAAAAAB9z8uRJx3X//v2dxtrba2pqXBrjX//6lyTJZDLpZz/7mQoKClq0Hz9+XO+//742bNigJ598UtOnT3epf1fU1dVp9+7dhvUPuIJnEb6I5xoAgM5hU38AAAAA8DENDQ2O68DAQKex9nb7SrqOqqurk3Th7LiCggJdf/31ys7O1meffaZPPvlEL730kiIiInT+/HllZWXpww8/dPFdAAAAAIBvYGUcAAAAAPgYm81mSGxz58+flyQ1NTXJZDLprbfeUkhIiKN97NixiomJ0cSJE9XQ0KAXXnhBd955p1tjXUyfPn1kNpsN6RtwVXx8vLdTADyus8/1vn37HD/iAADgcsTKOAAAAADwMcHBwY7rM2fOOI1tbGxsdU9HBAUFOa6nT5/eohBnd+2112ry5MmSLnwRe/ToUZfGAAAAAABfQDEOAAAAAHxMaGio4/rEiRNOY+3tbRXTOjqGsxUTzdv279/v0hgAAAAA4AsoxgEAAACAjzGZTI6VaxdbjVZRUSFJGjJkiEtjDB061HHdt2/fduP69evnuGaLMgAAAACXI4pxAAAAAOCDYmNjJUklJSXtxlitVlmt1hbxHXXjjTc6rmtqatqNa97mrGgHAAAAAL6KYhwAAAAA+KDExERJ0uHDh2WxWNqMKSgocFyPGTPGpf7vvvtu+fn5SZJ27drVbtzOnTsd1zfccINLYwAAAACAL6AYBwAAAAA+aNKkSY6tKpctWyabzdaivaamRtnZ2ZKkuLg4l1fGRURE6J577pEk/elPf2rzbLoDBw7o3XfflSTdcsstMplMrr4NAAAAAOj2PF6M27p1q/7v//2/SkhI0I033qgxY8boqaeeUnl5ucfGOHDggJ577jmNGzdO8fHxGjlypJKSkvTYY4/pzTff1DfffOOxsQAAAACgOwoLC1Nqaqokafv27UpLS9PevXtVXV2toqIipaSkqKqqSv7+/kpPT291f35+vsxms8xms/Lz89sc4/HHH1efPn10/PhxTZ06VX/729904sQJHTt2TGvXrtW0adP0zTffqGfPnnriiScMfb8AAAAA0FX5e7KzRYsWaeXKlS1eq6ys1Jo1a7R+/XotXrxYEyZM6NQYK1as0CuvvKKmpqYWrx85ckRHjhzR5s2bdc899ygyMrJT4wAAAABAdzd79mxVVFQoLy9PhYWFKiwsbNEeEBCgzMxMxcfHu9X/oEGDtGLFCs2dO1eHDx9WWlpaq5igoCD95je/aXHGHAAAAABcTjxWjMvJyXEU4uyr1CIiImSxWLRkyRKVl5drwYIFioqK0siRI90aY+nSpY5tVG6//XY9/PDDiomJ0RVXXKHKykrt2bOn3V9sAgAAAMDlKCMjQ3fddZdWr16tsrIy1dbWKjw8XKNGjdKMGTNkNps71f+oUaP0/vvv64033tDWrVv173//WzabTddcc43uuOMOzZgxQwMHDvTQuwEAAACA7scjxbjq6mqtWLFCkpSQkKDly5c7DvJOSEjQ8OHDNX78eFVVVWnJkiXKy8tzeYyioiJHIW7mzJmttjgJDw/Xd7/7XU2fPr2T7wYAAAAAfEtiYqISExNduic5OVnJyckdig0PD9cTTzzBVpQAAAAA0AaPnBm3bt061dfXS5Lmz5/vKMTZhYSEaNasWZKk4uJiWSwWl8d47rnnJEmxsbH63//9305mDAAAAAAAAAAAABjPIyvjNm/eLOnCeQExMTFtxowdO1ZZWVmO+Pbi2vLJJ59o//79kqQf//jH6tHDIzVEAAAAAAAAAN3E1q1blZeXp9LSUse2y6NHj9b06dMVHR3tkTEOHDigt99+W0VFRfrqq690/vx5XXXVVRo2bJhuvfVWPfjgg+rVq5dHxgIAXD48UowrKyuTJI0YMaLdmIEDB8pkMslqtaq0tNSl/rdt2yZJ6tGjR4utVWw2m86dOyd/f48dfQcAAAAAAACgi1m0aJFWrlzZ4rXKykqtWbNG69ev1+LFizVhwoROjbFixQq98sorampqavH6kSNHdOTIEW3evFn33HOPIiMjOzUOAODy0+kqltVqdWxRGRUV5TQ2MjJSVqtVhw4dcmmMf/7zn5KkwYMHq0+fPnrnnXe0evVqff755zp79qz69++vUaNG6cc//rGGDx/u3hsBAAAAAAAA0OXk5OQ4CnFJSUl67LHHFBERIYvFoiVLlqi8vFwLFixQVFSURo4c6dYYS5cuVXZ2tiTp9ttv18MPP6yYmBhdccUVqqys1J49e5Sfn++x9wQAuLx0uhh38uRJx3X//v2dxtrba2pqXBrjX//6lyTJZDLpZz/7mQoKClq0Hz9+XO+//742bNigJ598UtOnT3epf1fU1dVp9+7dhvUPuIJnEb6I5xoAAAAAYFddXa0VK1ZIkhISErR8+XL5+fk5/j58+HCNHz9eVVVVWrJkifLy8lweo6ioyFGImzlzpp544okW7eHh4frud79r6HeOAADf1unD1xoaGhzXgYGBTmPt7faVdB1VV1cn6cLZcQUFBbr++uuVnZ2tzz77TJ988oleeuklRURE6Pz588rKytKHH37o4rsAAAAAAAAA0NWsW7fO8V3i/PnzHYU4u5CQEM2aNUuSVFxcLIvF4vIYzz33nCQpNjZW//u//9vJjAEAaK3TK+NsNpshsc2dP39ektTU1CSTyaS33npLISEhjvaxY8cqJiZGEydOVENDg1544QXdeeedbo11MX369JHZbDakb8BV8fHx3k4B8LjOPtf79u1z/IgDAAAAANC9bd68WZI0aNAgxcTEtBkzduxYZWVlOeLbi2vLJ598ov3790uSfvzjH6tHj06vXQAAoJVOzy7BwcGO6zNnzjiNbWxsbHVPRwQFBTmup0+f3qIQZ3fttddq8uTJki58EXv06FGXxgAAAAAAAADQtZSVlUmSRowY0W7MwIEDZTKZJEmlpaUu9b9t2zZJUo8ePZSYmOh43Waz6ezZs66mCwBAmzpdjAsNDXVcnzhxwmmsvb2tYlpHx3C2YqJ5m/0XLQAAAAAAAAC6H6vV6tiiMioqymlsZGSkJOnQoUMujfHPf/5TkjR48GD16dNH77zzjqZMmaIbb7xRw4cP1+2336758+e7XOQDAKC5Tm9TaTKZFBQUpIaGhouuRquoqJAkDRkyxKUxhg4d6pgY+/bt225cv379HNdsUQYAAAAAAAB0XydPnnRc9+/f32msvb2mpsalMf71r39JuvAd589+9jMVFBS0aD9+/Ljef/99bdiwQU8++aSmT5/uUv+uqKur0+7duw3rH3AFzyJ8kTefa49sghwbGytJKikpaTfGarXKarW2iO+oG2+80XHtbEJt3uasaAcAAAAAAACga2toaHBcBwYGOo21t9tX0nWU/Qf9n3zyiQoKCnT99dcrOztbn332mT755BO99NJLioiI0Pnz55WVlaUPP/zQxXcBAIAHVsZJUmJionbt2qXDhw/LYrG0eUhq81+VjBkzxqX+7777bmVmZspms2nXrl36r//6rzbjdu7c6bi+4YYbXBoDAAAAAAAAQNdhs9kMiW3u/PnzkqSmpiaZTCa99dZbLY7YGTt2rGJiYjRx4kQ1NDTohRde0J133unWWBfTp08fmc1mQ/oGXOXsuCigu+rsc71v3z63d2X0yMq4SZMmKSgoSJK0bNmyVpNfTU2NsrOzJUlxcXEur4yLiIjQPffcI0n605/+1ObZdAcOHNC7774rSbrlllsch7YCAAAAAAAA6H6Cg4Md12fOnHEa29jY2OqejrB/pylJ06dPb1GIs7v22ms1efJkSRe+iL3YUT0AAHybR4pxYWFhSk1NlSRt375daWlp2rt3r6qrq1VUVKSUlBRVVVXJ399f6enpre7Pz8+X2WyW2WxWfn5+m2M8/vjj6tOnj44fP66pU6fqb3/7m06cOKFjx45p7dq1mjZtmr755hv17NlTTzzxhCfeFgAAAAAAAAAvCQ0NdVy39eP85uztbRXTOjqGsxUTzdv279/v0hgAAHhkm0pJmj17tioqKpSXl6fCwkIVFha2aA8ICFBmZqbbywAHDRqkFStWaO7cuTp8+LDS0tJaxQQFBek3v/lNizPmAAAAAAAAAHQ/JpNJQUFBamhouOhqtIqKCknSkCFDXBpj6NCh+uc//ylJ6tu3b7tx/fr1c1y7u0UZAODy5ZGVcXYZGRl69dVXdeedd+qqq65SQECArr76aiUnJ+udd97Rfffd16n+R40apffff18zZ87U0KFDFRQUpN69e2vYsGH68Y9/rIKCAt19992eeTMAAAAAAAAAvMp+3E1JSUm7MVarVVartUV8RzX/UX9NTU27cc3bnBXtAABoi8dWxtklJiYqMTHRpXuSk5OVnJzcodjw8HA98cQTbEUJAAAAAAAA+LjExETt2rVLhw8flsViUUxMTKuYgoICx/WYMWNc6v/uu+9WZmambDabdu3apf/6r/9qM27nzp2O6xtuuMGlMQAA8OjKOAAAAAAAAADwlEmTJikoKEiStGzZMtlsthbtNTU1ys7OliTFxcW5vDIuIiJC99xzjyTpT3/6U5tn0x04cEDvvvuuJOmWW26RyWRy9W0AAC5zFOMAAAAAAAAAdElhYWFKTU2VJG3fvl1paWnau3evqqurVVRUpJSUFFVVVcnf31/p6emt7s/Pz5fZbJbZbFZ+fn6bYzz++OPq06ePjh8/rqlTp+pvf/ubTpw4oWPHjmnt2rWaNm2avvnmG/Xs2ZPdugAAbvH4NpUAAAAAAAAA4CmzZ89WRUWF8vLyVFhYqMLCwhbtAQEByszMVHx8vFv9Dxo0SCtWrNDcuXN1+PBhpaWltYoJCgrSb37zmxZnzAEA0FEU4wAAAAAAAAB0aRkZGbrrrru0evVqlZWVqba2VuHh4Ro1apRmzJghs9ncqf5HjRql999/X2+88Ya2bt2qf//737LZbLrmmmt0xx13aMaMGRo4cKCH3g0A4HJDMQ4AAAAAAABAl5eYmKjExESX7klOTlZycnKHYsPDw/XEE0+wFSUAwOM4Mw4AAAAAAAAAAAAwCMU4AAAAAAAAAAAAwCAU4wAAAAAAAAAAAACDUIwDAAAAAAAAAAAADOLv7QQAADDCrl279OKLL6q0tFS1tbUKDw/X6NGjNX36dEVHR7vVp81m0+7du7V9+3bt3r1bBw8e1KlTpxQYGKjIyEjddttt+tGPfqSoqKgO9bd161bl5eV5NEcAAAAAAAAAXQvFOACAz3njjTe0cePGFq9VVlZqzZo1Wr9+vRYvXqwJEya43O9jjz2mLVu2tHq9qalJn3/+uT7//HOtWrVKCxcu1JQpU5z2tWjRIq1cudLjOQIAAAAAAADoWtimEgDgU9auXesoxCUlJSk/P187duxQTk6OoqOj1djYqAULFqi4uNjlvuvr6yVJN910k5555hmtX79eH3/8sTZt2qSMjAyFhobqm2++0dNPP60PP/yw3X5ycnIchThP5wgAAAAAAACga6EYBwDwGdXV1crLy5MkjRw5UsuXL1dsbKzCwsKUkJCg3NxchYeHq6mpSUuWLHG5/9GjR2vt2rVauXKlHnroIZnNZoWGhioyMlIPPvigVq9eraCgINlsNi1durTdHFesWCFJSkhI8HiOAAAAAAAAALoWinEAAJ+xbt06nT59WpI0bdo0+fn5tWgPCQnRrFmzJEnFxcWyWCwu9Z+amqqYmJh224cMGaLJkydLkr744gv961//ajNH+wq7+fPnezxHAAAAAAAAAF0LxTgAgM/YvHmzJMlkMmno0KFtxowdO7ZVvCcNGzbMcW21Wlu128ccNGhQu4U9o3MEAAAAAAAAcOlQjAMA+IyysjJJLQti3zZw4ECZTCZJUmlpqcdzOH78uOP6yiuvbNVuz3HEiBHt9mF0jgAAAAAAAAAuHYpxAACfYLVaHds/DhgwwGlsZGSkJOnQoUMezcFms6mwsFDShe0mhwwZ0m6OUVFRXskRAAAAAAAAwKXl7+0EAADwhJMnTzqu+/bt6zS2f//+kqSamhqP5rB27Vrt27dPkvTAAw/oiiuuaDdHew6XOsfm6urqtHv3bsP6B1zBswhfxHMNAAAAAJBYGQcA8BENDQ2O6549ezqNDQwMlCTHKjVPOHDggDIzMyVJERERmj17ttMc7TlcyhwBAAAAAAAAXHqsjAMA+ASbzWZIbEdUV1crNTVV9fX1CggI0NKlS9s8L86bObalT58+MpvNho8DdER8fLy3UwA8rrPP9b59+1RXV+ehbAAAAAAA3sLKOACATwgODnZcNzY2Oo21tze/x1319fV69NFH9eWXX6pHjx56/vnndfPNN180xzNnzlyyHAEAAAAAAAB4D8U4AIBPCA0NdVyfOnXKaeyJEyckSSEhIZ0as7GxUampqSopKZEk/fKXv9T48eM7lKM9B6NzBAAAAAAAAOBdFOMAAD7BZDIpKChIknTs2DGnsRUVFZKkIUOGuD3e2bNnNXfuXH388ceSpPnz5+vBBx/scI5Hjx41PEcAAAAAAAAA3kcxDgDgM2JjYyVJ+/fvbzfGarXKarW2iHeVzWbTk08+qc2bN0uSHn30Uf3kJz9xKUf7ajqjcgQAAAAAAADQNVCMAwD4jMTEREkXilkHDhxoM6agoMBxPWbMGLfGycjI0HvvvSdJ+tGPfqSf//znLud4+PBhWSwWw3IEAAAAAAAA0DVQjAMA+IxJkyapd+/ekqTc3FzZbLYW7TU1NcrOzpYkxcXFubXqbNmyZVq9erUkaeLEiXrmmWdcztG+VeWyZcsMyREAAAAAAABA10ExDgDgM8LCwnT//fdLkj799FOlpaVp7969qq6uVlFRkVJSUlRVVSV/f3+lp6e3uj8/P19ms1lms1n5+fmt2nNycvT73/9eknTHHXdo4cKFamhoUH19fZt/zp4922aOqampkqTt27e7nCMAAAAAAACA7sXf2wkAAOBJkydPVkVFhTZt2qTCwkIVFha2aA8ICFBmZqbi4+Nd7nvlypWO6+3bt+umm25yGp+VlaXk5ORWr8+ePVsVFRXKy8vzeI4AAAAAAAAAuhaKcQAAnzNz5kzddttt2rZtm8rKylRbW6vw8HCNGjVKM2bMkNls9naKysjI0F133aXVq1d32RwBAAAAAAAAdB7FOACAT7r55pv18MMPu3RPcnJymyvZ7DZv3tzZtFpITExUYmKiR/sEAAAAAAAA0LVwZhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQf28nAAAAAAAw1tatW5WXl6fS0lLV1tYqPDxco0eP1vTp0xUdHe3RsWw2m6ZNm6Z//OMfkqRrrrlGmzdv9ugYAAAAANCdsDIOAAAAAHzYokWL9Oijj2rLli2qqqpSY2OjKisrtWbNGk2ePFnr16/36Hhr1qxxFOIAAAAAABTjAAAAAMBn5eTkaOXKlZKkpKQk5efna8eOHcrJyVF0dLQaGxu1YMECFRcXe2S8EydOaOnSpfL399fAgQM90icAAAAAdHcU4wAAAADAB1VXV2vFihWSpISEBC1fvlyxsbEKCwtTQkKCcnNzFR4erqamJi1ZssQjY2ZmZqq2tlYzZszQtdde65E+AQAAAKC7oxgHAAAAAD5o3bp1qq+vlyTNnz9ffn5+LdpDQkI0a9YsSVJxcbEsFkunxvvwww+1YcMGXXPNNfrpT3/aqb4AAAAAwJdQjAMAAAAAH7R582ZJ0qBBgxQTE9NmzNixY1vFu6OhoUEZGRmSpKefflq9e/d2uy8AAAAA8DUU4wAAAADAB5WVlUmSRowY0W7MwIEDZTKZJEmlpaVuj/XSSy+psrJS99xzj8aMGeN2PwAAAADgiyjGAQAAAICPsVqtji0qo6KinMZGRkZKkg4dOuTWWGVlZcrNzVVQUJCefvppt/oAAAAAAF9GMQ4AAAAAfMzJkycd1/3793caa2+vqalxeZxz585p4cKFOnfunObMmaOIiAiX+wAAAAAAX+fv7QQAAAAAAJ7V0NDguA4MDHQaa2+3r6RzxZtvvqmysjKZzWZNmzbN5fs9pa6uTrt37/ba+EBzPIvwRTzXAAB0DivjAAAAAMDH2Gw2Q2Kbq6io0PLly+Xn56eMjAz5+/NbTwAAAABoC5+WAAA+adeuXXrxxRdVWlqq2tpahYeHa/To0Zo+fbqio6Pd7tdqtWrPnj0qKSlRSUmJSktLHSsJsrKylJyc7PT+iooK3X333R0aa8eOHQoLC3M7VwDA5Ss4ONhxfebMGaexjY2Nre7piF/96lc6ffq0HnjgAY0cOdL1JD2oT58+MpvNXs0BsIuPj/d2CoDHdfa53rdvn+rq6jyUDQAA3Y/Hi3Fbt25VXl6ex7/8bIvNZtO0adP0j3/8Q5J0zTXXaPPmzR4dAwDQ/bzxxhvauHFji9cqKyu1Zs0arV+/XosXL9aECRPc6nvq1KmqrKz0RJoAABgmNDTUcX3ixAmnsfb2kJCQDvf/97//Xdu3b1f//v01f/58t3IEAAAAgMuFR4txixYt0sqVK1u85qkvP9uyZs0aRyEOAABJWrt2raMQl5SUpMcee0wRERGyWCxasmSJysvLtWDBAkVFRXXqV/x9+/bV8OHD1a9fPxUUFLjVx2uvvaabbrqp3XZXVygAAGBnMpkUFBSkhoYGHT161GlsRUWFJGnIkCEd7t9+z4kTJ3TLLbc4ja2srHSsWps2bZqeeuqpDo8DAAAAAL7AY2fG5eTkOApxSUlJys/P144dO5STk6Po6Gg1NjZqwYIFKi4u9sh4J06c0NKlS+Xv76+BAwd6pE8AQPdWXV2tvLw8SdLIkSO1fPlyxcbGKiwsTAkJCcrNzVV4eLiampq0ZMkSt8Z4+umnVVBQoH/84x964403NHXqVLfz7dWrl4KDg9v9AwBAZ8TGxkqSSkpK2o2xWq2yWq0t4gEAAAAAnuWRlXHV1dVasWKFJCkhIcFxiLf978OHD9f48eNVVVWlJUuWOL4o7YzMzEzV1tZq1qxZKikp0VdffdXpPgEA3du6det0+vRpSRd+eW+fi+xCQkI0a9YsZWVlqbi4WBaLRTExMS6NMWbMGI/lCwCAkRITE7Vr1y4dPny43Tmv+epuV+a4CRMm6NZbb3Ua89RTT6msrEzh4eF6/fXXJYmzUAEAncLxOACA7sojK+PWrVun+vp6SdL8+fPb/fJTkuPLz8748MMPtWHDBl1zzTX66U9/2qm+AAC+w/7ByGQyaejQoW3GjB07tlU8AAC+aNKkSQoKCpIkLVu2TDabrUV7TU2NsrOzJUlxcXEurYwLCwvTd77zHad/7Ku8e/bs6XjNZDJ56N0BAC43ixYt0qOPPqotW7aoqqpKjY2NjuNxJk+erPXr13t0PI7HAQB4kkeKcfYvMwcNGtTuCgNPffnZ0NCgjIwMSRe2Cuvdu7fbfQEAfEtZWZkkadiwYe3GDBw40PFFYGlp6SXJ62IaGxu9nQIAwAeFhYUpNTVVkrR9+3alpaVp7969qq6uVlFRkVJSUlRVVSV/f3+lp6e3uj8/P19ms1lms1n5+fmXOn0AABw4HgcA0N15ZJtK+5efI0aMaDfG/uWn1Wrt1JefL730kiorK3XPPfewVRgAwMFqtTpWaQ8YMMBpbGRkpKxWqw4dOnQpUmvXs88+q8rKSjU0NKhnz54aPHiw7rjjDk2bNo0PfAAAj5g9e7YqKiqUl5enwsJCFRYWtmgPCAhQZmam4uPjvZQhAADOcTwOAMAXdHplXPMvP6OiopzGRkZGSpLbX36WlZUpNzdXQUFBevrpp93qAwDgm06ePOm47tu3r9PY/v37S7qwPZc3ffHFF2poaJB0YXVceXm5cnJydO+99+qDDz7wam4AAN+RkZGhV199VXfeeaeuuuoqBQQE6Oqrr1ZycrLeeecd3Xfffd5OEQCAdnE8DgDAF3R6ZVzzLz/tX262pzNffp47d04LFy7UuXPnNGfOHEVERLjchyfU1dVp9+7dXhkb+DaeRfgid5/r8vJyx3XPnj2dxgYGBkqS4wPdpdSjRw8lJCRo3Lhxio2NVUREhAIDA3XkyBFt2LBBOTk5amho0OOPP65+/fopISHBsFyY09CV8CzCF3Wl5zoxMVGJiYku3ZOcnKzk5GS3x8zNzXX7XgAA7Dp6PE5WVpYjvr24i+F4HACAUTq9Ms7+i37pP19utqczX36++eabKisrk9ls1rRp01y+HwDg22w2myGxnnb11VcrJydHycnJMpvN6tu3rwIDA3X99ddr7ty5ys3NVa9evXTu3Dk9++yzOnfunNdyBQAAAABvc+V4HKlzZ4NzPA4AwCidXhl3Kb78rKiocOwHnZGRIX9/jxx155Y+ffrIbDZ7bXygOc72gC9y97kODg52XDc2NjqNtbc3v6eriIuLU0pKil5//XV9+eWXKikp0ciRIw0ZizkNXQlzGnxRZ5/rffv2qa6uzkPZAADQ/bh6PE5nzgbneBwAgJE6XdVq/kXmmTNnnMa6++Xnr371K50+fVoPPPCAYV9IAgC6t9DQUMf1qVOnnMaeOHFC0oWzBbqixMREvf7665Iki8XC3AcAAADgssTxOID38CzCF3nzue70NpXNv/y0f7nZHne+/Pz73/+u7du3q3///po/f75bOQIAfJ/JZFJQUJAk6dixY05jKyoqJElDhgwxPC93NP+Q+fXXX3sxEwAAAADwHo7HAQD4ik6vjLN/+dnQ0KCjR486jXXny0/7PSdOnNAtt9ziNLaystKx3da0adP01FNPdXgcAED3Fxsbq127dmn//v3txlitVlmtVkd8V3T8+HHH9ZVXXunFTAAAAADAezgeB/AejhKAL/LmUQKdXhkn/efLzJKSknZjusOXnwCA7i0xMVHShTnnwIEDbcYUFBQ4rrvqgdwbN250XDNnAgAAALhcXcrjce6//36OCAAAGMYjP/VITEzUrl27dPjwYVksFsXExLSKcffLzwkTJujWW291GvPUU0+prKxM4eHhjjN2wsLCOjwGAMA3TJo0ScuXL9fp06eVm5ure++9V35+fo72mpoaZWdnS5Li4uK8Uuj66quvNHDgwHbbd+7cqVWrVkmSBg8erBEjRlyq1AAAAACgS+F4HACAr/BIMW7SpEl6+eWX1dDQoGXLlun111/32JefYWFhFy2s2X/x0rNnT33nO99x4x0AAHxBWFiY7r//fv3xj3/Up59+qrS0NKWmpspkMmnv3r16/vnnVVVVJX9/f6Wnp7e6Pz8/X7/4xS8kSVlZWUpOTm4V89VXX+mrr75y/L35lphHjhzRZ5991iKfa6+9tsX99913n26++Wbdfffdio2N1VVXXSVJOnr0qD744AOtXLlSTU1N8vf31zPPPKMePTyyiB0AAAAAuh2OxwEA+AqPFOPCwsKUmpqq3/zmN9q+fbshX34CANARkydPVkVFhTZt2qTCwkIVFha2aA8ICFBmZqbbe0T/5S9/0csvv9xm2yuvvKJXXnnF8fdJkybp+eefbxFz9uzZNvNqrl+/flq8eLFuv/12t3IEAAAAAF9hPxuc43EAAN2Zx04knT17tioqKpSXl2fIl58AAHTUzJkzddttt2nbtm0qKytTbW2twsPDNWrUKM2YMcOrB2JnZWXpk08+0Z49e2S1WlVTU6Ompib169dPw4YNU0JCgqZMmdJiOxYAAAAAuFxxPA4AwBd4rBgnSRkZGbrrrru0evXqLvflJwDg8nLzzTfr4Ycfdume5OTki67OnjNnjubMmeN2XklJSUpKSnL7fgAAAAC4nHA8DgDAF3i0GCdd+LVKYmKiS/d05MtPZ3Jzc92+FwAAAAAAAEDXxPE4AABf4PFiHAAAAAAAAAB4CsfjAAC6O4pxAAAAAAAAALo0jscBAHRnFOMAAAAAAAAAdHkcjwMA6K56eDsBAAAAAAAAAAAAwFdRjAMAAAAAAAAAAAAMQjEOAAAAAAAAAAAAMAjFOAAAAAAAAAAAAMAgFOMAAAAAAAAAAAAAg1CMAwAAAAAAAAAAAAxCMQ4AAAAAAAAAAAAwCMU4AAAAAAAAAAAAwCAU4wAAAAAAAAAAAACDUIwDAAAAAAAAAAAADEIxDgAAAAAAAAAAADAIxTgAAAAAAAAAAADAIBTjAAAAAAAAAAAAAINQjAMAAAAAAAAAAAAMQjEOAAAAAAAAAAAAMAjFOAAAAAAAAAAAAMAgFOMAAAAAAAAAAAAAg1CMAwAAAAAAAAAAAAxCMQ4AAAAAAAAAAAAwCMU4AAAAAAAAAAAAwCAU4wAAAAAAAAAAAACDUIwDAAAAAAAAAAAADEIxDgAAAAAAAAAAADAIxTgAAAAAAAAAAADAIBTjAAAAAAAAAAAAAINQjAMAAAAAAAAAAAAMQjEOAAAAAAAAAAAAMAjFOAAAAAAAAAAAAMAgFOMAAAAAAAAAAAAAg1CMAwAAAAAAAAAAAAxCMQ4AAAAAAAAAAAAwCMU4AAAAAAAAAAAAwCAU4wAAAAAAAAAAAACDUIwDAAAAAAAAAAAADEIxDgAAAAAAAAAAADAIxTgAAAAAAAAAAADAIBTjAAAAAAAAAAAAAIP4ezsBAACMsGvXLr344osqLS1VbW2twsPDNXr0aE2fPl3R0dFu92u1WrVnzx6VlJSopKREpaWlqq+vlyRlZWUpOTm5w31t3bpVeXl5Hs8RAAAAAAAAQNdBMQ4A4HPeeOMNbdy4scVrlZWVWrNmjdavX6/FixdrwoQJbvU9depUVVZWdjrHRYsWaeXKlYbkCAAAAAAAAKDrYJtKAIBPWbt2raMQl5SUpPz8fO3YsUM5OTmKjo5WY2OjFixYoOLi4k6N07dvX91222269957Xb43JyfHUYgzMkcAAAAAAAAA3sfKOACAz6iurlZeXp4kaeTIkVq+fLn8/PwkSQkJCRo+fLjGjx+vqqoqLVmyxBHriqefflqDBw/WkCFD5Ofnp507d6qgoMClHFesWOHIyYgcAQAAAAAAAHQdrIwDAPiMdevW6fTp05KkadOmOYpcdiEhIZo1a5Ykqbi4WBaLxeUxxowZo+uuu65V367kaD9jbv78+YbkCAAAAAAAAKDroBgHAPAZmzdvliSZTCYNHTq0zZixY8e2ir+U7GMOGjRIMTExbcZ4O0cAAAAAAAAAnkMxDgDgM8rKyiRJw4YNazdm4MCBMplMkqTS0tJLkldz9hxHjBjRboy3cwQAAAAAAADgORTjAAA+wWq1OrZ/HDBggNPYyMhISdKhQ4cMz6u55jlGRUU5jfVWjgAAAAAAAAA8y9/bCQAA4AknT550XPft29dpbP/+/SVJNTU1RqbUSvMc7Tm051LkWFdXp927dxvWP+AKnkX4Ip5rAAAAAIDEyjgAgI9oaGhwXPfs2dNpbGBgoCQ5VqldKs1ztOfQHm/lCAAAAAAAAMCzWBkHAPAJNpvNkFhP6mo59unTR2az2fBxgI6Ij4/3dgqAx3X2ud63b5/q6uo8lA0AAAAAwFtYGQcA8AnBwcGO68bGRqex9vbm91wKzcc7c+aM01hv5QgAAAAAAADAsyjGAQB8QmhoqOP61KlTTmNPnDghSQoJCTEypVaa52jPoT3eyhEAAAAAAACAZ1GMAwD4BJPJpKCgIEnSsWPHnMZWVFRIkoYMGWJ4Xs01z/Ho0aNOY72VIwAAAAAAAADPohgHAPAZsbGxkqT9+/e3G2O1WmW1WlvEX0r2MUtKStqN8XaOAAAAAAAAADyHYhwAwGckJiZKulDMOnDgQJsxBQUFjusxY8Zckryas+d4+PBhWSyWNmO8nSMAAAAAAAAAz6EYBwDwGZMmTVLv3r0lSbm5ubLZbC3aa2pqlJ2dLUmKi4vzyqqzSZMmObaqXLZsWZfMEQAAAAAAAIDnUIwDAPiMsLAw3X///ZKkTz/9VGlpadq7d6+qq6tVVFSklJQUVVVVyd/fX+np6a3uz8/Pl9lsltlsVn5+fptjfPXVV/rss88cf5pviXnkyJEWbUeOHGkzx9TUVEnS9u3bXc4RAAAAAAAAQPfi7+0EAADwpMmTJ6uiokKbNm1SYWGhCgsLW7QHBAQoMzNT8fHxbvX/l7/8RS+//HKbba+88opeeeUVx98nTZqk559/vlXc7NmzVVFRoby8PENyBAAAAAAAANB1UIwDAPicmTNn6rbbbtO2bdtUVlam2tpahYeHa9SoUZoxY4bMZrO3U1RGRobuuusurV69usvmCAAAAAAAAKDzKMYBAHzSzTffrIcfftile5KTk5WcnOw0Zs6cOZozZ05nUnNITExUYmKiR/oCAAAAAAAA0DVxZhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGMTf2wkAAAAAAIy1detW5eXlqbS0VLW1tQoPD9fo0aM1ffp0RUdHu9WnzWbT7t27tX37du3evVsHDx7UqVOnFBgYqMjISN1222360Y9+pKioKA+/GwAAAADoXijGAQAAAIAPW7RokVauXNnitcrKSq1Zs0br16/X4sWLNWHCBJf7feyxx7Rly5ZWrzc1Nenzzz/X559/rlWrVmnhwoWaMmWK2/kDAAAAQHdHMQ4AAAAAfFROTo6jEJeUlKTHHntMERERslgsWrJkicrLy7VgwQJFRUVp5MiRLvVdX18vSbrpppv0gx/8QDfddJMGDBig+vp6ffTRR/rtb3+rkydP6umnn1Z4eLjuvPNOj78/AAAAAOgOKMYBAAAAgA+qrq7WihUrJEkJCQlavny5/Pz8HH8fPny4xo8fr6qqKi1ZskR5eXku9T969Gj94he/UExMTIvXQ0ND9eCDD+rWW29VcnKyGhoatHTpUopxAAAAAC5bPbydAAAAAADA89atW+dYvTZ//nxHIc4uJCREs2bNkiQVFxfLYrG41H9qamqrQlxzQ4YM0eTJkyVJX3zxhf71r3+51D8AAAAA+AqPr4zjYHAAAAAA8L7NmzdLkgYNGtRu0Wzs2LHKyspyxDsrrrlj2LBhjmur1aqrr77ao/0DAAAAQHfg0WIcB4MDAAAAQNdQVlYmSRoxYkS7MQMHDpTJZJLValVpaanHczh+/Ljj+sorr/R4/wAAAADQHXisGMfB4AAAAADQNVitVsfnqIvtIBIZGSmr1apDhw55NAebzabCwkJJF7bEHDJkiEf7BwBcftiRCwDQXXmkGMfB4AAAAADQdZw8edJx3b9/f6ex9vaamhqP5rB27Vrt27dPkvTAAw/oiiuu8Gj/zdXV1Wn37t2G9Q+4gmcRvqgrPNfsyAUA6M56eKITDgYHAAAAgK6joaHBcR0YGOg01t5u/0znCQcOHFBmZqYkKSIiQrNnz/ZY3wCAy8+3d+TKz8/Xjh07lJOTo+joaDU2NmrBggUqLi52ue/mO3I988wzWr9+vT7++GNt2rRJGRkZCg0N1TfffKOnn35aH374oUffFwDg8uGRlXEcDA4AAAAAXYfNZjMktiOqq6uVmpqq+vp6BQQEaOnSpYafF9enTx+ZzWZDxwA6Kj4+3tspAB7X2ed63759qqurc+teduQCAPgCj6yMc+VgcEkcDA4AAAAABgoODnZcnzlzxmlsY2Njq3vcVV9fr0cffVRffvmlevTooeeff14333xzp/sFAFy+2JELAOALOl2Mc/VgcEkcDA4AAAAABgoNDXVcnzhxwmmsvT0kJKRTYzY2Nio1NVUlJSWSpF/+8pcaP358p/oEAKCjO3J9O96Tvr0jFwAArur0NpUcDA54D88ifBHPNQAAnWcymRQUFKSGhgYdPXrUaWxFRYUkdepHjWfPntXcuXP18ccfS7qwcuHBBx90uz8AAOxc2ZHLarWyIxcAoEvq9Mo4DgYHAAAAgK4nNjZWkhwr1dpitVodv/C3x7vKZrPpySefdKxEePTRR/WTn/zErb4AAGiOHbkAAL6i0yvjOBgc8B4OBocv8ubB4AAA+JLExETt2rVLhw8flsViaXNrr4KCAsf1mDFj3BonIyND7733niTpRz/6kX7+85+7lzAAAN/CjlyA9/Aswhd587nu9Mo4DgYHAAAAgK5n0qRJCgoKkiQtW7as1Y8ja2pqlJ2dLUmKi4tza2XcsmXLtHr1aknSxIkT9cwzz3QyawAA/oMduQAAvqLTK+M4GBwAAAAAup6wsDClpqbqN7/5jbZv3660tDSlpqbKZDJp7969ev7551VVVSV/f3+lp6e3uj8/P1+/+MUvJElZWVlKTk5u0Z6Tk6Pf//73kqQ77rhDCxcubPGl6bcFBgbK37/TH0EBAJcRduQCvIcdueCLvLkjV6c/CXEwOAAAAAB0TbNnz1ZFRYXy8vJUWFjoOPPGLiAgQJmZmW59KF25cqXjevv27brpppucxrdV0AMAwBl25AIA+IpOb1MpcTA4AAAAAHRVGRkZevXVV3XnnXfqqquuUkBAgK6++molJyfrnXfe0X333eftFAEAaBM7cgEAfIVH9gjhYHAAAAAA6LoSExOVmJjo0j3JyclOV7LZfyQJAIBR2JELAOArPLIyjoPBAQAAAAAAAHgaO3IBAHyBR4px9oPBJTkOBt+7d6+qq6tVVFSklJSUix4MbjabZTablZ+f36q9vYPB6+vr2/xz9uxZT7wtAAAAAAAAAF5kX9lt35GrLezIBQDo6jyyTaXEweAAAAAAAAAAPGvSpEl6+eWX1dDQoGXLlun111+Xn5+fo50duQAA3YFHVsbZcTA4AAAAAAAAAE9hRy4AgC/w2Mo4Ow4GBwAAAAAAAOAp7MgFAOjuPF6MAwAAAAAAAABPysjI0F133aXVq1errKxMtbW1Cg8P16hRozRjxgyZzWZvpwgAQLsoxgEAAAAAAADo8tiRCwDQXXn0zDgAAAAAAAAAAAAA/0ExDgAAAAAAAAAAADAIxTgAAAAAAAAAAADAIBTjAAAAAAAAAAAAAINQjAMAAAAAAAAAAAAMQjEOAAAAAAAAAAAAMAjFOAAAAAAAAAAAAMAgFOMAAAAAAAAAAAAAg/h7OwEAAIywa9cuvfjiiyotLVVtba3Cw8M1evRoTZ8+XdHR0Z3uv7y8XH/84x+1Y8cOVVVVqV+/fho+fLimTp2qO++8s937KioqdPfdd3dojB07digsLKzTuQIAAAAAAADwHopxAACf88Ybb2jjxo0tXqusrNSaNWu0fv16LV68WBMmTHC7/3Xr1unpp59WY2Oj47Wqqipt2bJFW7Zs0cMPP6yFCxe63T8AAAAAAAAA30ExDgDgU9auXesoxCUlJemxxx5TRESELBaLlixZovLyci1YsEBRUVEaOXKky/0XFxfrqaeeUlNTk6Kjo5Wenq6YmBj9+9//1iuvvKKNGzfqrbfe0jXXXKNHHnnEaV+vvfaabrrppnbbg4ODXc4PAAAAAAAAQNfCmXEAAJ9RXV2tvLw8SdLIkSO1fPlyxcbGKiwsTAkJCcrNzVV4eLiampq0ZMkSt8Z4/vnn1dTUpPDwcOXm5iohIUFhYWGKjY3V8uXLlZCQIEl6+eWXVV1d7bSvXr16KTg4uN0/AAAAAAAAALo/inEAAJ+xbt06nT59WpI0bdo0+fn5tWgPCQnRrFmzJF1Y4WaxWFzqv6ysTJ999pkkadasWQoJCWnR7ufnp/nz50uS6uvrtX79ejfeBQAAAAAAAABfQjEOAOAzNm/eLEkymUwaOnRomzFjx45tFe9q/5J07733thkTExOja6+9VpK0adMml/oHAAAAAAAA4HsoxgEAfEZZWZkkadiwYe3GDBw4UCaTSZJUWlrqVv8mk8nRR1vi4uIkqcMr7xobG13KAwAAAAAAAED34e/tBAAA8ASr1ar6+npJ0oABA5zGRkZGymq16tChQy6NcfDgQUlSVFTURfuXpLq6Olmt1nYLd88++6wqKyvV0NCgnj17avDgwbrjjjs0bdo0DRw40KXcAAAAAAAAAHRNFOMAAD7h5MmTjuu+ffs6je3fv78kqaamxq0x7PdfrH/7GO0V47744gvHdWNjo8rLy1VeXq7Vq1crMzNT48aNcyk/V9XV1Wn37t2GjgF0FM8ifBHPNQAAAABAohgHAPARDQ0NjuuePXs6jQ0MDJQkx0q6jjp9+nSH+u/Vq1ebeUlSjx49lJCQoHHjxik2NlYREREKDAzUkSNHtGHDBuXk5KihoUGPP/64+vXrp4SEBJdyBAAAAAAAANC1UIwDAPgEm81mSGxb/Pz83O7/6quvVk5OTqvXr7/+es2dO1d33XWXpk2bpm+++UbPPvusNmzYoCuuuKJT+banT58+MpvNhvQNuCo+Pt7bKQAe19nnet++faqrq/NQNgAAAAAAb+nh7QQAAPCE4OBgx3VjY6PTWHt783s6onfv3pKkM2fOOI1r3h4UFOTSGHFxcUpJSZEkffnllyopKXHpfgAAAAAAAABdC8U4AIBPCA0NdVyfOnXKaeyJEyckSSEhIW6NYb//Yv27M4YkJSYmOq4tFovL9wMAAAAAAADoOijGAQB8gslkcqxCO3bsmNPYiooKSdKQIUNcGsMef/To0Q71HxwcLJPJ5NIYktS/f3/H9ddff+3y/QAAAAAAAAC6DopxAACfERsbK0nav39/uzFWq1VWq7VFvKv9N++jLXv27HGrf7vjx487rq+88kq3+gAAAAAAAADQNVCMAwD4DPv2jlarVQcOHGgzpqCgwHE9ZswYt/r/dj/NWSwWHTlyxK3+7TZu3Oi4dregBwAAAAAAAKBroBgHAPAZkyZNUu/evSVJubm5stlsLdpramqUnZ0tSYqLi3O50HXjjTdqxIgRkqTs7GzV1NS0aLfZbHrhhRckSUFBQZo4cWKrPr766iunY+zcuVOrVq2SJA0ePNgxHgAAAAAAAIDuiWIcAMBnhIWF6f7775ckffrpp0pLS9PevXtVXV2toqIipaSkqKqqSv7+/kpPT291f35+vsxms8xms/Lz89sc48knn5S/v7+qqqqUkpKioqIiVVdXa+/evUpLS9NHH30kSUpNTVVYWFir+++77z7NmTNH7777rr744gudPHlSJ0+eVElJibKysjRz5kw1NjbK399fzzzzjHr0YKoGAAAAAAAAujN/bycAAIAnTZ48WRUVFdq0aZMKCwtVWFjYoj0gIECZmZmKj493q//4+HhlZmZq4cKFKi8v1yOPPNIq5sEHH9Ts2bPbvP/s2bNt5tVcv379tHjxYt1+++1u5QgAAAAAAACg66AYBwDwOTNnztRtt92mbdu2qaysTLW1tQoPD9eoUaM0Y8YMmc3mTvU/adIkxcTE6M0339THH3+sqqoq9evXT7GxsZo6dWqLs+W+LSsrS5988on27Nkjq9WqmpoaNTU1qV+/fho2bJgSEhI0ZcoUhYaGdipHAAAAAAAAAF0DxTgAgE+6+eab9fDDD7t0T3JyspKTkzsUazablZWV5XJeSUlJSkpKcvk+AAAAAAAAAN0TB9EAAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEEoxgEAAAAAAAAAAAAGoRgHAAAAAAAAAAAAGIRiHAAAAAAAAAAAAGAQinEAAAAAAAAAAACAQSjGAQAAAAAAAAAAAAahGAcAAAAAAAAAAAAYhGIcAAAAAAAAAAAAYBCKcQAAAAAAAAAAAIBBKMYBAAAAAAAAAAAABqEYBwAAAAAAAAAAABiEYhwAAAAAAAAAAABgEIpxAAAAAAAAAAAAgEH8Pd3h1q1blZeXp9LSUtXW1io8PFyjR4/W9OnTFR0d3en+y8vL9cc//lE7duxQVVWV+vXrp+HDh2vq1Km68847PfAOAAC+YNeuXXrxxRe79Hxk9JwJAIAdn9MAAL6A+QwA0F15tBi3aNEirVy5ssVrlZWVWrNmjdavX6/FixdrwoQJbve/bt06Pf3002psbHS8VlVVpS1btmjLli16+OGHtXDhQrf7BwD4hjfeeEMbN25s8VpXm4+MnjMBALDjcxoAwBcwnwEAujOPbVOZk5PjmBCTkpKUn5+vHTt2KCcnR9HR0WpsbNSCBQtUXFzsVv/FxcV66qmn1NjYqOjoaOXk5GjHjh3Kz89XUlKSJOmtt97SH/7wB0+9JQBAN7R27VpHIa6rzkdGz5kAANjxOQ0A4AuYzwAA3Z1HinHV1dVasWKFJCkhIUHLly9XbGyswsLClJCQoNzcXIWHh6upqUlLlixxa4znn39eTU1NCg8PV25urhISEhQWFqbY2FgtX75cCQkJkqSXX35Z1dXVnnhbAIBuprq6Wnl5eZKkkSNHdsn56FLMmQAASHxOAwD4BuYzAIAv8Egxbt26daqvr5ckzZ8/X35+fi3aQ0JCNGvWLEkXfmlisVhc6r+srEyfffaZJGnWrFkKCQlp0e7n56f58+dLkurr67V+/Xo33gUAoLtbt26dTp8+LUmaNm1al5yPjJ4zAQCw43MaAMAXMJ8BAHyBR4pxmzdvliQNGjRIMTExbcaMHTu2Vbyr/UvSvffe22ZMTEyMrr32WknSpk2bXOofAOAb7POFyWTS0KFD24zx9nxk9JwJAIAdn9MAAL6A+QwA4As8UowrKyuTJI0YMaLdmIEDB8pkMkmSSktL3erfZDI5+mhLXFycJLGKAAAuU/b5YtiwYe3GeHs+MnrOBADAjs9pAABfwHwGAPAFnS7GWa1Wx1LxqKgop7GRkZGSpEOHDrk0xsGDB13qv66uTlar1aUxAADdW/P5aMCAAU5jvTUfXYo5EwAAic9pAADfwHwGAPAV/p3t4OTJk47r/v37O421t9fU1Lg1Rkf7t4/h7Ncsrjpz5oykCxPu7t27O9XX73//e0nS+U5nhcvV7////+3ss+hJ9udaavBqHujG/v9nyN3n+vDhw47rvn37Ov7dbou35qNLMWd2hKfmNOYzeEJXm9OYz+ARnZzTvs3ZnNYePqe5hjkNnsCcBp/k5TmN+cx1zGnorK42n0nMafCALvAZrdPFuIaG//wHEBgY6DTW3m7/RUtHnT59WpLUs2dPp3G9evVqMy9POHfunMf6io+P91hfQFfBcw1vaz4J9uzZ0+m/296ajy7FnNkRnprT+O8evojnGl2RO/9u8znNNfy3D1/Ec42uyNV/t5nPXMd/+/BFPNfoatz5d7vTxTibzWZIbFv8/PwM7d+ZwMBAnTlzRldcccVFJ38AwKXX/IORn5+f03+rvTUfXco50xnmNADoHs6cOaNz58659W81n9MAAF2Ju3Ma8xkAoCvpzGe0ThfjgoODWyTiTGNjY6t7OqJ3795qamq6aP/N24OCglwa42JiYmI82h8AwLOafzAymUxO/9321nx0KebMjmBOAwDfx+c0AIAvYD4DAPiKHp3tIDQ01HF94sQJp7H29pCQELfG6Gj/7owBAOjeusN8dClyBABA6h7zIgAAF8N8BgDwFZ0uxplMJsevQY4ePeo0tqKiQpI0ZMgQl8awx3e0/+DgYI8eogoA6Pq6w3x0KXIEAEDqHvMiAAAXw3wGAPAVnS7GSVJsbKwkqaSkpN0Yq9Uqq9XaIt7V/pv30ZY9e/a41T8AwDd0h/nI6BwBALDrDvMiAAAXw3wGAPAFHinGJSYmSpIOHz4si8XSZkxBQYHjesyYMW71/+1+mrNYLDpy5Ihb/QMAfEN3mI+MzhEAALvuMC8CAHAxzGcAAF/gkWLcpEmTHEvGly1bJpvN1qK9pqZG2dnZkqS4uDiXf0Fy4403asSIEZKk7Oxs1dTUtGi32Wx64YUXJF04QHXixInuvA0AQDfXHeYjo3MEAMCuO8yLAABcDPMZAMAXeKQYFxYWptTUVEnS9u3blZaWpr1796q6ulpFRUVKSUlRVVWV/P39lZ6e3ur+/Px8mc1mmc1m5efntznGk08+KX9/f1VVVSklJUVFRUWqrq7W3r17lZaWpo8++kiSlJqaqrCwME+8LQBAN9Md5qPO5ggAQEd1h3kRAICLYT4DAPgCf091NHv2bFVUVCgvL0+FhYUqLCxs0R4QEKDMzEzFx8e71X98fLwyMzO1cOFClZeX65FHHmkV8+CDD2r27Nlu9Q8A8A3dYT4yOkcAAOy6w7wIAMDFMJ8BALo7jxXjJCkjI0N33XWXVq9erbKyMtXW1io8PFyjRo3SjBkzZDabO9X/pEmTFBMTozfffFMff/yxqqqq1K9fP8XGxmrq1Kkt9njG5aOiokJ33323R/rKyspScnKyR/ryhIqKCq1du1aSdMstt+jWW2/1ckaXn5dfflm///3vNXr0aL388svq2bOnt1NCB3SH+cjoHNF9MI+57tv/ffz5z39WXFyc03s++OAD/fznP5ck/fSnP9WcOXMu2ve+ffs6lZs7918KCxYs0Lvvvqtrr71Wf/3rX72dDi6B7jAvAgBwMcxnAIDuzM/27Y2WgW7Gl7/E3Llzp6ZNmybJ+ReHMMby5cv18ssvO/7+ve99TytWrKAgB8CjmMdc9+0vWkaNGqU//vGPTu+hGPcfTz75pNauXatrr71WGzdu9HY6AOBVGzdu1E9/+lP17NlTf//732UymbydEnzQu+++q/T0dF155ZX629/+pv79+3s7JQDwGObSS495pXvy6Mo4wBv69++vFStWtNv+8ccfKzc3V5J06623Or4UbEtMTIzH80P39Lvf/a7Vc7Vt2zb99Kc/ZYUcAI9iHuu8/6+9Ow+rqtr/OP5hEBFUHBIN0FTsOpuWOQ+ZQ+Y89MuGa4OliWnXtDIb7i2fW9qgZplD3izNskwR51lzSHE25zkUUYQQmWf4/cFzdgc5wAHO4Si+X8/j8+zjXnudtWHD4qzvWt8VHBys3bt3q127do5uCoC7yDvvvKNly5ZJkpycnLRp0ybVrFmzwOsCAwM1ceJESdmrMKZMmWLV+5kC6ZLlyRf5rQjx8PBQ5cqVVb9+fXXp0kV9+vSRh4eHVe9r7syZM9qwYYN2796tq1evKjo6Wu7u7qpSpYqaNGmijh07qmfPnnJ3dy903ZJ0/fp1bdiwQXv27NGFCxcUHR2tpKQklS9fXjVq1FDTpk3VqVMnde7c2SZ/j6ekpGjy5MmSpCFDhlg9eGiLdlozeaOwq3yee+45vfvuuwWWK+qza027ivKsZWRk6MKFCzp+/LhOnDih48eP6/Tp00pOTpZU9Ak9WVlZWrdunVasWGHsL1apUiX5+/urT58+GjhwoFxdrRsWK25dffv21ezZsxUSEqKpU6fq448/LvT92BIZYHC7oC+9+/rSI0eOaOXKlTpy5IjCwsIUHx+vMmXKyMvLS7Vq1VL9+vXVvHlztWvXLsf+jJMmTdKPP/4oSQoICNDYsWML1c6kpCS1b99eCQkJcnFx0bZt23K0tSiTKs0nn7Zq1cr43G7OXlld6FfuTATjcMcrV66cunXrluf52NhY49jHxyffsoAkzZgxQ7NmzbJ4bvv27Xrttdf05Zdf0rEAsAn6saIrV66ckpKSJElTp04lGAegxCQmJuZI85qVlaXly5frtddec2Cr8paYmKjExESFhYVp69atmj17tqZNm6YWLVpYdX1ERIQ++eQTrVmzRrcm10lNTVVsbKxCQkK0evVqTZ8+XePHj1e/fv2sbl9cXJy++OILLVmyRKmpqbnOR0dHKzo6WqdOndKSJUtUpUoVBQQE6Omnn1aZMmWsfp9b/fTTTwoLC1PZsmWt2gfKUe20JXs/u0V51saOHZtr/6/iiomJ0Wuvvabg4OAc/x8ZGanIyEgFBwdr8eLFmjlzpnx8fOxel4uLiwICAjRhwgQtX75cL730kvz9/Yt3k0VkngFm+/btevXVV8kAA4egL/3b3dCXxsXF6d1339WGDRtynUtPT1dSUpLCw8O1b98+/fDDD3JyctKhQ4eMgOfgwYONYNyKFSv0r3/9S05OTla3c8OGDUpISJAkdejQwWGr96ZNm1ZgVhdr0K/cmQjGAYAZ80Ccr6+v/Pz8tHfvXtWoUUN16tTRnj17tG3bNgJyAHAbqFGjhurVq6dNmzbp+PHj2rhxo3r06OHoZgG4C5gP6JgEBQVpzJgxhRoYspdbV1zHx8fr5MmTWrFihW7evKmrV69qxIgRCgoKkq+vb751nTt3TsOHD9e1a9ckSWXKlFGHDh3Upk0bVatWTUlJSfrzzz+1adMmXbp0SeHh4XrzzTd16tQpvfXWWwV+PS5duqSRI0fq4sWLxv81a9ZM7dq1k5+fn8qXL6+bN2/q8uXL2rVrl86ePasbN27oo48+Uv369Yu8H2lycrK++eYbSdmrKgoalHNUO03yW0VvYs1qEls/u7Z41jIyMnK8rlSpkipVqqSQkJBCt0fKHtQeNWqUDhw4IEm699579eSTT+q+++5TeHi4li1bpgsXLujEiRMaPny4fvnlF5UvX97udfXt21dffvmlwsLCNHPmTE2fPr1I91ccZIDB7YS+9O7pS9PS0vTSSy/pjz/+MO7/0Ucf1YMPPihvb29lZWUpMjJSp06d0u7duxUREaGsrKwcQcvGjRurfv36OnPmjK5evarg4GC1bdvW6raaVkRKcujWDrbM6kK/cuchGAcUICEhQb/++qu2b9+uc+fO6ebNm/Lw8FDNmjXVqVMnDR06NMey6VtlZGRo1apVWr9+vZHOwsnJSZUrV86xBL1jx44qV66cpJzLnE1mzpyZY/8yk6LsRxMfH6+tW7cqODhYJ0+e1JUrV5SUlCRPT0/5+vqqdevWeuaZZ1SrVi2r60xKSlJgYKB27Nih06dPKzo6WpJUrVo1NWzYUB07dlTv3r3z/GBS3OttYe7cuTkCcQsXLjS+5m5ubpozZ45eeeUVBQcHa9u2bRo/fry++uoru7UHAGyhNPZj5saOHastW7YoMzNTX3zxhbp27SoXF5di1QkABQkMDJSUPZjUs2dPrVq1SmFhYYUeGLIXS6uoBwwYoFdeeUX//Oc/dfHiRcXGxmr27Nn673//m2c9f/31l1588UVFRkZKkpo3b67Jkyerbt26ucqOHz9eixYt0qeffqq0tDTNnz9f5cuX16uvvppn/dHR0XrhhRd09epVSdmpnD788MM8VxlMmDBBR48e1RdffKHff/89369BQYKCgnTjxg1J2V+b/DiynSa2Whlv62fXFs9as2bN5O/vr8aNG6tx48aqWbNmjhR0hbV48WIjeNa4cWN999138vLyMs7/85//1KhRo7Rr1y6dP39eX3/9tSZMmGD3ulxcXNS3b1/NmTNHGzZs0NWrVwtclWdLZIDB7Ya+9O7pS3/88UcjEOfr66t58+bluYorKytLhw4d0s8//yxnZ+cc5wYNGmSkxFy+fLnVz8nVq1e1d+9eSdkTPh599FGrrrMle2R1oV+58zgXXAS4e23fvl3du3fX5MmTtXv3bkVGRiotLU0xMTE6fvy4Zs2apW7dumnLli0Wr79x44aGDBmiCRMmaNu2bQoPD1dqaqpSUlIUHh6ukydPasmSJRozZozNPqQVJDU1VW3bttWbb76pZcuW6dSpU4qLi1N6erpiYmJ08uRJfffdd3r88ceN5d8F2bFjh7p166ZJkybpt99+U3h4uFJSUpSSkqIrV65o06ZN+ve//62PPvrILtfbSqdOnVSpUiX5+PhowYIF8vPzy3He3d1dc+bMUatWreTq6qpevXrZtT0AUFylsR+7Vb169dS/f39J0oULF7RixQqHtAPA3SM0NFT79++XlJ3m6MUXXzTOmfa9uV1VrVo1R6Bg69at+ZafMGGCMXjYokULfffddxYHDyXJ2dlZzz33nKZOnWrM4P/666916NChPOt/++23jcHDFi1a6Keffiow3VezZs00f/58TZw4sVhptRYvXixJqlWrVoHv6ch22lJJPruFedZGjhyp8ePHq2fPnoXau86S9PR0zZkzR1L2/lOffPJJjuCZJJUtW1affvqpkfps0aJFxmRQe9VlYko5l5GRoV9++aWId1l4t2aAMa2CqVGjhjGYbcoAYym9HWBr9KV3V1+6atUq4/iDDz7IN52ik5OTHnroIX322WfGZE+Tfv36Ge3duHGj4uPjrWrn8uXLjVV2ffv2dUhwqEaNGurevbskGVldbIF+5c7CyjggDxs2bNDrr7+ujIwMubi46JFHHlHbtm11zz33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\n",
      "text/plain": [
       "<Figure size 1080x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 291,
       "width": 881
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_style(\"whitegrid\")\n",
    "fig, axes = plt.subplots(1, 4, figsize=(15, 4))\n",
    "metrices = ['Test acc', 'Test nll', 'AUROC (CIFAR100)', 'AUROC (SVHN)']\n",
    "metrices = ood_table.columns[1:]\n",
    "for i, m in enumerate(metrices):\n",
    "    sns.barplot(x='Method', y=m, data=ood_table, ax=axes[i],\n",
    "               palette=pallete,edgecolor = \"black\",\n",
    "               hue_order=['HMC', 'ShiftMatch'])\n",
    "    axes[i].set_ylabel('')\n",
    "    if 'nll' in m:\n",
    "        m = r'Test NLL $\\downarrow$'\n",
    "    axes[i].set_xlabel(m, fontsize=15)\n",
    "    axes[i].set_xticks([])\n",
    "    \n",
    "patches = [\n",
    "    matplotlib.patches.Patch(color=pallete[i], label=t)\n",
    "    for i,t in enumerate(ood_table['Method'])\n",
    "]\n",
    "fig.legend(handles=patches, loc=\"lower center\", ncol=4,\n",
    "          bbox_to_anchor=(0.5, -0.1)) \n",
    "# ax = axes[-1]\n",
    "# ax.legend()\n",
    "# handles = ax.get_legend_handles_labels()\n",
    "# ax.get_legend().remove()\n",
    "# # ax.grid(True)\n",
    "# ax.set_ylabel('Log-Likelihood', fontsize=16)\n",
    "ax.tick_params(axis='both', which='major', labelsize=8)\n",
    "# ax.set_xlabel('Corruption Intensity', fontsize=16)\n",
    "# figlegend = plt.figure(figsize=(2,2))\n",
    "# legend = fig.legend(*handles, \n",
    "# #            loc ='upper left',\n",
    "#            loc ='lower center',\n",
    "#            bbox_to_anchor=(0.5, -0.4),\n",
    "#            fontsize=12,\n",
    "#            ncol=6\n",
    "#           )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 244,
   "id": "6c067d02",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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nj1bS5cuzfNeTEyMVqxYodWrV2vu3LkaNGiQU9t4//339a9//UsZGRl53j979qzOnj2rLVu26O6771aDBg2c2g4AAEBl5LJwuGjRIhMMe/furaefflr16tVTVFSU5s2bpxMnTuill15Sw4YN1a5duxJt480339TChQslSXfccYcee+wxtWrVSu7u7oqJidGPP/6o0NBQV+0SAABApeOScJiQkKD3339fktS1a1e9++67slgs5v/btGmjAQMGKC4uTvPmzVNISIjD29i5c6cJhk888YSmTp2aZ3lAQID+/Oc/a+TIkU7uDQAAQOXlkhtSwsLClJKSIkl67rnnTDC08fPz05gxYyRJhw4dUlRUlMPbePXVVyVJrVu31vPPP+9kiwEAAFAQl4TDLVu2SJIaN26sVq1aFVimb9+++crba//+/Tp58qQk6fHHH5ebGzdZAwAAlAaXpKzIyEhJ0s0331xombp16yowMFCSFBER4VD93333nSTJzc1NPXr0MO9brVZlZmY62lwAAAAUwulrDmNjY80p5YYNGxZZtkGDBoqNjdXPP//s0DaOHDkiSWrSpIl8fX311VdfadmyZTp27JgyMzNVq1Ytde7cWY8//rjatGlTsh0BAACA8+Hw4sWL5nWtWrWKLGtbnpiY6NA2fvnlF0lSYGCgnn32Wa1fvz7P8t9++01r167VunXr9MILL5TqTSnJyck6cOBAqdWPssNxrJwq+3GnD7s+cAwrr7I49k6fVk5NTTWvq1SpUmRZ23LbSKO9kpOTJeVce7h+/Xr96U9/0sKFC/XDDz9o//79WrBggerVq6fs7Gy99tpr+vbbbx3cCwAAAEguGDm0Wq2lUja37OxsSVJGRoYCAwO1ZMkS+fn5meV9+/ZVq1atdN999yk1NVXz589Xt27dSrSt4vj6+io4OLhU6kbZat++fXk3AeXAkeN+/Phx8+X0ekEfdn2g/6q87D32zvRfTo8c+vj4mNdpaWlFlk1PT8+3jj28vb3N65EjR+YJhjaNGjXS/fffLynnBxIdHe3QNgAAAOCCcFizZk3zOj4+vsiytuUFhTt7t1FUYs69zDb1DQAAAOzndDgMDAw0I3vFjdadO3dOktS0aVOHttG8eXPzunr16oWWq1Gjhnl9vZ0KAgAAKAsumeewdevWkqTDhw8XWiY2NlaxsbF5yturbdu25nVR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oIJz+aNGevTooR49eji0ztChQzV06NASb3Px4sUlXhcAAAC/c8k1hwAAALg+EA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgEA4BAABgeLi6wm3btikkJEQRERFKSkpSQECAunTpopEjR6pFixYlqtNqterAgQPavn27Dhw4oFOnTunSpUuqUqWKGjRooNtvv12PPPKIGjZs6OK9AQAAqFxcGg5nz56tpUuX5nkvJiZGK1as0OrVqzV37lwNGjTI4Xqffvppbd26Nd/7GRkZOnbsmI4dO6YvvvhCL7/8sh544IEStx8AAKCyc1k4XLRokQmGvXv31tNPP6169eopKipK8+bN04kTJ/TSSy+pYcOGateunUN1p6SkSJI6dOigfv36qUOHDqpTp45SUlK0Y8cO/eMf/9DFixc1ffp0BQQEqFu3bq7aLQAAgErFJeEwISFB77//viSpa9euevfdd2WxWMz/t2nTRgMGDFBcXJzmzZunkJAQh+rv0qWLXnzxRbVq1SrP+zVr1tSwYcPUqVMnDR06VKmpqXrzzTcJhwAAACXkkhtSwsLCzOjec889Z4KhjZ+fn8aMGSNJOnTokKKiohyqf9y4cfmCYW5NmzbV/fffL0n63//+p19++cWh+gEAAJDDJeFwy5YtkqTGjRsXGuL69u2br7wr3XjjjeZ1bGysy+sHAACoDFwSDiMjIyVJN998c6Fl6tatq8DAQElSRESEKzabx2+//WZeV6tWzeX1AwAAVAZOh8PY2FhzSrm4qWQaNGggSfr555+d3WweVqtV4eHhknJOYTdt2tSl9QMAAFQWTt+QcvHiRfO6Vq1aRZa1LU9MTHR2s3msXLlSx48flyQ99NBDcnd3d2n9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zp07Vb169SL712vZ2xe3bt1aX331VaG/q88//7zWrFmjIUOG6PXXXzfv078Uj3DopNwd0K5du3T+/HnVrVu3TLbt6empGjVqSMr54F28eFEnT57UyZMntWLFCr355pu69957i6xjzZo1mj17ti5duiQp55emWrVqunjxouLj43Xw4EEtWrRIM2bM0MCBA4usa8uWLZoxY4bi4uLMe97e3rJYLIqJiVFMTIw2btyot956S2+88YZdocImOztb77zzjiwWi55++ulyaYOU92dekOIe21jSz4szx3r37t3mj3NJHDt2TCNHjjSB0tfXVxcvXtTWrVu1bds2TZ48WU8++aTL1x84cKDee+89ffnll3r88cfVsGHDEu9DcaxWq1555RWFhIRIyplQf9asWRW+A/8joI/8XXn2kQkJCRo7dqwiIiLMe1WqVJHVatXPP/+sU6dO6dtvv1W1atW0f/9+U2bIkCFatWqVfvrpJx05ckRt27Ytti2rVq2SJPXq1UvVq1e3ex8cFRkZqU2bNumee+5xeF36l6K55G7lyurixYv69ttvVbVqVQ0YMEDZ2dlavXp1mW2/Xbt22rlzp3bu3Knvv/9ehw8f1ieffKKgoCBlZGTopZdeUkJCQqHrh4SEaMqUKbp06ZJat26tjz/+WD/++KP27t2rw4cPa+HChWrbtq0uXbqkKVOmmA92QUJDQ/V///d/iouLU9OmTfXGG29o9+7dOnTokA4ePKj9+/frn//8pzp27KgLFy7k6XzssX37dv3vf/9T+/btC/22X9ptkPL+zAv695e//KXQdZ35vDh7rGvVqqVu3bpp/Pjx+vvf/273/l69elXjxo1TYmKiWrVqpbVr1+rAgQPat2+fRo8ebaaRss0W4Mr1PTw8NGTIEGVkZGjp0qV2t9lRVqtVM2fOzPP5Xr58uWbOnJlvWi44hj7yd+XdR06ZMkURERHy8fHRlClTtGPHDh0+fFj79+/X/v379dlnn+mRRx7JF+Y6deqkoKAgSVJYWFix7Th16pR5IMaQIUMc2oeS+Oc//6ns7GyH16N/KRrh0Alr165VRkaGevXqpWHDhkmSXaceS4unp6fuuusuvfXWW5Kk1NRUbdy4scCyUVFRmjNnjqxWq3r16qXly5erW7du8vLyMnXdeeedCgkJ0d133y2r1ao5c+bo6NGj+eo6duyYZs6c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e/a8bp992mzyuvJuQqk59Xa/Ut/G6dOnFRISoj179ig6OlpXr15V9erVVatWLTVs2FAdO3ZUx44dddNNN+W5+aBnz56KiYnR+PHjNWHChBJtOzg4p6967bXXNHTo0HzLrVar/vvf/yo0NFQnT55UcnKyrFarevXqpQ8++MDu7ezZs0cjRoww/9+2bVutWLGi2PUmT56sr7/+2vx/Ye2s6Gz9UVBQkLZs2VLezYETCIfAdWTt2rV6/vnni5yGyBbu7BUfH6+ZM2dq06ZN+ZZlZGQoOTlZp06d0urVq1WnTh29+OKL6tev9MMG/jg+//xzvfXWW8rIyMjzfnx8vOLj43XixAlt3rxZkrRr1y75+/uXafvefPNNLVq0qNDlw4cP1969ezVkyBC9/vrrdtd75MgRnTp1Ss2aNSu0THJystn30pT7S+bx46X35RfXB8IhcJ3w9fVVbGysdu/erdtvv73QcqtWrTLlk5OTi6zzzJkzGj16tM6dOydJateune6//37deuut8vf315UrV3Tu3Dl99913+uqrr3ThwgUtW7aMcAgjLCxMr732miQpKChII0aMUMeOHVW3bl1lZGQoOjpa+/fvV3h4uCIjI8u8fSkpKfrPf/4jSbrnnns0adIk1alTRxaLxakHAdh+v8LCwjRp0qRCy23YsEFXr1616/cRKCuEQ+A60adPH3311VcKCwsrNBympqaaEcC+ffsWecrr6tWrGj9+vM6dOyc3NzdNnz5djz76aJ4yNWvWVP369dWxY0c9/fTTeu+998rlDzwqrgULFkiSGjRooNDQUNWoUSPP8sDAQHXo0EF//etf9eOPP8rb29vlbShqpOynn34yI5rjxo0rcpTPEbbfxzVr1ujZZ58tdJ6+sLAwScX/PgJliRtSgOvEfffdJ0kKDw/XlStXCiwTHh6u1NRUNWjQQLfeemuR9X3yySc6ceKEJOmZZ57JFwyv5ePjo2nTpmnGjBklaD2uR6dPn1ZMTIwk6cEHH8wXDK91yy236IYbbiiLphlXr141r6tVq+ayeu+55x55e3srJiZG+/fvL7DML7/8on379slisWjQoEEu2zbgLEYOgetEx44dFRQUpJiYGIWHh5uwmNvq1asl5QTJop44cPXqVS1ZskRSzojP2LFj7W7HjTfe6GDLcb1KSEgwr318fFxS5+bNm7V06VJFRUUpJSVF9evXV9++fTV27Fj5+voWuE5BN6RcezOXJPXq1SvP/48fPz5PmZUrV2rlypX5yhR0o0zVqlXVu3dvhYWFadWqVbrtttvylVm9erWsVqtuu+02BQUFFbnf2dnZ2rNnjzZv3qwjR44oNjZWv/32m7y9vdWsWTP17NlTjzzySL6fwblz5/Ltl+3nYVPYDSTR0dFasmSJdu3apV9//VVpaWmqU6eOmjZtqnvuuUd9+vRR9erVC23zuXPn9Mknn2j79u26cOGCqlevbkaJW7VqVeT+onwxcghcJywWiwYOHCjp9xCYW2xsrHbt2iVJxY5S7N27V4mJiZKkoUOHyt3d3bWNRaWQe6Rw586dTtf36quvaty4cdq5c6cuXryo9PR0nT59Wh9++KEeffRRpaSkOL0NV7J9Qdu4caPS0tLyLbedUi7oi9y1tmzZolGjRmnx4sX64Ycf9OuvvyojI0NJSUk6dOiQ5s+fr6FDhyo6Otolbf/ss8/Ut29fff755zp+/LguXbqktLQ0RUdH67vvvtP06dMVGhpa6Pp79+7V4MGDFRISopiYGGVkZCg+Pl4bN27UQw89pO+//94l7UTpYOQQuI4MGjRIH374oXbt2qULFy6oTp06ZtmaNWuUnZ2tP//5z2rSpIkOHjxYaD0HDhwwrwsa8QDs0axZM9WtW1fnz5/X1q1b9be//U2jR49W8+bNHa4rLCxM0dHRevDBB/XQQw+pYcOGio+P17///W8tX75cx44d00cffaTJkyfbVd9TTz2l0aNHa//+/XryySclSV9//bXq1atnynh6emr06NEaO3asDhw4oIEDB2rWrFl56vH09Cx0G126dFGdOnV04cIFbd68Oc+NWocPH9apU6dUpUoV9e3bV0lJSUW2193dXR07dlTv3r3VqlUrBQYGytfXVxcuXNCuXbv02Wef6cyZM5o8ebL++9//mvWCgoJ08OBBrVmzRjNnzpSkfL/7185u8Pnnn5u7sps1a6annnpKHTp0UPXq1RUfH68ff/xR69evL3RWhMuXL2vChAmqX7++JkyYoD//+c+yWCzasWOH5s6dq0uXLumll17SN99849RNPyg9HBWgHF29erXY0Y709HS762vevLnatGmjiIgIrV27VqNHjzbLbKMU9lzbZLs7WZLLLtBH5WOxWDR16lQT2FasWKEVK1aofv36atu2rdq0aaMOHTrolltuKXZ0Ojo6Ws8++6yefvpp856fn59mz56tCxcuaOvWrQoNDbU7HHp5ecnLyyvPNY433HBDvtPfXl5epm0eHh4OnR53c3PTgAED9Omnn2r16tV5wqHt97FHjx6qVq1aseGwR48e6tGjR773a9asqeDgYPXr108DBgzQ4cOHtWvXLnXp0kVSzjHw8fHJM/9oUfvwyy+/6K233pKUMzvBp59+mucmoerVq6tp06YaPHiwMjMzC6zj0qVLuummm/TFF1/kWXfw4MHy9vbWhAkT9Ouvv+r777/XXXfdVeR+o3wQDoFyZBuxcKXBgwcrIiJCYWFhJhwePXpUJ06ckKenp/r3719sHbn/UBV1TRFQnP79+8tisejVV19VXFycpJwA8ssvv2jjxo2SpDp16mjEiBEaOXJkoZOo16tXr9Dfl/vvv19bt25VXFycfv311zyjf+Vt8ODB+vTTT7V9+3YlJCTI399fGRkZZtLrwYMHu2Q7derUUZcuXbRhwwZ9//33Jhw6atmyZcrIyJCbm5vmzZtX5N3jRY36Pf/88wWue/fdd6tGjRpKSkrSkSNHCIcVFNccAteZ/v37y8PDQ8eOHTNTeNjmNuzWrZv8/PzKr3GolPr166fNmzfr7bff1qBBg9SwYcM8yy9cuKC33npLo0aNKvRO+9tvv73Q0cWmTZua17YAWlEEBwerZcuWyszMNIHwu+++08WLF+Xv768777zT7royMjL03//+V08++aTuuusu3XzzzQoODjb/NmzYICnnLvGSsl2X3L59ezVu3LhEdXh5eRX65Cc3Nzc1atRIkvTbb7+VrJEodYwcAuXI0cfn2cP2B2fr1q1atWqVnn/+efNHyZ4L36W8NxJcunRJtWvXtnv7QEGqVKmi/v37m5HrpKQk7d+/X+vWrdP69euVlZWlAwcOaP78+Zo+fXq+9XNfP3ut3KeGc09NU1Hcd999OnbsmFatWqXhw4ebU8q2L3L2iIuL0+jRo830UkW5fPlyidtqu6GlZcuWJa7D39+/yGsxq1atKqliHivkYOQQuA7ZQuDatWu1fft2xcXFqUaNGurevbtd6+d+zvKpU6dKo4mo5GrUqKFevXpp/vz5+te//mWmVvrvf/9b4HW29t4xb7VaXdpOVxg4cKDc3d0VERGhQ4cOaevWrZLs/7ImSVOnTjWXhowaNUqff/65tmzZor179+rgwYM6ePCgBgwYIEnKysoqcVttT2lxZuqhP/KxQg7CIXAd6tmzp6pVq6YLFy5ozpw5kqR777230Ou5rpV7gux9+/aVShsBm27dupkvLlevXr3uvpAEBASYawCnTJmi9PR0NWvWTG3btrVr/bNnz5qpX6ZPn64XX3xRXbp0UVBQkGrUqCEfHx/5+PgUekreEbZQWNGmBULZIhwC1yHb9BjS76eJHBml6Nixo7k2MTQ01KmRCMAeuae3cUXIqWhsv38l+X08duyYeV3UDWX2nHIuju16wNzbROVDOASuU7nvgmzUqFGxj8vLrWrVqnrkkUck/f6UA3udPHnS7rKAzfnz583roq4vLA+26wKd+ZLUu3dvc/euo4/Ly32avbA2/PDDD0VOgJ372sai9uOOO+6QlDPXqasm1MYfD+EQuE61b99e69at07p168yj8Bzx5JNPmkfhLViwQF988UWR5VNTUzV//nzNnj27RO3F9efs2bN65513zNN2CnP06FFt2rRJktSkSZNiHyVX1myj6BcuXChxHVWrVtXatWu1bt06bdy4UfXr17d73dzXANuuV8wtJSUl3+Tc18o9S0FR+zFs2DB5enoqOztb06ZNK3IUt7B5DvHHRzgErlMWi0XNmzdX8+bNFRgY6PD6VatW1XvvvaegoCBlZ2dr1qxZevjhh/XVV1/p1KlTSkxM1Pnz57V//3698847uueee/Txxx9zkTmMq1ev6sMPP9Rdd92lyZMna9WqVTp58qQuXryohIQEHTlyRAsWLNCjjz5qHi/37LPPlm+jC9C6dWtJOaNp69evV2JiojIzM5WZmans7Gy76wkKClLz5s0dniKmbdu2JiDOmTNHS5cuVXR0tOLj47V582YNGzZMx44dyzOlz7VatWplnmjyz3/+UzExMUpPT1dmZmaekcR69eppypQpZn8feOABrVq1SjExMbp06ZLOnDmjtWvX6umnny72CyP+uJjKBkChmjZtqi+//FIvv/yytmzZYu6KLEz9+vU1fPjwMmwhKjIvLy95enoqLS1NX3/9tZlSqSA33HCDpk2bpnvvvbcMW2if++67Tx9//LGSkpLyhdfx48drwoQJpbp9d3d3zZ07V08++aSSk5Pzjc67ublp2rRpOnbsmH7++ecC66hdu7b69euntWvXKjQ0NM9zkYOCgrRlyxbz/yNHjlR6erreeecdnTx5UtOmTSuwzuKm4cIfF+EQQJFq166tf/3rXzpy5IjWrVunPXv26Pz580pKSlKVKlUUGBioNm3aqHfv3urRo0eR85uhcmnSpIl2796t7777Tnv37tXRo0d19uxZXb58WRaLRdWrV1ezZs3UuXNnDR06tEI92SS3gIAAhYSE6MMPP9S+ffsUFxenjIyMMm1D586d9eWXX+qDDz7Q3r17lZycrJo1a6pdu3YaPny4brvtNr3wwgtF1vHaa6/pxhtv1MaNG3XmzBlduXKl0JH+sWPHqlevXlqyZIl27dql8+fPy2q1qk6dOmrSpInuuece9enTpzR2FRWAxco5IFzj6NGjkqSbbrqpnFsCAEAO/jaVHa45BAAAgEE4BAAAgEE4BAAAgEE4BAAAgEE4BAAAgEE4BAAAgEE4BAAAgEE4BAAAgEE4BAAAFRrP6yhbhEPkY7FYJMmhB8oDAFBabOHQ9vcJpYtwiHzc3d0lSZmZmeXcEgAAZJ5lbfv7hNJFOEQ+3t7ekqTk5ORybgkAAFJKSoqk3/8+oXQRDpGPj4+PJOnixYvKysoq59YAACqzrKwsXbx4UdLvf59QugiHyKdatWry8vJSenq6oqOjdfnyZWVnZ3NBMACgTFitVmVnZ+vy5cuKjo5Wenq6vLy8VK1atfJuWqVgsfIXHwVIT0/X6dOnGTkEAJQ7d3d3NWnSRF5eXuXdlEqBcIhCZWZmKikpSUlJSUpPT2fkEABQZiwWi7y8vFSjRg3VqFFDHh4e5d2kSoNwCAAAAINrDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGAQDgEAAGD8P+FMLkMcbxB7AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 360x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 223,
       "width": 323
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_style(\"whitegrid\")\n",
    "fig, axes = plt.subplots(1, 2, figsize=(5, 3), sharey='all')\n",
    "metrices = ['Test acc', 'Test nll', 'AUROC (CIFAR100)', 'AUROC (SVHN)']\n",
    "metrices = ood_table.columns[1:]\n",
    "for i, m in enumerate(metrices):\n",
    "    sns.barplot(x='Method', y=m, data=ood_table, ax=axes[i],\n",
    "               palette=pallete,edgecolor = \"black\",\n",
    "               hue_order=['HMC', 'ShiftMatch'])\n",
    "    axes[i].set_ylabel('')\n",
    "    if 'nll' in m:\n",
    "        m = r'Test log-likelihood $\\uparrow$'\n",
    "    axes[i].set_xlabel(m, fontsize=12)\n",
    "    axes[i].set_xticks([])\n",
    "    \n",
    "patches = [\n",
    "    matplotlib.patches.Patch(color=pallete[i], label=t)\n",
    "    for i,t in enumerate(ood_table['Method'])\n",
    "]\n",
    "fig.legend(handles=patches, loc=\"lower center\", ncol=4,\n",
    "          bbox_to_anchor=(0.5, -0.12)) \n",
    "# ax = axes[-1]\n",
    "# ax.legend()\n",
    "# handles = ax.get_legend_handles_labels()\n",
    "# ax.get_legend().remove()\n",
    "# # ax.grid(True)\n",
    "# ax.set_ylabel('Log-Likelihood', fontsize=16)\n",
    "ax.tick_params(axis='both', which='major', labelsize=8)\n",
    "# ax.set_xlabel('Corruption Intensity', fontsize=16)\n",
    "# figlegend = plt.figure(figsize=(2,2))\n",
    "# legend = fig.legend(*handles, \n",
    "# #            loc ='upper left',\n",
    "#            loc ='lower center',\n",
    "#            bbox_to_anchor=(0.5, -0.4),\n",
    "#            fontsize=12,\n",
    "#            ncol=6\n",
    "#           )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "be426f12",
   "metadata": {},
   "outputs": [],
   "source": [
    "# base_dir = '/home/ooo123_321321/shift_match_log'\n",
    "base_dir = '/home/ooo123/data/shift_match_log'\n",
    "ckpts = os.listdir(base_dir)\n",
    "ctypes = ['cifar10', 'cifar100'\n",
    "          , 'svhn_cropped']\n",
    "logs_shift_match = []\n",
    "for ctype in ctypes:\n",
    "    for ckpt in ckpts:\n",
    "#         if 'channel_wise_sep_cov.pkl' in ckpt:\n",
    "        if 'spatial_sep_cov.pkl' in ckpt:\n",
    "            if (ctype + '_') in ckpt:\n",
    "                logs_shift_match.append(load_checkpoint(os.path.join(base_dir, ckpt)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "4c4ea4af",
   "metadata": {},
   "outputs": [],
   "source": [
    "# base_dir = '/home/ooo123_321321/shift_match_log'\n",
    "base_dir = '/home/ooo123/data/shift_match_log'\n",
    "ckpts = os.listdir(base_dir)\n",
    "ctypes = ['cifar10', 'cifar100', 'svhn_cropped']\n",
    "logs_origin = []\n",
    "for ctype in ctypes:\n",
    "    for ckpt in ckpts:\n",
    "        if 'None.pkl' in ckpt:\n",
    "            if (ctype + '_') in ckpt:\n",
    "                logs_origin.append(load_checkpoint(os.path.join(base_dir, ckpt)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "eae630dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.867993625"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p = logs_shift_match[0]['prediction']\n",
    "entropy_in = - (p * np.log(p)).sum(-1)\n",
    "p = logs_shift_match[1]['prediction']\n",
    "entropy_out = - (p * np.log(p)).sum(-1)\n",
    "y = np.concatenate([np.zeros(10000,), np.ones(10000,)])\n",
    "score = np.concatenate([entropy_in, entropy_out])\n",
    "roc_auc_score(\n",
    "    y, score\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "ad56f908",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.50505066"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "entropy_in.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "a5c14128",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.2387452"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "entropy_out.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "f6ff2289",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.86406738"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p = logs_origin[0]['prediction']\n",
    "entropy_in = - (p * np.log(p)).sum(-1)\n",
    "p = logs_origin[1]['prediction']\n",
    "entropy_out = - (p * np.log(p)).sum(-1)\n",
    "y = np.concatenate([np.zeros(10000,), np.ones(10000,)])\n",
    "score = np.concatenate([entropy_in, entropy_out[:10000]])\n",
    "roc_auc_score(\n",
    "    y, score\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "13071d55",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-52-1427e387d3db>:20: MatplotlibDeprecationWarning: savefig() got unexpected keyword argument \"layout\" which is no longer supported as of 3.3 and will become an error two minor releases later\n",
      "  fig.savefig('pred_entropy.pdf', layout='tight')\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "datasets = ['CIFAR10', 'CIFAR100', 'SVHN']\n",
    "fig, axes = plt.subplots(1,2, figsize=(10,4))\n",
    "axes = axes[::-1]\n",
    "for i, l in enumerate(logs_shift_match):\n",
    "    p = l['prediction']\n",
    "    entropy = - (p * np.log(p)).sum(-1)\n",
    "    sns.kdeplot(entropy, label=datasets[i], ax=axes[0])\n",
    "for i, l in enumerate(logs_origin):\n",
    "    p = l['prediction']\n",
    "    entropy = - (p * np.log(p)).sum(-1)\n",
    "    sns.kdeplot(entropy, label=datasets[i], ax=axes[1])\n",
    "axes[0].legend()\n",
    "axes[1].legend()\n",
    "axes[0].set_title('ShiftMatch',fontsize=16)\n",
    "axes[1].set_title('HMC',fontsize=16)\n",
    "axes[0].set_xlabel('Entropy values',fontsize=14)\n",
    "axes[1].set_xlabel('Entropy values',fontsize=14)\n",
    "axes[0].set_ylabel('',fontsize=14)\n",
    "axes[1].set_ylabel('',fontsize=14)\n",
    "fig.savefig('pred_entropy.pdf', layout='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e47d3992",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for l in logs_origin:\n",
    "    p = l['prediction']\n",
    "    entropy = - (p * np.log(p)).sum(-1)\n",
    "    sns.kdeplot(entropy)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
