{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "428503c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "rng = np.random.default_rng(42)\n",
    "\n",
    "import sys\n",
    "\n",
    "sys.path.insert(0, \"../\")\n",
    "\n",
    "import pandas as pd\n",
    "from mdu.unc.entropic_ot import EntropicOTOrdering\n",
    "from mdu.unc.constants import OTTarget, ScalingType, SamplingMethod\n",
    "from mdu.unc.general_metrics.mahalanobis import MahalanobisDistance\n",
    "\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import roc_auc_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "885d0bbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_gaussian_class(mean, cov, n):\n",
    "    return rng.multivariate_normal(mean, cov, n)\n",
    "\n",
    "\n",
    "def msp_uncertainty(probs):\n",
    "    return 1 - probs.max(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3ee1765",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2aabcc9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_train = 1000\n",
    "n_test = 3000\n",
    "n_cal = 250\n",
    "\n",
    "mu0 = np.array([-0.8, 0.0])\n",
    "mu1 = np.array([0.8, 0.2])\n",
    "cov = np.array([[1.0, 0.6], [0.6, 1.2]])  # correlated, overlapping\n",
    "\n",
    "X0_tr = make_gaussian_class(mu0, cov, n_train // 2)\n",
    "X1_tr = make_gaussian_class(mu1, cov, n_train // 2)\n",
    "y_tr = np.concatenate([np.zeros(len(X0_tr), dtype=int), np.ones(len(X1_tr), dtype=int)])\n",
    "X_tr = np.vstack([X0_tr, X1_tr])\n",
    "\n",
    "X0_cal = make_gaussian_class(mu0, cov, n_cal // 2)\n",
    "X1_cal = make_gaussian_class(mu1, cov, n_cal // 2)\n",
    "y_cal = np.concatenate(\n",
    "    [np.zeros(len(X0_cal), dtype=int), np.ones(len(X1_cal), dtype=int)]\n",
    ")\n",
    "X_cal = np.vstack([X0_cal, X1_cal])\n",
    "\n",
    "X0_te = make_gaussian_class(mu0, cov, n_test // 2)\n",
    "X1_te = make_gaussian_class(mu1, cov, n_test // 2)\n",
    "y_te = np.concatenate([np.zeros(len(X0_te), dtype=int), np.ones(len(X1_te), dtype=int)])\n",
    "X_te = np.vstack([X0_te, X1_te])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5fcf2a8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "lr = LogisticRegression()\n",
    "params = lr.fit(X_tr, y_tr)\n",
    "probs_te = lr.predict_proba(X_te)\n",
    "probs_cal = lr.predict_proba(X_cal)\n",
    "\n",
    "yhat_te = probs_te.argmax(axis=1)\n",
    "miscl_labels = (yhat_te != y_te).astype(int)  # positives = misclassified"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "175cf583",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_ood = 3000\n",
    "ood_ring = make_gaussian_class(mean=np.array([0.0, 6.0]), cov=cov, n=n_ood)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "76f17591",
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute classifier probs on OOD\n",
    "probs_ood = lr.predict_proba(ood_ring)\n",
    "\n",
    "# Concatenate for OOD detection evaluation against an ID \"background\" sample\n",
    "# Use a balanced ID sample from test set\n",
    "idx_bg = rng.choice(len(X_te), size=n_ood, replace=False)\n",
    "X_bg = X_te[idx_bg]\n",
    "probs_bg = probs_te[idx_bg]\n",
    "\n",
    "ood_labels = np.concatenate([np.ones(n_ood, dtype=int), np.zeros(n_ood, dtype=int)])\n",
    "X_mix = np.vstack([ood_ring, X_bg])\n",
    "probs_mix = np.vstack([probs_ood, probs_bg])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "153f1800",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a73a4376",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Uncertainty measures\n",
    "u1_cal = msp_uncertainty(probs_cal)\n",
    "u1_te = msp_uncertainty(probs_te)\n",
    "u1_mix = msp_uncertainty(probs_mix)\n",
    "\n",
    "mah = MahalanobisDistance()\n",
    "mah.fit(X_cal[None], y_cal)\n",
    "\n",
    "u2_cal = mah.predict(X_cal[None])\n",
    "u2_te = mah.predict(X_te[None])\n",
    "u2_mix = mah.predict(X_mix[None])\n",
    "\n",
    "# Evaluate AUCs\n",
    "auc_miscl_u1 = roc_auc_score(y_score=u1_te, y_true=miscl_labels)\n",
    "auc_miscl_u2 = roc_auc_score(y_score=u2_te, y_true=miscl_labels)\n",
    "\n",
    "auc_ood_u1 = roc_auc_score(y_score=u1_mix, y_true=ood_labels)\n",
    "auc_ood_u2 = roc_auc_score(y_score=u2_mix, y_true=ood_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "02721f0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# 3) Composite via rank-max (percentile calibration on ID train)\n",
    "def to_percentiles(ref, x):\n",
    "    ref_sorted = np.sort(ref)\n",
    "    # percentile of x within ref (empirical CDF)\n",
    "    ranks = np.searchsorted(ref_sorted, x, side=\"right\")\n",
    "    return ranks / len(ref_sorted)\n",
    "\n",
    "\n",
    "target = OTTarget.BETA\n",
    "sampling_method = SamplingMethod.GRID\n",
    "scaling_type = ScalingType.FEATURE_WISE\n",
    "grid_size = 5\n",
    "eps = 0.5\n",
    "n_targets_multiplier = 1\n",
    "max_iters = 1000\n",
    "random_state = 42\n",
    "tol = 1e-6\n",
    "\n",
    "\n",
    "multi_dim_uncertainty = EntropicOTOrdering(\n",
    "    target=target,\n",
    "    sampling_method=sampling_method,\n",
    "    scaling_type=scaling_type,\n",
    "    grid_size=grid_size,\n",
    "    target_params={},\n",
    "    eps=eps,\n",
    "    n_targets_multiplier=n_targets_multiplier,\n",
    "    max_iters=max_iters,\n",
    "    random_state=random_state,\n",
    "    tol=tol,\n",
    ")\n",
    "\n",
    "scores_calib = np.column_stack([u1_cal, u2_cal])\n",
    "multi_dim_uncertainty.fit(\n",
    "    scores_cal=scores_calib,\n",
    ")\n",
    "scores_test = np.column_stack([u1_mix, u2_mix])\n",
    "ood_scores = multi_dim_uncertainty.predict(scores_test)\n",
    "\n",
    "scores_test = np.column_stack([u1_te, u2_te])\n",
    "te_scores = multi_dim_uncertainty.predict(scores_test)\n",
    "\n",
    "auc_multi_mis = roc_auc_score(y_score=te_scores, y_true=miscl_labels)\n",
    "auc_multi_ood = roc_auc_score(y_score=ood_scores, y_true=ood_labels)\n",
    "\n",
    "\n",
    "# Summary table\n",
    "summary = pd.DataFrame(\n",
    "    {\n",
    "        \"Task\": [\"Misclassification detection\", \"OOD detection\"],\n",
    "        \"AUC: u1 (1-MSP)\": [auc_miscl_u1, auc_ood_u1],\n",
    "        \"AUC: u2 (kNN-dist)\": [auc_miscl_u2, auc_ood_u2],\n",
    "        \"OT-scores\": [auc_multi_mis, auc_multi_ood],\n",
    "    }\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "177f95ae",
   "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>Task</th>\n",
       "      <th>AUC: u1 (1-MSP)</th>\n",
       "      <th>AUC: u2 (kNN-dist)</th>\n",
       "      <th>OT-scores</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Misclassification detection</td>\n",
       "      <td>0.765928</td>\n",
       "      <td>0.444899</td>\n",
       "      <td>0.710329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>OOD detection</td>\n",
       "      <td>0.098877</td>\n",
       "      <td>0.999980</td>\n",
       "      <td>0.999883</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Task  AUC: u1 (1-MSP)  AUC: u2 (kNN-dist)  OT-scores\n",
       "0  Misclassification detection         0.765928            0.444899   0.710329\n",
       "1                OOD detection         0.098877            0.999980   0.999883"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "47434c1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrr}\n",
      "\\toprule\n",
      " & Task & AUC: u1 (1-MSP) & AUC: u2 (kNN-dist) & OT-scores \\\\\n",
      "\\midrule\n",
      "0 & Misclassification detection & 0.766 & 0.445 & 0.710 \\\\\n",
      "1 & OOD detection & 0.099 & 1.000 & 1.000 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(summary.to_latex(float_format=\"%.3f\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80c51bc7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "38e27782",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "\n",
    "\n",
    "def pretty_matplotlib_config(\n",
    "    fontsize=15,\n",
    "    legend_fontsize=None,\n",
    "    legend_title_fontsize=None,\n",
    "    axes_titlesize=None,\n",
    "    axes_labelsize=None,\n",
    "    tick_labelsize=None,\n",
    "    suptitle_size=None,\n",
    "):\n",
    "    rc = matplotlib.rcParams\n",
    "    rc[\"pdf.fonttype\"] = 42\n",
    "    rc[\"ps.fonttype\"] = 42\n",
    "    rc[\"text.usetex\"] = True\n",
    "\n",
    "    # Base font\n",
    "    rc[\"font.size\"] = fontsize\n",
    "\n",
    "    # Legend\n",
    "    rc[\"legend.fontsize\"] = (\n",
    "        legend_fontsize if legend_fontsize is not None else 0.8 * fontsize\n",
    "    )\n",
    "    rc[\"legend.title_fontsize\"] = (\n",
    "        legend_title_fontsize\n",
    "        if legend_title_fontsize is not None\n",
    "        else rc[\"legend.fontsize\"]\n",
    "    )\n",
    "\n",
    "    # Axes titles & labels\n",
    "    rc[\"axes.titlesize\"] = (\n",
    "        axes_titlesize if axes_titlesize is not None else 1.1 * fontsize\n",
    "    )\n",
    "    rc[\"axes.labelsize\"] = (\n",
    "        axes_labelsize if axes_labelsize is not None else 0.95 * fontsize\n",
    "    )\n",
    "\n",
    "    # Tick labels\n",
    "    rc[\"xtick.labelsize\"] = (\n",
    "        tick_labelsize if tick_labelsize is not None else 0.85 * fontsize\n",
    "    )\n",
    "    rc[\"ytick.labelsize\"] = (\n",
    "        tick_labelsize if tick_labelsize is not None else 0.85 * fontsize\n",
    "    )\n",
    "\n",
    "    # (optional) Figure suptitle\n",
    "    if suptitle_size is not None:\n",
    "        rc[\"figure.titlesize\"] = suptitle_size  # affects plt.suptitle\n",
    "\n",
    "\n",
    "# example\n",
    "pretty_matplotlib_config(\n",
    "    fontsize=35,\n",
    "    legend_fontsize=30,\n",
    "    axes_titlesize=40,  # title of each axes\n",
    "    axes_labelsize=40,  # x/y labels\n",
    "    tick_labelsize=40,  # tick labels\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "64bdbea1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABYYAAARaCAYAAAD4naaUAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAA5FpJREFUeJzs/W+MI/l93/t+2D07O/LuThd7NrZW1srbRUuIL46OtcUeG7m+OD7xkFZwchM4XrL7SQAjD4a0H8ciPX4kAb6YJWXnYWJy4gQJ7oNMk7YT5M9NRI50bZwEUKZJbaCD2MiK1WNbkrXGqrt6diea3Z3pOg9arKkqks0im2z+e7+AxpI15K9+v6oie/vDH7+/mOu6rgAAAAAAAAAAK2Nt1h0AAAAAAAAAAFwsgmEAAAAAAAAAWDEEwwAAAAAAAACwYgiGAQAAAAAAAGDFEAwDAAAAAAAAwIohGAYAAAAAAACAFUMwDAAAAAAAAAAr5tKsOwAAwDJwHEfValX379+XbduybVuO48g0TZmmKcuylM/nZZrmzPvmOI5s25ZhGNrc3PT6aBiG0um0UqnUhfcR4+HcAgAAABhXzHVdd9adAAAgzHEcxePxkZ/XDcQsy/KCsGmGse12W8ViUc1mM9LjLcvSrVu3lMlkptanrnq9rkqlErlvfplMRrdu3ZJlWVPo2ejq9bqy2Wxgm2VZarVa527btm0lEonAtlKppEKhcK528/m8qtWqdz+Xy6lSqZyrza5lOreILnxNFQoFlUqlGfYIAGYvkUjItm3vfqvV4nccAETEjGEAwFJxHMebNVmv1yVNL4wtFosql8sjPafdbiubzSqTyejOnTsyDGOifZJOj0E2mx0rNOyq1+tqt9vqdDoT7Nn47t6927Ot3W7LcZypHMN5tYznFgAAAMBsEAwDAJZeN4y1LEu1Wu3cM4ht21Y6nQ7MTukyDCMwS9m2bbXb7Z7H1ut1NZtN3bt3b6KzWvrNrPWzLEumaWpzc9PrX/en32PngeM4XsgfVq1Wzz2zd1Es47kFAAAAMDsEwwCAhVEqlZTL5Qb+++HhoTdbuNFoaG9vT47jeP/ebreVSCTUaDTGrrVq27aSyWSgXek0aCuVSgPbbbfbun37diDgdBxHyWRyYl95rFaryufzPdtN01SxWDzz2DmOo729PZVKJS9InEU95H729vYG/tvdu3dXIhhe1nMLAAAAYHbWZt0BAACiMgzjzJ/uIm+ZTEaVSkVHR0eqVCo9pQbS6fRYX8XvBrnhULhUKqnVap0ZNndnK9dqtZ7+JJNJtdvtkfvjNyg4LJVK6nQ6ZwaH0umxzeVy6nQ63qzq69evn6tPk1Kr1bzb4UCz32zsZbPM5xYAAADA7BAMAwCWWi6X08HBQU+gmM1mewLeYW7cuNHznEajMdKM1Uwmo1ar1RMO92s7qna73Tc4bLVaY82mzWQy6nQ6F7JA3jCO4wRC/FQq1TO7elILus2jZT63AAAAAGaLYBgAsPQMw+gJYx3HUbFYjNxGuVzumdU7bkkK0zTVarUC2xzH0c2bN0duS1LfurONRmMp6shWq9XA/Ww223PMB9UfXgbLfG4BAAAAzBbBMABgJRiGoVu3bgW2hUPHQWzb7gmRC4XC2HWKpdNwODzTtV6vjxxy5vP5nlIKlUrlXH2bJ3fv3g3cT6VSSqfTgW3dBf6WzbKfWwBB6XRasVjM+1nG9zVMD9cPAGAcBMMAgJXRrxZrlFrD4VDYNE2VSqWJ9Ccc8o0yi9m27Z5w27KsoTVnF0U48O0eq37B6LKVk1j2cwsAAABg9giGAQAro7tInd+wGTWO4/TM4h0lvB0mHDDbth15Ybx+4fSdO3cm0q95EA57/WUVwjVy9/b2LqRPF2XZzy0AAACA2SMYBgDgDLdv3w7cNwxjorM2LcvqqRcbdTZyeEZpv4XZFlk4kN/Z2fFuhxdkCy9St+iW/dwCAAAAmD2CYQDAyrBtW47jBLaZpnnmc8IB3TS+yh8OOZvNZk8/w/rVRw63s8ja7Xagvq5lWYHZ3stcTmLZzy0AAACA+UAwDABYGf1mlJ61kFe/IDm88Nkk+GfCdg2b/dpoNHq2hcsrLLJwyNsvGA2Pd9SF++bVsp9bAAAAAPOBYBgAsBIcx+mpDZxKpXpqDvuNGiSPq1/t437hoF+4b9Po1yyFawb3C893d3d7ti1DOLzs57ZeryubzSqRSCgWiykejyuRSCibzY5dDiSbzSqdTns//g90HMdRuVxWOp0O7DOZTKpcLg+dnT9t3femZDLZczymdT1P4xzMg1lcB/V6Xel0WslkUvF4XLFYTLFYTIlEQul0WuVyeWgt+0kLH4dB/c5ms0omk0okEpHatW1b5XI5MNZJXKvNZlP5fL7vMTxP22ddD5LGvh6azaZ37Pyvn3w+f+HnetqmdW665vH1M8wi9hkAzuQCADCHjo6OXEmBn0qlMnZ7lmX1tNdqtc58TiqVCjzeNM2x9z9MJpOJvK9Op9MzllKpNLW+XbRGoxEYm2VZAx8bPg6pVGrk/U3reOZyuUCbuVxuZn2ZB7VazTUMo2d84R/TNN1GozFS2+F2j46OXNd13VKpNHR/hmGMvL9JqVQqkfrXvQbC11ShUBhpf5M4B/2u0U6nE2n/4fMR5TXRFX4/7ve6uMjroFAoRDqW/mNaq9UCbUR9br+fs34fmqYZeKxfpVLp6XeU322FQmGir92jo6NIbfrbHvY7O+w814OknrG0Wq2+/y8R/hnluj6PaV0/F3FuJvH68Qtf81H602q13EKhEPg56/ftpPsMAPOCYBgAMJcmFQw3Go2ePxikaGFb+HnjhI5R9fsjbJBarTb0D9hFFg7Jzzrv4cf6//iPap6C4WU9t+FQL8rPKOFK+I/1TqfT99o46ydquDkpowQv3ZAhfBxHCYYneQ7C741RXy/hUM0wjMj9j3K+Luo6GLXNQcdznDaivC/2C4aPjo4GXgNnBcNHR0d9f4ee9RMlDBt33KO8H07ieugGjP3em8/6GfVDm3FM6/qZ9rmZ1OvHb9RguNPp9A15Bz1vGn0GgHlxSQAALBHbtmXbthqNhur1emABs65CoaBCoTC0rcPDw8D9s8pOnNe1a9d6tjmO03ef4X5J0ubm5jS6NRPhr6b2KyPRlc/nex6/t7c3lUUCL8Iyntt0Ot1TnsA0TWUyGe8r7K1WS3t7e4Gvb1erVR0eHqpWq428z2w2632V1zRN5fN5GYYhx3HUaDT6lkvI5/NDS7hMSr1eV7lc7vtvqVRK6XRahmGo0+l472Pdn3FM+hxkMplA/xuNxtD3VMdxer5e3d1mWdaZzw2/xk3THLpwqDSd66Barfb0p3vOun2ybVudTkfNZjNwzpLJ5NA+T4PjOLpx40bfr7cbhjHwWDqOo2Qy2XPdWZal3d1d7xqtVquB6yabzarVap15Xrvnwd9mKpVSIpHw3vMajUbPYpzpdFqdTifS+Q8LXw/d6/+s66FYLKpYLCqbzXrbcrmcksmkHMdRp9Pped1Ip2Uq8vn8WP2ctWmem3l4/di27Z0/v0aj0feanYc+A8BUzTqZBgCgn34zhifxM8qs4/BzpzkDqN9XygfNXOs303DUWbLzKjwrK8os7fCsn7NKT/QzTzOGl+3c9ptlddZswn5f8Y7yuhv09d5Bx3zQbLGLONZHR0d9953JZAbuf9BsxSjHZhrnIFzuJcqfFP4x+Mcf5bUWtYTGRVwHo86W7nQ63us6PBux1WoFfsJt12q1nsd0f0bpY3imcLc8ybDZ0f1mGA/6HTpKOSR/H3O53Jn96HeOMpnMmW13jXM9nDU72jCMgce93+ts2mWApn39TOPcTPL1c1a7gx476P13lDIVk+ozAMwLgmEAwFyadDB8VugSdf/TDIZHKSEQDkmGBRmLJBxERAnyz3s85ikYXqZzG76mDcOI9DX9fqHjsD+u+/2hP+xDhX77uYh6kP3OcZT3ln79Hfa8aZ6D8DEfduz8wZn/dR7lg5zwvgZdD9O+DsK/F0b5ECrK6zhcamPcUOmscDPq78J+H1YO60+4/2eVFigUCpHLt/T7/Rjluf2uh2HnrNVqDTx2w/Z5keWn+pnU9TOtczPN10+UYHhQWZSz3rum/ZoHgHmwJgAAllihUNDR0ZFqtdq5S0GMu2p9FP1KCAwyzZIWs+Q4Ts9Xec8qI9Hl/4pvV/grrotimc7tzZs3A/drtVqkr1WnUimVSqUz24qiUqkM3U/4eI/yOhxX+NrsN95+UqmUUqnUSPua5jkI92VYGQ7/a9v/mm2322e+t4b/3TCMoaUn/CZ5HYRLKmxvb0fuxzy8tnO5XOTfheHzXygUhh73cMmRs459qVSKXGYhk8n0PLZf2YcohpWmsSyrb78KhcLQ/mYymcD9cUu/zNq0zs0sXz+DyqJUKpWe8+a36K95AIiCYBgAsDAymYxqtdrAn341Lm/dujXW/5xHre07Kf2CkUG1Zbs1Qf0uItCatr29vcD9foFNP/0eNywMmlfLcm7r9Xrgmh411CwUCoFz2m63RwqCotagDf+RP80Pf6TeWrlSbwB3llHey6Z9DnZ3dwOPD79+/fzhrmmaPf0469yG/22UMUz6Ogi/Fvf39yP3ZdYsy4r8vhiuz2+aZqTrNHxuxw1v+wmH0q1Wa+Q2ol4P/QLw8PXeTzqdDtxfxPfucUQ9N7N8/dy4caMn5C2VSkPXI1jk1zwAREUwDABYGOl0WplMZuBPv1ku48w0HGSaodH3v//9nm2D/oDtFxgv6swkv3Bokc/nIz83PLP4PAt1zdKynNvznMuuW7duBe6PsgjdWTPA/MJBa7/X4SSFZ9WmUqmRZr+OYtrnIBzQ9ltcruvu3bve7e6MTP+x9//7Wc+VogV0XZO+DsLvye12e+CY582dO3ciPzZ8zKMeRyk4G9xxnIm9f4WP/TjtRh1H+H046iz18POm/UHTvIh6bmb1+kkmkz37iboI8SK/5gEgKoJhAMBSCYch9Xp97P+Jn8QfolH1a3vQ7MB+gfGi/6HSL1QaN4zoWsRZw8tybs8zy3PQc86akRrWb+Z1P4Nm5U9L+LiEZxhOc1+TPgf9wrJBM0T927tj9s/SHfS8fu8Lo4xj0tdBONCWTkOncrk81yGgZVkjfQARPh+jhPHh2deTev+6du3auduIej2ERS2rsKqinptZvH7S6XTPNZjL5SJ/U2NRX/MAMAqCYQDAUun3delxZw1fZDAc/kP8rK+M9/sD//79+5Pu0oXqV3fVcZzIP9vb2z3HrN/X9ufdMpzb8LXc7w/rKMLHYpTZhxcd+EYV7v84YW0UF3UOwoFhv5m/4XC3Gxz6Q/FBs43D47Asa6RxTOM6CM+ilqRisah4PK5EIqF8Pt9TxmPWRrnObNvu6XsymVQsFov0k0wme9qbF+NeDwTDk3ORr59sNtv3vXDUD40X8TUPAKO4NOsOAAAwaZVKJTAzqN1uq16vjzQDVToNLsJ/VDSbzYmHOd1w02/YPlKpVKBvk6zlOIjjOGPVTNzc3Bwa5oQDpWazqXg8PvK+/GzbVrvdntpX9adlFud2ksLX8nkW4DEMI9Be1D+853HRn359n1Y/L+ocZDIZFYtF7/6wcNc/y7hfneHwa/U8ZSS6+5u0QqGgu3fv9h2rbduqVqveB12WZalUKk3tA4Corl+/Hvmxkw63Ri3P0v3wYX9/X51Ox/u9M4mZx/P4vrBIJnFuLur1c/PmzYH7GPX/4xbxNQ8Ao2DGMABg6Zim2bOgiD+8iKrf/9hP42v9/YK/YQFI+CvojuNMPUCsVqtKJBIj/wzrVzfAnYZFLCcxi3M7SeEZgueZtRl+7jzNPhxVvw9VpjUT8aLOQb/FvMLXqj/c9ZcZCM/+7TfbONzWqB/uTcu9e/ciBT/tdlvpdLpvqZuLNEogOosF09rttvL5vBKJhOLxuJLJpPL5vMrlsqrVas9ieBdtXr+BcBGmcW4u4vVz1v9TZLPZkT8AWbTXPACMgmAYALCUwvXjbNtWuVweqY1+X1ueRtDYr81hf4D0C0gWMQSVptvvKHVp+4Vzk1iELBywRA1nluncYvmFr9fwIoH+cDcclvjf59rtdiCsCd/vF0LPimEYajQaqtVqkb6RUK/Xp1pPephRgs1wYJbL5eS67tg/Z9VybTabSiaTSiaTqlarC/3Bz7KZ5rm56NdPv5I4o5YYW7TXPACMgmAYALCUDMPoWXG6WCyOPEtkZ2cncH/Ss1v7zQaNUkfTNM2eQGbWs6rGFa4F3Gg0xg4hwud83Nm2kziO4Wst6sJHi35uw9fueWYghse8yF8F7xfOTasm5UWeg3D44X+9hevVhj/wOuu58zpb2C+TyajVaqnVaqlQKJwZGDWbzZE/nJyFi6qtn8/n+y4MZhiGMpmMSqWSGo2GOp2Ojo6OIi8WhvO7qHNzEa8fy7LUarX6Lkw8zv8bLONrHgAIhgEAS6tUKvWEGKOWlOj3+Nu3b5+nWwHhRdek3tnOg/R7XD6fP3efBikUCmOFtWcFOu12OxA8GIZxrtp8/UpwRJltG/7jbhJhyP7+fuD+KLMdL/rcTtKkgqV+oem8zBgdR79Qe1qh20Weg/Dr1R8G+4OXfjN+wx+8NRoN73a4tMQ8z77r1hVttVpyXVeNRqPv+944JY0uWvg6ncY1ms/n+y442mq1dHR0pFqtpkKhoFQqNfbCiRjPLM7NtF4/pmnq3r17kk5nvod/z49TUmLafQaAWSAYBgAstXDANupXIk3T7Ak+6vX6RGYNO47T80dDv/2d1bfwHyLNZrNnBu48C4e24aBoVJZl9YRPUY5HOFAOf419VP2eP0rgvcjn1l9HVnq2YNGowsG6tNjBsNTb/35jnISLPgf9rlUpGPT2u/4Nwwi05w+Sw++xi7SYUyqVUq1W6ymrIUV7P5qlcNgXnvV9Xu12uyd4rFQqajQaC7dQ6LKZl3MzidePaZpqtVqBaznc3jglJQZZ5Nc8ABAMAwCWWi6X6wkyRp152W/25iT+mOjXxqhfybxz507PjJ1sNrswZQfCNYAnsWBLv/M77A+zfjN9otQnHiQ823Gcr8Ev6rkNh33SeH8Yh//AXqRgcJBwuOIPTqOIGtBd9DkIf7By//59SWfXF+7yvza6IWQ4FJ7HMhJRZDKZnoVQu8dmnoXP83neC8PCHwbmcrmeY4TZmLdzc57XT61W6/n9aZrmxEpKDLKor3kAq41gGACw9MJ/CDSbzZH+ELAsq6d2bXel7nF1V/P2S6VSIwcghmH0naGSTCbPHSCed9bsMM1mM9D+ectIdI2zeFu/mdrj1k10HKenruCtW7dGbmeRz234HIxafsVxnJ6Za4tSSuMs4QC1Xq+PdB5GqRV8kecg/NrpvrbPqi/cFS4Rsb+/3/P+3K9EzKIIj2+ar7tJCR/vSdb3Db93RS0RMokFQXG2eTw3475+BpW4yOVyPe9F5ykp0c8ivuYBrDaCYQDA0kulUj1/CIwzazg8269arY61sEiz2ezZ/6AQMIpUKtV30bVEIjH2TJhisahkMjm1r7pL/WcnTYJpmj3nKhxC9xMOP2zbHuv8hmeCp1Kpsb+Gu6jnNhyE9yubcpbwMexXWmMRnacGZb+ZtGe5yHNgGEbgGm+324Hr86wPfML/1mg0emZSL8Ns8a6oi1BK06tBPUwmkwnMOLdte6xaqVECsagfdsz7NyXm0XmP2Tyem1FeP4NMs6REP5PoMwBME8EwAGAl9Av9+i38dpZ+X00sFosjhczlcrnvLJx+bY+iVCr1BIjS6cyVbDYbKVDqBkfxeNwLRKc50yU8Y3qSswL7nZNhX4fuNzO8WCyO9BX8crkceLxhGJEWvzvLIp5bwzB6+hw+NoP0e9wkZyzOWvgDkH7fHujnxo0bI+3nos9B+PXrD3eHlYjxB7/hBSkty5qrxcfi8fhI7wnhkPusOtmbm5uB+2d9BX3asxDD5zvqtdNVr9e1tbXVsz08/igfiNq2TZ3WCM57/VzEuZnm6yeqfr+X6/X6wH7NQ58BYKpcAADm0NHRkSsp8FOpVM7VZiaTCbRnGMbIbXQ6HdcwjJ6+mabp1mq1gc9rNBquZVk9z5PkNhqN8wwroFQq9d1Ht4+ZTMYtFApupVJxS6WSWygU3Fwu55qm2fc5pVJpYn3zq9VqPX2bpH7Xj2VZkZ6bSqVGPg5HR0duLpfj3Ib0u+YLhULfxw46hrlcbuh+wq/JqMc9vL9BfZukftfmWeej0+kMfO+I0t+LOgedTqfn/bV7++jo6MznViqVvs8b9Tqd9nXQarUC7ydnvee7rusWCoWeY3nWsQj3wzCMnsd3r4ezzkn4Nd9qtc7sZ9T+RLnmwr/rwv0Pv/cPu74ajUbf37mpVGpo/yd1PUS5/l03eH10fy7Sea+faZ+bab5+wtd8p9M5s23X7f1d3+94Tfs1DwDzgGAYADCXphEM92tznCCo0+kMDNsMw/ACukKh4GYymTMfO8ngsKvVag3c5yg/qVQq0h9X4wj/QTaNkLJfwBv1D7R+zzVN0y2VSm6r1XKPjo7cTqfjNhoNN5fL9f3jeNgfkONYhHPrd3R0NLC/4ddJv8dEDfMXKRh23WAQGn5P8If7g47LKP29qHPgur3hTPd1M0w4VB414Oma9nUw6Lx1g7ZCoeCWSqWB7wnDAsZ+wZxpmn0/5Dnrg81JBcOu2/+90DAMN5fLuZVKJXCt9htzv333e1y4zUKhcOZ7HcFwr0lcP9M8N9N8/YwTDB8dHfXsJ5PJXFifAWBeEAwDAObSNIJh1+0/m2PcgKzfbKqoP5lMZuqzSEqlUt8/VIb9mKY5lcC6q9+5nUZI2e+P5FEC6HHPr2EY5wpiopjXc9vP0dHRwBmvw14jUS1aMNxv38N+SqVST0gXtb8XcQ5ct//7a9Q+jhsq+80qGI762otilDYHvW9OMhh23d5v20T9sSyr7++5cY5j+PolGO7vvNfPNM/NNF8/4wTDrtv//xP8H+pexGseAGaNGsMAgJVSKpX61gkeR6VSUavVGmlhJMuyVKvVzl1TOIpCoaCjoyM1Go2exYT69SuXy6nVaqnT6Ux1sadwrV/LsqZSg6/fQlmj1Pvtnt9RFo7rHvNxF5sbdT/zdm77MQxDrVYrcp3g7kKM4y7GuCgqlUqkY2JZljqdjgqFwtjvGRd1DvrVT49aO7zfdTlvi87lcjl1Op2RF0LMZDJqtVqRHhvlmGcyGTUajQurXTrq7yzTNFWr1dRqtfo+J5fLRb4WU6mUOp1Oz2KK6O+81880z81FvH5Glclket5nbt686dVgnsc+A8CkxVzXdWfdCQAAFp3jOKpWq2o0Gjo8PJRt23IcR6ZpyjRNWZalfD4/F4uQ+BedmadFneZZd4Gdu3fvynEc2bYtwzC0ubkpy7K0u7urVCo18+O5COe2Xq+rUqnItu2+x3HUP8AXnW3bKpVKajab3vEwTVPb29vK5/OBDxmq1ao6nY53P51OjxWecg4mo16vq9FoaH9/33vPl+Sdw1Qqpd3d3ZE/KKpWqyqVSj3n5vr168rlcjN9bXffB/2LBBqGoe3tbe/6iTreZrOpUqmk/f19OY7jHTfTNHveU9vttu7eves9N5FI9CzkiFOTuH4u4txM6/UzTYvYZwAYhmAYAAAAAAAAAFYMpSQAAAAAAAAAYMUQDAMAAAAAAADAiiEYBgAAAAAAAIAVQzAMAAAAAAAAACuGYBgAAAAAAAAAVgzBMAAAAAAAAACsGIJhAAAAAAAAAFgxBMMAAAAAAAAAsGIuzboDWBwnJyf67ne/q5deekmxWGzW3QEAAAAAAAAQ4rqu3nvvPX3iE5/Q2trgecEEw4jsu9/9rl599dVZdwMAAAAAAADAEH/xF3+hT37ykwP/nWAYkb300kuSTi+qq1evzrg3AAAAAIBF4jiO/u7f/buKx+P6N//m38ykD//8n/9z/et//a/14MEDPXjwQK+99pp++qd/Wv/gH/wD/c2/+TdXsu1VxjU5n23j/B4+fKhXX33Vy/IGibmu615Qn7DgHj58qI2NDR0fHxMMAwAAAAAiazabymazchxHqVRKjUZjZvsfJJVKqVaryTCMlWh71XFNzl/bmJyoGR6LzwEAAAAAgImzbVvValXJZFLpdPrMIGma6vV6pP03m01tbW3Jtu2lb3tVcU3Ob9uYDYJhAAAAAAAwEclkUvF4XLFYTIlEQvl8Xu12e2b9abfbymaz3n3DMFSpVHR0dCTXddXpdJTL5bx/dxxH6XR6qdteNVyT8982ZsgFIjo+PnYlucfHx7PuCgAAAABgDkka+pNKpS6sP5Zlefs1DMPtdDp9H1cqlQJ9LBQKS9v2quGanP+2MXlRMzxqDCMyagwDAAAAAM4Sj8clSaZpant7W+l0WqlUytsu6cLqudbr9cAMx1arJcuyBj4+m82qXq9798+KSxa17VXENTnfbWM6qDEMAAAAAAAu1NHRkY6OjtRqtVSpVJTJZGa2AFWlUvFuW5Z1ZpAlSaVSKXDfH2wtS9uriGtyvtvGbBEMAwAAAACApeI4jprNpnf/1q1bQ59jmqZSqZR33x+GLUPbmK1FvW64JpcbwTAAAAAAAFgq/iBLUiCkOot/JmS4jUVvG7O1qNcN1+RyIxgGAAAAAABLxV8v1jCMyKUDrl+/Hrhv2/bStI3ZWtTrhmtyuREMAwAAAACApbK/v+/dNk0z8vPCj22320vTNmZrUa8brsnlRjAMAAAAAACWin924ihhVnhRrfv37y9N25itRb1uuCaXG8EwAAAAAABYKo7jeLc3Nzcn0s6it43ZWtTrhmtyuREMAwAAAACApTHJAOrw8HAp2sZsLep1wzW5/AiGAQAAAADA0oq6WFa/xw8Lxha1bczWol43XJPLh2AYAAAAAAAsjUnOTAy3tahtY7YW9brhmlx+BMMAAAAAAAAAsGIIhgEAAAAAAABgxRAMAwAAAACApbG5uTm1tha1bczWol43XJPL79KsOwAMcnJyoidPnujk5GTWXQGAhba2tqb19XWtr6/PuisAAABTN+oCWaO0tahtY7YW9brhmlx+BMOYK0+ePNF7772n9957T48ePZp1dwBgqVy+fFkvvfSSXnzxRX3sYx9TLBabdZcAAACmznGcsR8/bJbjoraN2VrU64ZrcvkQDGNuPHr0SH/xF38h13X1wgsv6OMf/7guX76stbU1wgsAGJPrujo5OdHTp0/16NEjHR8f6/vf/76uXLmiV199VZcu8b8CAABguR0eHkZ+bDj4GjbLcVHbxmwt6nXDNbl8+GsQc6EbCr/wwgt65ZVXCCoAYAquXr0q13X1gx/8QN/5znf04MEDfepTn9Lly5dn3TUAAICJMgzDC6Zs2478vPBjr127tjRtY7YW9brhmlxuLD6HmXvy5IkXCv/4j/84oTAATFEsFtOP/MiP6LXXXlMsFtOf/dmfyXXdWXcLAABgokzT9G6fJ8zqN8txUdvGbC3qdcM1udwIhjFz7733nlzX1SuvvKK1NS5JALgIzz33nH78x39cT5480fvvvz/r7gAAAEzU9va2d3uUuqjhMMvfzqK3jdla1OuGa3K5kcJh5t577z298MILzBQGgAt25coVXblyRcfHx7PuCgAAwEQlk8nA/Xa7Hel59+/fD9y3LGtp2sZsLep1wzW53AiGMVMnJyd69OiRXnrppVl3BQBW0sbGht5//32dnJzMuisAAAATs7OzE7h/9+7dSM9rNpve7VQqtVRtY7YW9brhmlxuBMOYqSdPnkgSCx8BwIxcvnxZruvq6dOns+4KAADAxBiGEZihWK1Whz6n2WwGviqfzWaXqm3M1qJeN1yTy41gGDPVnaFGbWEAmI319XVJIhgGAABLJ5/Pe7cdxxkaaBWLxcD9XC63dG1jthb1uuGaXF6kcRFls9meC3uW6vW60um0EomE4vG44vG4ksmkyuXySMXA50UsFpt1FwBgJfH+CwAAFkU+n1cikfB+wotbheVyORmGEXj+oPqo5XI58G+FQmEp28ZkcU2ev23MmIszHR0duZZluZLcTCYz6+64rVbLNQzDNQzDrVQq7tHRkfdvjUbD62upVJr4vo+Pj11J7vHx8cTa/MEPfuD+9//+390f/OAHE2sTABAd78MAAGCScrmca1lWz4+kwE+/xzQajTPbzmQygTZardbQ/jQajcBzun9Ld7VaLTeXywUeY5pmpLEuaturhmty/tvG5EXN8AiGB+h3Qc86GC6VSt6b1VkKhcJU+kswDADLh/dhAAAwSalUqidwi/rjD5n6GSeEc91nf0tH+TEMw+10OpHHu6htrxKuycVoG5MVNcOjlIRO66OUy2Xl83ml02mvLEOz2ZyblRObzaaKxaJM09S9e/fOfGypVFImk1G9Xg/UgQEAAAAAYNUUCgU1Go3AV+H7sSxLBwcHMk1z6dvGbC3qdcM1uXxiruu6s+7ErLXbbSWTSRmGoe3tbVmWpXQ6rVQqpWq16oWrmUxGtVrtwvvnOI62trbkOI5arVZgNciznhOPxyVJjUZjIgH3w4cPtbGxoePjY129evXc7UnS48ePdXBwoK2tLV25cmUibQIAouN9GAAArArHcbS3t6dKpSLbtuU4jkzTlGVZyufz5/q7eVHbxmwt6nXDNTn/omZ4BMNDzEMwnM/nVa1WZVmWWq1W5OcVi0WVy2UZhqGjo6Nz94NgGACWD+/DAAAAALBcomZ4lJKYc47jqFqtSpJ2d3dHem738Y7jqNlsTrxvAAAAAAAAABYTwfCc29vb825HKSHh5398qVSaWJ8AAAAAAAAALLZLs+4AzlapVLzb4xTtNgzDmzHsOM7QAuGL6rXf+Pez7sLSePDm3551FwAAAAAAADBlzBiec+1227s9TjDsf87+/v5E+gSsgmazqVgsFvhJp9PnbjeRSPS06zhO5OdXq1Vls9lAO/F4XMlkUsViUbZtR2qnXq/39GPQTzweVzqdVrlcHqmvAAAAAABgfhEMzzF/KDzuTF9/MNxoNM7bJWCldWfej6vdbkcObvs9N5FIKJ/Pq16vB9pxHEftdlvlclmJRELpdDrw/nFe3W8dFItFxeNxFYvFibUNAAAAAABmg1ISc8y/YNw4s4XDz5tkUATMSjableM4M/ugY29vT7lcbqzn3r17d6znlcvlvmFst4644ziBoLjZbCqZTMp13cj7qNVqfbcfHh6q1Wqp2Wx6+yiXy2o2m7p3797SlqcBAAAAAGDZEQzPsU6n493e3Nwcq41r1655t8edqQjMg3q97pVKSKVSM+tHpVIZOxiuVquSntX+jvocfyicSqVUKpV6FqN0HEd7e3sqlUqybXvkxSozmczQx/gD6na7rRs3bqjVao20HwAAAAAAMB8oJTHHDg8PJ9oewTAWRbcsQrFYVDqdVjweVzabndk1bBiGF0a32+2xykn4y1BEDbYdxwmEwoVCQY1Go2/oaxiGcrmcOp2OCoWCtre3R+7jMIVCIRAEd88TAAAAAABYPATDc8wfgo37dW2+5o1FdPfuXRWLRa9kwTwseOZfeK4783cU/lINu7u7kZ5TrVa9sVuWpVKpFOl5pVJJlUpl5D5GYVmWCoWCd596wwAAAAAALCaC4Tk2jTBsHgI2IArDMGSapjKZjCqVSiCMnAV/qYVxagXv7e1JOh1X1DIP/jrKUcPkixAOqP310AEAAAAAwGKgxvCKOTw8jDyL+IMPPtAHH3zg3X/48KEk6enTp3r69KkkKRaLaW1tTScnJ4GFrgZtX1tbUywW87Y/ffpUrut6jxllsSxMR/ccxGKxvudj0PZRDGv7zTff1JtvvhnYHg4jXdcduY+jbA/f39rakmmasm1b7XZbnU4nsLjjWW03Gg3vQ5mbN2/23Ve/4+7/1oBpmhMZ66Dxjdp291hIUqvV0o0bN6Z6PqKMKYpZ9XGex+S//sZ9Lw9v7/6O8G/vth9l+/r6ulzXDWzv9mXQ9qh9Z0yMiTExJsbEmBgTY2JMjIkxMaZlH1P4MYMQDM+xSdQYHnfROkm6ffu2vvSlL/Vs73Q6evHFFyVJGxsbeuWVV/TOO+/o+PjYe8zLL7+sl19+Wd/5znf06NEjb/vHP/5xGYahBw8e6MMPP9TJyYmePHniXbAffPBB4EXy/PPPKxaL6fHjx4E+XLlyRa7rBoJrTMbjx4/13HPP6dKlS9456rp8+bLW19fPdZ5isZiuXLmik5MTffjhh972tbU1Pf/883r69Kk++ugjb/v6+rouX77c8wb30Ucf6fLly/roo48Cb6KXLl3Sc88917N91DGFA7XHjx/rl37pl/SP/tE/kiT943/8j/Vbv/VbkcbkL+vwS7/0S4Hxddt+/PixN9Zu369eveo9xrbtc4/Jf57CfRj1PG1tbXnB8P/4H//DOx9PnjzRkydPvMeHx9Q1qfN0Edfeso/pgw8+8Po17nt51yc/+Um9+OKL6nQ6gbFubW3p0qVLevvttwNj+vSnP60nT57o4OAg0PfPfOYzevTokb797W8Hjpdpmjo+Ptb3vvc9b/sLL7ygV199VYeHh3r33Xe97ef9/cSYGBNjYkyMiTEt/Jj+/88mWnz6nX+rJ+sf08HLz9a6WHM/0mfe+Xd6dPlH9e3Nn3s2picPZb57T8cf+wl9b+PZN91e+OAdvXr0X3T44l/Xuy/+1LMx/c8HeuXhN/TO1dd1/COvPRvT+3+il9//U30n/v/Uo+d/7NmYjtsyfvBnevDyDX146dn/737y8D/rxQ//Sp0f+3/rJPbcszG929Slpz/Q2z/2d+THmBZrTIVPv+Fte+I+0R9/8MfaXNvU5y5/ztv+6OSRvv7h1/XK+iv6qeee9f3w6aHe+ugtbV3a0talLW/7d598V3/65E/11y/9dX3i0ie87QdPDnTw5ECfe+5z2lx/lon8yUd/or98+pf62cs/qxfWXvC2v/XhWzo8OdT/9vz/pkuxZzHZ1z/4uh67j/XzV34+MKY/evxHuhK7op99/mcZ0wKPqXL92d/pc/1e7jPK76eoeVnMPe9UpSVXrVaVz+clnX6V3F8ndNri8bg3yzCXy41VM7ReryubzXr3w7Mcz9JvxnD3BdENrM77Kcnjx4/1Z3/2Z9ra2tLHPvaxsWfObd36D2M9D70Obv8fkuZvhmOpVNJv/MZvSDpdvO0rX/nKVGdtNptN/eIv/qKk0/IPh4eHsm1bP/mTPynpdAbvt771rUhtx2Kxge1IwZn8/nby+bzu3LkTeO55x9pVr9e1s7Pj3e/3aeJZbScSCS8YfvPNN1UoFKZ6PqKMKYpZ9XGex/T48WMdHBzINE1dvnx5bj/xXsZP8RkTY2JMjIkxMaapjum3fvTZdveJpJhOYuvBMblP5Ia2x+RqzX06cPuJ1uTGnlWljLmu1vRUJ1qX+8P/7z3dfqI1negkti5Xz7avuU8Vkztw+9NYcP7amvtUkquTnu2MaZHG9PrWa4HtT/VUMcW0Fqpwetb2Na0p5uuLK1cnOhm4fV3B43iiE7lyz719nL4zpvkb0zf+/je8bXP9Xh5he7/fT++9957i8biOj48Dk87CmDG8IMadPRx+3igziJ9//nk9//zzPdvX19e1vh58wXUvzrBh29fX1wPBWcz3Cwqz4T8Hg87HJM7TqG2Htw+7ZibVvv9+IpHwSijYtq1vfOMbgXrB/dqu1+ve7Z2dncD17n9ev+P+q7/6q14w7DiOfvEXfzFQd3jcsQ4aX9Q2HMcJlLlIJpNTPx/Dto9iVn2c1zH5r79x38vDwr8jxtkei8VG2j6pvjMmxsSYGNM42xkTY5rLMblPQltdrfdsOw0SR9m+phPJ7Z1UsKanUp/Pu08Dw+jb++1z8HbGtChjeqredtwRt5+o/1fjB23v18akto/ad8Y0f2NamPfyiNvDfR+0r54+RXoUAEDS6IvQ+Wf6+2fvR2FZllKpZ18jazabSiQSKpfLgWD2ohWLxcB9fx8BAAAAAMBiIBieY+epDzxI1IXnAPTXLS0jnZaaOYvjOGo2m5JOX3vjBKi1Wi1Q/sW2bRWLRSUSCSUSCeXzeW8fF6HZbAbGHV4UEAAAAAAALAaC4TlGiAvMH9M0vfIRjuOo3W4PfOze3p5321/PdxSGYajVagVKVnTZtq1qtap0Oq1YLKZ8Pu/VJZ+GYrGodDrt3bcsS4VCYWr7AwAAAAAA00ON4TnmnzE8btjjfx5BMzAZu7u7XiBcqVQGLgzp3+6faTyqbjhcr9dVqVQGzhCuVquqVquq1WqBkhdRDJr97DiO7t+/r2azGXg/sSxL9+7dG2kfAAAAAABgfhAMzzH/18fHXXzObxqlKYBVlMvlvDq7e3t7fYNh/2xiwzD6zvgdVSaT8QLfer2uRqOhZrPZU284m82OHA6PElzncrmBYTgAAAAAAFgMlJKYY4lEwrs97ozhTqfj3fYHzQDG5w96/XWE/fxlJHK53MT7kMlkVKlU1Ol01Ol0ekLgbDY7sQXquuMtFArqdDqEwgAAAAAALAGC4Tnmn2E47oxh//MmMWMRwCn/DNt+QemkykhEYZqmarWaarVaYHt3VnMUnU5Hruv2/Tk6OlKr1VKpVOIDJgAAAAAAlgTB8Bzb3t72bo87Y9g/Y/D69evn7RKAH/IvJheeMewvI2Ga5oWFqZlMJrAYXL1ev5D9AgAAAACAxUMwPMfCdUnH+Vq4/zmpVGoi/QIWQT6fVywWG/qTTqfHat8wDO81FS4n4S8jMe3ZwmG3bt0K3B+0UB0AAAAAAFhtBMNzbnd317s9asDjOI430ziVSskwjAn2DEA2m/Vu+8s4+G+PsgDcJBiGEZihPO63DQAAAAAAwHK7NOsOrBrHcbS/v6/t7e1IQW0mk/HqhDYajZEWsfLPWvQHWMAqyOfzSiaTQx93njIPOzs73ozgvb09VSqVwOxhy7JmXpOXD4QAAAAAAEA/BMMXqFqtBr5WXqvVhs4mNE1TmUxG9Xp95Hqh3VmLhmGMFCgDy8CyrKkvuNgtJ9FsNr26wv7yLRddRkI6/fDJ34dZB9MAAAAAAGA+UUpiCP/XsM/7lexwSBR1Fm+pVPJul8vlSM+xbdubtXjnzp2IPQQwKv/r+u7du7p79653379A3Tiy2ay3iF1Ut2/f9m5f5MJ3AAAAAABgsRAMD9FoNLzb+/v7Y7czaOG4KGGzaZqqVCqSpGKxGOk53bAqk8lceI1TYJX4X1/NZtP7QGYSdb3r9bqSyaRXTmaYZrMZ+PDI/6ESAAAAAACAH6UkfqharXq3HcdRp9PR/v5+YLae4ziKx+Pa2dlRIpEIhD47OztnhkDdmXvhr3hHDY5yuZw6nY7K5bJu3Lihe/fuDXxusVhUs9lUKpUKLIIFYDq65V787xfnLSPhf68ol8sql8vK5XLK5/M9JTJs21apVAq8j6VSKT4UAgAAAAAAAxEM/1C/mbiGYfQNX/f29noeG2V2YKPR8L4ankqlvFnAUZVKJV2/fl03b97U1taW7ty5Ewh+2u22FwoXCgVmC2Jh+UuhdN2/fz/w7/4QVJK2t7enXlN4kHw+31MD/LyhrGmayuVygXFWq1XvfrdERL9vI1iWFfi2AwAAAAAAQBjB8A8dHR1NfR+maarVap2rjW5piHq9rkqlomKxqMPDQ6/93d1d1Wq1c3+FHZildrt95oxb27Z7/j2Xy438YcukpFKpwP1JzdTtvsaLxWJP8DyoPM0sjwMAAAAAAFgcBMMLitrBQQ/e/Nuz7gJWXKPR8L5JMMmZy6ZpqlaryXEc7e3tqdFoqN1u6/DwUI7jyDAMmaapVCqlfD7PYnMAAAAAACCSmOu67qw7gcXw8OFDbWxs6Pj4WFevXp1Im48fP9bBwYG2trZ05cqVibQJAIiO92EAAJbUFzdm3QPA89mtT826C0DAN3/lm7PuwlRFzfDWLrBPAAAAAAAAAIA5QDAMAAAAAAAAACuGYBgAAAAAAAAAVgzBMAAAAAAAAACsGIJhAAAAAAAAAFgxBMMAAAAAAAAAsGIIhgEAAAAAAABgxRAMAwAAAAAAAMCKIRgGAAAAAAAAgBVDMAwAAAAAAAAAK4ZgGAAAAAAAAABWDMEwAAAAAAAAAKwYgmEAAAAAAAAAWDEEwwAAAAAAAACwYgiGAQAAAAAAAGDFEAwDAAAAAAAAwIohGAYAAAAAAACAFUMwDAAAAAAAAAArhmAYAAAAAAAAAFYMwTAAAAAAAAAArBiCYQAAAAAAAABYMQTDAAAAAAAAALBiCIYBAAAAAAAAYMUQDAMAAAAAAADAiiEYBgAAAAAAAIAVQzAMAAAAAAAAACuGYBgAAAAAAAAAVsylWXcAmIgvbsy6B8vji8ez7gEAAAAAAACmjBnDAOZOs9lULBYL/KTT6XO3m0gketp1HOf8HY5gFvuMap77NgvxeNw7HrZtz7o7AAAAAABMBcEwgIXQbDbPFVq2221CPgAAAAAAgB8iGAawMPb29sZ+7t27dyfYEyAa27YDM7KbzeasuwQAAAAAgCSCYQALpFKpjP3carUqSTIMY0K9AQAAAAAAWFwEwwDmmmEYSqVSkk7LQYxTTsJfhqLbFgAAAAAAwCojGAYw9/wLz3Vn/o6iVqt5t3d3dyfSJyCKzc1NlUol78c0zVl3CQAAAAAASdKlWXcAAIbJZDIqFouSTmsFFwqFkZ7frU1sGIYsy5p4/4BBDMMY+XoFAAAAAOAiMGMYwNwzTdObadlut2XbduTn+stI5HK5aXQPAAAAAABg4RAMA1gImUzGuz3KInT+x1JGAgAAAAAA4BTBMICFkM/nvdv1ej3y87qPpYwEAAAAAADAMwTDABaCv5yEbdtqt9tDn+MPkHd2dqbWNwAAAAAAgEVDMAxgYfjLSdy9e3fo4/1lJLLZ7Fj7dBxH5XJZ6XRaiURC8Xhc8Xhc6XTaWxBvXO12W9lsVolEQrFYzGs36ozoafZtmvtLp9NKJpNKJpPetvMei65ms9nTTjKZVLlc9mpNj8O2bRWLRSWTScXjccViMSUSCZXL5aHPjcVi3s9ZfahWq96x7fY9kUgonU6rWq2eq/8AAAAAAITFXNd1Z90JLIaHDx9qY2NDx8fHunr16kTafPz4sQ4ODrS1taUrV66M39AXNybSH0j64vGse6Bms6l0Oi3ptATE0dGRpNNwLpFI9Gzvx3EcxePxM9uQpKOjIxmG0beNfD6varV6Zl8Nw1CtVlMqlTrzcbFYLLDParV6ZphaKBRUKpUG/vs0+9bveExzf8Vi8cy2hx0L6fS8ZrPZM2eSG4ahO3fuBD5g6Ccej3shbKPRUKVSOTOgtixLrVZr4L8PO762bSuZTEYKfjudjjdzflIm9j4MAADmC38jYY58dutTs+4CEPDNX/nmrLswVVEzPIJhREYwvCLmOBiWpGQy6YV/rVZrYN3garXq1SXO5XLe7OFRgmF/oGdZlra3t73H1ut12bbt/fuwwM7fViqVUrPZlGEYXokL27bVbDYDzzmrzWn1bdDxmOdj0W63dePGjUCwmkqlZJqmDg8P1Ww2A/82LGj2B8NdhmEolUppc3NT+/v7PQF0JpNRrVYbOt7w8XUcR1tbW97+TNP0gmvHcWTbtvb3971/n8avbIJhAACWFH8jYY4QDGPeEAyfunSBfQKAc9vd3fVCuUqlEigX4eff7l+4bhTdkO7WrVs9YWmpVArMos1ms2fOGvVrNpt9Z5n6A/HuGAYFmNPq2yDzeiwcxwmEwplMRnfu3OnpY7lc9mZol8tlXb9+fejMYf/4CoVCYFt4hnK9Xle73R55gUN/iYizwuVmsznw3wAAAAAAGAczhhEZM4ZXxJzPGB5UIsLvrMeMMmPYcZyB/xbejxR9hu9Z+/UHrGeVKJhW3wb1a16PRTab9co8nBWsSr1h86D9+mcMVyoV5XK5gW36Hzto/2cdX3//G43G0DIc08CMYQAAlhR/I2GOMGMY84YZw6dYfA7AQjEMw5uV6ThOT8kBSdrb2/NunxXqRdnXsH/3B3ln1bf1y+VyA9v2L5J3Vs3ZafXtovd3nmNh27YXqnbrB58llUoFZgnfvn17aP+2t7fP/Hd/EFyv18+9wB0AAAAAABeFYBjAwvGXhuhXSmISZSSi8s+KvX//fqTn+GetnuXw8HCsPnWN07eL3t95joV/QbidnZ2h4bUUvB7OWlAuqlQqFdjv/v7+SM+/fv16oG/DFvgDAAAAAGBSCIYBLJzuImWSemYMO47jzVY1TfPMRdAmYZzw9qw+bW5unqc7AecNli9if+c5Fo1Gw7sdNWD2zwC2bftcM3y7/DOlR531G54xnc/nFYvFlEgklM/nzz0LGQAAAACAQVh8DsDC6ZYtaDabXjmJbjjnLyMxydnC7XZbzWZT9+/fV7vd1uHh4dwEdhfdt3k5Fv4QNsps4X6POzw8jPzcQfwBdqfTGem5hmHo4OBAyWQyMB7btlWtVr0ZxIVCYeBChAAAAAAAjINgGMBCymaz3mzhWq3mBcP+mq/+erLjKhaLqlarEw0+zxtEdk2jbxe9v0kdi3H7NA/hvmEY6nQ6qlarqlQqfeszl8tl2bZ95uJ6AAAAAACMglISABaSv5xEd5awfzE6y7LOVUbCtm3F43GVy2UvPEylUiqVSmo0Gup0OnJd91yL2y1K3+b1WPhD5ag1jcOlHiZRasTf5rVr18ZuJ5fLqdVq6ejoSI1GQ7lcLtC/er0+kbrIAAAAAABIzBgGsKDC5STa7XYgoDtvGYl0Ou2FoLlcTqVSaWKzW8/rovs2r8cilUp5s2v7zbLtx/84wzAmMg7/gnOWZZ27ve613Z0F71+U7vbt2xOZCQ8AAAAAADOGASwsf/h79+5d3b1717vvn1E8qmaz6YXMpmmqUqkMDBAveoG3i+7bPB+L3d1d77a/n2e5ffu2dzvKNTJsTOHF4fwL0U2Kv7bwqIvbAQAAAAAwCMEwgIXlnznZbDa9MhKpVGpiM1qHtTPLoO6i+zZvx8KyrEAQm81mz3x8tVoNzBiOspjbWTORHcdRsVgcqb2wKMfMH077F7oDAAAAAOA8CIYBLLRuONxut72Zm+ctI7G9ve3dbrfb3tf4w4rFYuQSBpNy0X2b52MhSZVKxbvdbreVTCb7hq3FYjFwXUQth1EsFvvW9W02m4F9GYahQqEwcv9LpZLi8fiZi/r5w+dpzEgGAAAAAKwmagwDWGj5fL4nuDtvDVZ//eLuPkqlkjcT2bbtmS0CdtF9m+djIZ2Wt2g0Gkqn05JOw+FEIiHTNGVZlmzb7gmsc7ncSCFuNpuVZVleSL6/v9/T5p07d8bq//7+vhzHUT6fVz6fl2EY2t7elmmaOjw89Gpod40zKxkAAAAAgH4IhgEstPAMykktzFWpVJRMJr1Qzrbtntmy3X1ddDB60X2b52MhnV4DrVZL2WzWm8Fr23bfmcOVSkW5XC5y27VaTbdv31a73R44I7pWq4193eXzeRWLRe/YOo7jhfD99jMPi/4BAAAAAJYDwTCWwxePZ90DzFCj0fCCNcuyJtKmaZpqtVoqFoverM3ubM50Oq1MJiPTNANB6PXr1yey73nr2zwfiy7LstTpdFSv13X37t1AP03T1O7urnK5XKRgdWdnx6vra1mWWq2W6vW6KpWKN8PXNE2lUikVi0WZpjl2v3O5nHK5nJrNpmq1mte+bdte31OplG7dukUoDAAAAACYqJjruu6sO4HF8PDhQ21sbOj4+FhXr16dSJuPHz/WwcGBtra2dOXKlYm0CQCIjvdhAACW1Bc3Zt0DwPPZrU/NugtAwDd/5Zuz7sJURc3wWHwOAAAAAAAAAFYMwTAAAAAAAAAArBiCYQAAAAAAAABYMQTDAAAAAAAAALBiCIYBAAAAAAAAYMUQDAMAAAAAAADAiiEYBgAAAAAAAIAVQzAMAAAAAAAAACuGYBgAAAAAAAAAVgzBMAAAAAAAAACsGIJhAAAAAAAAAFgxBMMAAAAAAAAAsGIIhgEAAAAAAABgxRAMAwAAAAAAAMCKIRgGAAAAAAAAgBVDMAwAAAAAAAAAK4ZgGAAAAAAAAABWDMEwAAAAAAAAAKwYgmEAAAAAAAAAWDEEwwAAAAAAAACwYgiGAQAAAAAAAGDFEAwDAAAAAAAAwIohGAYAAAAAAACAFUMwDAAAAAAAAAArhmAYAAAAAAAAAFYMwTAAAAAAAAAArBiCYQAAAAAAAABYMZdm3QFgEj77Lz476y4sjW/+yjdn3QUAAAAAAABMGcEwgLnTbDaVTqe9+7VaTZlM5lxt2ratRCLh3T86OpJhGOdqc9Lq9bqy2ax3f9Q+ttttJZNJSZJhGDo6OhqrH7Ztq1KpqNlsyrZtOY4j0zRlmqay2ax2dnbm4thNup/FYlH1en1q/e10OlNrGwAAAACAUREMA5g7qVRKhmHIcRxJUqVSOXcwXKlUetpHkG3bymazarfbff/Ntm01m03l83kVCgWVSqUZ9HJ6/XQcR7ZtT7q7AAAAAADMJYJhAHNpZ2dH1WpV0ukMYsdxzhXm+meC5vP583Zv6VSr1Z7jYhiGtre3ZRiGbNsOBLHlcln1el2NRkOmaS5FPxOJhCzLGtqH7uzkrijPAQAAAABg3hAMA5hL+XzeC4YlaW9vT7lcbqy22u22NxPUMIxzzz5eNuVyWcVi0btvWZZKpZJSqVTgcY7jqFqteo+1bVvJZFKtVutCwuF+/bxz507fYLbbz+4s4Cj9LBQKKhQKQ/tRLBZVLpe9+61Wa8SRAAAAAAAwe2uz7gAA9GNZViDE85eCGJX/uTs7O+fq17LxB73SaTjaarV6QmHpNFQvFArqdDreuXEcR8lkMjCD9iL6WSqV1Gq1Bs7WzeVyOjg48P79ovoJAAAAAMCiIBgGMLf8JQP8s35Htbe317fNVWfbduB4RK3Ha5pmYPat4ziBRfOm3c9SqRRpZq9hGLp3796F9RMAAAAAgEVCMAxgboVLR4wza7hbn1g6DTSpB/uMPyTtlo+IyjAM1Wo1736z2QzUcZ4kfz9TqVSkULjLMAw1Gg3v/jT7CQAAAADAIiEYBjC3DMMIlDQYJ9Dzh8nUFn6m2WwGFmnzh7xRWZYVCO/9pR4mZRL9NE0zECZPo58AAAAAACwagmEAc80/W9S27UBIGIU/TKaMxDP+2cGpVGrsxeP8Iatt22o2m+fum5+/n5lMRoZhjNXOrVu3vNvT6CcAAAAAAIuGYBjAXAuXk7h7927k5/pD4fBidqvMcZxAMHqewNw0zcCs7vMsEhg2yX6GZ59Psp8AAAAAACwigmEAc89fAqJarUZ+nj/8Y7bwM+HZsuctsZFOpwe2fR7htvzB7jim1U8AAAAAABYRwTCAuecPdcOzSAcJP25nZyfSvqrVqpLJpOLxuGKxmBKJhIrFomzbjtzfdrutfD6vRCKhWCymWCymeDyudDqtcrnsLYY3K/7F2CYxi9of2DqOM9KxOsui9BMAAAAAgEVEMAxg7qVSqUBt2SgLkO3t7Q18fj/tdlvxeFz5fF7tdtsLb23bVrlcViKRGDpb2XEcpdNpJZNJVavVQPDYDaqLxaLi8fhMF0A7PDz0bluWde72wqHtpAJXfz8nEQyHrwGCYQAAAADAKiMYBrAQ/DN+o5STGKWMRLPZVDKZ9MJgwzCUyWSUy+UCwWk+nw/ULfZzHEfJZDIwS9k0TWUyGWUymZ5wepalDPyB6Obm5rnbCweuk5oR7e/nuIvO+YXHOuuZ2wAAAAAAzNKlWXcAAKLI5/OBQLherw+sjWvbttrttqRnIe9ZstmsdzuXy/UsTNZsNr36tDdv3uzb3o0bN7wg0zAM3bt3r+9s3Ha7rWKxONOF8PyB6CQC1zD/TN/zmHZwO6l+AgAAAACwiJgxDGAhWJYVCFPv3r078LH+Wb3DagsXi0UvgMxkMj2hsHRaiqK73XEclcvlwL+Xy2UviDZNU61Wa2CJBsuy1Gg0VCqVzuzXNPnD4GmEr5OYhSxNvp/hIHhS/QQAAAAAYBERDANYGP6SEINKOkjRy0iEQ96zahfncjkvqPQviiZJt2/f9m6XSqVIs4GnMVM3Kn8gOolZs+HQdlJjW5R+AgAAAACwiCglAWBh5HK5wKJt1WpVuVwu8Jh2u+2VdDBN88zF1cIL1A2r+2uaptrtduBxzWazpzbxvPMH15NYgC3cxqTKZPjb6c7IPo/9/f2B7QMAAAAAsGoIhgEsDMMwZFmWFxLWarWeYNg/W3hYSNtqtbzbzWZzpAXhHMeRYRiBwHJ7ezvy82cpnU579ZonEbj6j5thGBMLXP39lE4D6PO07T/fk+wnAAAAAACLiFISABaKvzSEf7Zul38W8FllJKTzzZbtljbodDretvMGjeHSBqOWT/A//qz6ualUKnB/lEC8H39pjXDb+XxesVhs6E93cb+z+nlW+ZAowjPEAQAAAABYZQTDABZKeIawP+zzB8XhxeqGaTQacl038s80ZpuGw9xRF1zzP/6s+rndmddd/Rbck06D82q16v30649t24FgeXd3d6Q+nyVqP6MIf4gwyX4CAAAAALCIKCUBYOFkMhlv9milUvHCYv/iccNmC0vB8LTdbo81i9Tfxnnr9YbrIe/v759ZIznsrJm7YaVSyZulW6/X+5ZpME1TpVLJG1etVutZeK9UKnm3+9VYzufzSiaTQ/s+KGj399O2bdXr9bHqOPv7aZrmQtSCBgAAAABgmgiGASycfD7vBcPtdtur9+ufPbyzszO0nXQ67bVz//79sfqSTqdVLpcl9S5uNg7/Inj9aiifxT9zt19phvB+TNP0Qt98Pt8T+kqnYXMikfDaL5fLKhQKkk6Pvb8GsD987bIsa6Rwe1g/b968OXKoW6/XA8fGv4AhAAAAAACrilISABZOKpUKzNTd29vzAuJ+/z6IPzzuzpo9T18cxzl3HVx/aDnKgnj+/pumGWn2s3+GdTf0DevOGvb3r1uWIZvNetstyxopxB6Fv5/h/Q5j27Zu3rzp3U+lUlPrJwAAAAAAi4RgGMBC8oe6tVpNd+/e9e5HKSMhnZY+8IeEUQPHdrsduO9v4+bNm5FqAw8KkFOpVCDUjTKWcPgZtRavZVk9oW+/cLhQKARm/WazWSWTSS+INgxD9+7di7TPcYT7Wa/XIx+XZDLpnQ/DMAIhMwAAAAAAq4xgGMBC8geDzWYzELSOUmqgVCp5M37b7XYg8Ayr1+tKJpOBELbbRrdGruM42tra6gmP/W0kEokzQ+harea1Z9u2EonEme35w89CoTBSreRCoeCVhpBOw+FkMtmzv/CsXX8o3Gq1Is3QPo9wP6vVqhKJRN8Z1Y7jqFwuK5FIBELhe/fuTb2fAAAAAAAsCmoMA1hIlmUFas92/ztqmYBuYHjjxg05jqN2u61EIiHLsrS9ve21vb+/HwgZwxqNhhfQOo6jZDIpwzC8kNZxnJ4Qs1sbuV+fGo2G0um0bNv2Zr6mUiml02mZpqn79++r2WwGAtxcLte3zu8wpVJJ165d88pYdANy0zRlmqYMw+gblndD4UELx01auJ+2bSudTsswDG1vb3v9DIfapmmq0WhcWD8BAAAAAFgEMdd13Vl3Aovh4cOH2tjY0PHxsa5evTqRNh8/fqyDgwNtbW3pypUrY7fz2X/x2Yn0B9I3f+Wbs+5CZOVyuWchsVarNdZiZ7ZtK5vNDpyZ22Wapmq1Wt99dOvfDqsL3K3bG2Vmcz6fDyzw1o9hGCqVSueunRv1GPh1Op0LD1xH6WehUBgrLD9LuOTGov8andT7MAAAmDNf3Jh1DwDPZ7c+NesuAAGLlH2MI2qGRzCMyOY5GMZqchxH8Xjcu28Yho6Ojs7VZrPZVKVSUbvdlm3b3mxU0zSVzWYjlWkItyGdhsGWZWl3d3ekUhfSaRBaqVTUbDZl27Y303h7e1vZbHbii6m1221VKhXt7+/37C+dTgfCeMuy1Gq1Jrr/8/SzO8s5m81qZ2dnKqUjCIYBAMBCIBjGHCEYxrwhGD5FMIzICIYBSKf1ff01nkulUqD+LxYL78MAACwpgmHMEYJhzBuC4VMsPgcAGEkulwuU0igWiwMX7AMAAAAAAPOJYBgAMLI7d+4E7mez2Rn1BAAAAAAAjINgGAAwMsuyAuUj2u12oO4uAAAAAACYbwTDAICxlEolWZblLfhWqVTkOM6suwUAAAAAACK4NOsOAAAWV6vVmnUXAAAAAADAGJgxDAAAAAAAAAArhmAYAAAAAAAAAFYMwTAAAAAAAAAArBiCYQAAAAAAAABYMQTDAAAAAAAAALBiCIYBAAAAAAAAYMUQDAMAAAAAAADAiiEYBgAAAAAAAIAVQzAMAAAAAAAAACuGYBhzwXXdWXcBAFYS778AAAAAsJoIhjFTa2unl+DJycmMewIAq6n7/tt9PwYAAAAArAb+CsRMra+vS5KePn06454AwGp68uSJpGfvxwAAAACA1UAwjJlaX1/X5cuX9ejRo1l3BQBW0nvvvacrV64QDAMAAADAiiEYxsy99NJLev/996lzCQAX7OTkRO+//76uXr06664AAAAAAC4YwTBm7sUXX9STJ0/0gx/8YNZdAYCV8vDhQ7muq5deemnWXQEAAAAAXDCCYczcxz72MV25ckXf+c539NFHH826OwCwEt5//31973vf09WrV3X58uVZdwcAAAAAcMEIhjFzsVhMr776qmKxmP78z/9cjx8/nnWXAGBpnZycyHEcffvb39aLL76oT3ziE7PuEgAAAABgBi7NugOAJF26dEmvvvqq/vzP/1wHBwe6cuWKNjY2dPnyZa2vrysWi826iwCwkFzX1cnJiZ48eaL33nvPq+l+9epVfeITn+D9FQAAAABWFMEw5sbzzz+vn/zJn9T777+v4+Nj/dVf/RUL0gHABF25ckV/7a/9Nb300kuUjwAAAACAFUcwjLkSi8X00ksv6aWXXtLJyYmePn2qp0+fzrpbALDQ1tbWtL6+rvX19Vl3BQAAAAAwJwiGMbfW1ta0tram5557btZdAQAAAAAAAJYKi88BAAAAAAAAwIohGAYAAAAAAACAFUMwDAAAAAAAAAArhmAYAAAAAAAAAFYMwTAAAAAAAAAArBiCYQAAAAAAAABYMQTDAAAAAAAAALBiCIaHqNfrSqfTSiQSisfjisfjSiaTKpfLchxnpn1zHEflclnpdFrxeFyxWEzxeFyJREL5fF7tdnum/QMAAAAAAAAwnwiGB2i324rH47p586ay2axarZaOjo50dHSkUqmku3fvKh6Pq1wuz6R/+Xxe8XhclUpFpmnq1q1bqtVqunPnjjKZjJrNppLJpNLpNAExAAAAAAAAgICY67rurDsxb8rlsorFoizLUqvVGvi4YrGocrmsTCajWq12IX1zHEfJZFKSVCqVlMlkBj62Xq/r5s2bchxHpVJJhULhXPt++PChNjY2dHx8rKtXr56rLQAAAADAFH1xY9Y9ADyf3frUrLsABHzzV7456y5MVdQMjxnDIc1mU8ViUaZp6t69e2c+thvM1ut15fP5C+lfNxTudDpnhsKSlMlkdHR0JMuyVCwWVa1WL6KLmJJqteqVNYnFYkokEspms2o2m7Pu2tS0223l83klk0mvXEoi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AAAJIxgGAAAAAEgYwTAAAAAAQMIIhgEAAAAAEkYwDAAAAACQMIJhAAAAAICEEQwDAAAAACSMYBgAAAAAIGEEwwAAAAAACSMYBgAAAABIGMEwAAAAAEDCCIYBAAAAABJGMAwAAAAAkDCCYQAAAACAhBEMAwAAAAAkjGAYAAAAACBhBMMAAAAAAAkjGAYAAAAASBjBMAAAAABAwgiGAQAAAAASRjAMAAAAAJAwgmEAAAAAgIQRDAMAAAAAJIxgGAAAAAAgYQTDAAAAAAAJIxgGAAAAAEgYwTAAAAAAQMIIhgEAAAAAEkYwDAAAAACQMIJhAAAAAICEEQwDAAAAACSMYBgAAAAAIGEEwwAAAAAACSMYBgAAAABIGMEwAAAAAEDCCIYBAAAAABJGMAwAAAAAkDCCYQAAAACAhBEMAwAAAAAkjGAYAAAAACBhBMMAAAAAAAkjGAYAAAAASBjBMAAAAABAwgiGAQAAAAASRjAMAAAAAJAwgmEAAAAAgIQRDAMAAAAAJIxgGAAAAAAgYQTDAAAAAAAJIxgGAAAAAEgYwTAAAAAAQMIIhgEAAAAAEkYwDAAAAACQMIJhAAAAAICEEQwDAAAAACSMYBgAAAAAIGEEwwAAAAAACSMYBgAAAABIGMEwAAAAAEDCCIYBAAAAABJGMAwAAAAAkDCCYQAAAACAhBEMAwAAAAAkjGAYAAAAACBhBMMAAAAAAAkjGAYAAAAASBjBMAAAAABAwgiGAQAAAAASRjAMAAAAAJAwgmEAAAAAgIQRDAMAAAAAJIxgGAAAAAAgYQTDAAAAAAAJIxgGAAAAAEgYwTAAAAAAQMIIhgEAAAAAEkYwDAAAAACQMIJhAAAAAICEEQwDAAAAACSMYBgAAAAAIGEEwwAAAAAACSMYBgAAAABIGMEwAAAAAEDCCIYBAAAAABJGMAwAAAAAkDCCYQAAAACAhBEMAwAAAAAkjGAYAAAAACBhBMMAAAAAAAkjGAYAAAAASBjBMAAAAABAwgiGAQAAAAASRjAMAAAAAJAwgmEAAAAAgIQRDAMAAAAAJIxgGAAAAAAgYQTDAAAAAAAJIxgGAAAAAEgYwTAAAAAAQMIIhgEAAAAAEkYwDAAAAACQMIJhAAAAAICEEQwDAAAAACSMYBgAAAAAIGEEwwAAAAAACSMYBgAAAABIGMEwAAAAAEDCCIYBAAAAABJG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",
      "text/plain": [
       "<Figure size 1500x1200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Data from the LaTeX table\n",
    "tasks = summary.values[:, 0].astype(np.str_)\n",
    "methods = [\"1-MSP\", \"Mahalanobis\", \"VecUQ-OT\"]\n",
    "values = np.round(summary.values[:, 1:].astype(float), decimals=3)\n",
    "\n",
    "# Positions for groups and bars\n",
    "x = np.arange(len(tasks))\n",
    "width = 0.25\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(15, 12))\n",
    "\n",
    "# Plot each method as a separate set of bars\n",
    "rects = []\n",
    "for i, method in enumerate(methods):\n",
    "    rect = ax.bar(x + (i - 1) * width, values[:, i], width, label=method)\n",
    "    rects.append(rect)\n",
    "\n",
    "# Labels and title\n",
    "ax.set_ylabel(\"ROC-AUC\")\n",
    "ax.set_title(\"ROC-AUC on downstream tasks\")\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(tasks, ha=\"center\")\n",
    "ax.set_ylim(0, 1.05)\n",
    "ax.legend()\n",
    "\n",
    "# Add a light grid on Y\n",
    "ax.yaxis.grid(True, linestyle=\"--\", alpha=0.5)\n",
    "\n",
    "\n",
    "# Annotate bars with values\n",
    "def autolabel(rects_):\n",
    "    for r in rects_:\n",
    "        height = r.get_height()\n",
    "        ax.annotate(\n",
    "            f\"{height:.3f}\",\n",
    "            xy=(r.get_x() + r.get_width() / 2, height),\n",
    "            xytext=(0, 3),  # 3 points vertical offset\n",
    "            textcoords=\"offset points\",\n",
    "            ha=\"center\",\n",
    "            va=\"bottom\",\n",
    "        )\n",
    "\n",
    "\n",
    "for r in rects:\n",
    "    autolabel(r)\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save files for download\n",
    "# png_path = \"/mnt/data/roc_auc_barplot.png\"\n",
    "pdf_path = \"../resources/pics/roc_auc_barplot.pdf\"\n",
    "# svg_path = \"/mnt/data/roc_auc_barplot.svg\"\n",
    "# fig.savefig(png_path, dpi=300, bbox_inches=\"tight\")\n",
    "fig.savefig(pdf_path, bbox_inches=\"tight\")\n",
    "# fig.savefig(svg_path, bbox_inches=\"tight\")\n",
    "\n",
    "plt.show()\n",
    "\n",
    "# png_path, pdf_path, svg_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0502163",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7fb27b941602401d91542211134fc71a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "multidimensional-uncertainty",
   "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.12.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
