{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tutorial to evaluate models\n",
    "\n",
    "In this tutorial we present two ways to evaluate your models. "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evaluating from a list of model predictions CSVs\n",
    "\n",
    "The first option is to save the model predictions as a CSV and compute the factor accuracies and error ratios directly from those to easily compare them. Model predictions should be stored as a CSV with 3 columns, file_name, predicted_class and predicted_probability. (See next cell)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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>predicted_class</th>\n",
       "      <th>predicted_probability</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>file_name</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>ILSVRC2012_val_00000293.JPEG</th>\n",
       "      <td>0</td>\n",
       "      <td>0.634764</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ILSVRC2012_val_00002138.JPEG</th>\n",
       "      <td>391</td>\n",
       "      <td>0.360206</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ILSVRC2012_val_00003014.JPEG</th>\n",
       "      <td>0</td>\n",
       "      <td>0.951837</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ILSVRC2012_val_00006697.JPEG</th>\n",
       "      <td>0</td>\n",
       "      <td>0.999731</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ILSVRC2012_val_00007197.JPEG</th>\n",
       "      <td>0</td>\n",
       "      <td>0.998473</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                              predicted_class  predicted_probability\n",
       "file_name                                                           \n",
       "ILSVRC2012_val_00000293.JPEG                0               0.634764\n",
       "ILSVRC2012_val_00002138.JPEG              391               0.360206\n",
       "ILSVRC2012_val_00003014.JPEG                0               0.951837\n",
       "ILSVRC2012_val_00006697.JPEG                0               0.999731\n",
       "ILSVRC2012_val_00007197.JPEG                0               0.998473"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from imagenet_x import load_model_predictions\n",
    "\n",
    "\n",
    "models_predictions, top_1_accs = load_model_predictions('../model_predictions/base')\n",
    "\n",
    "models_predictions['DINO'].head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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>pose</th>\n",
       "      <th>background</th>\n",
       "      <th>pattern</th>\n",
       "      <th>color</th>\n",
       "      <th>smaller</th>\n",
       "      <th>shape</th>\n",
       "      <th>partial_view</th>\n",
       "      <th>subcategory</th>\n",
       "      <th>texture</th>\n",
       "      <th>larger</th>\n",
       "      <th>darker</th>\n",
       "      <th>object_blocking</th>\n",
       "      <th>person_blocking</th>\n",
       "      <th>style</th>\n",
       "      <th>brighter</th>\n",
       "      <th>multiple_objects</th>\n",
       "      <th>worst_factor</th>\n",
       "      <th>average</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>model</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>DINO</th>\n",
       "      <td>0.821561</td>\n",
       "      <td>0.737577</td>\n",
       "      <td>0.772103</td>\n",
       "      <td>0.710569</td>\n",
       "      <td>0.620690</td>\n",
       "      <td>0.596465</td>\n",
       "      <td>0.722571</td>\n",
       "      <td>0.519658</td>\n",
       "      <td>0.471631</td>\n",
       "      <td>0.693333</td>\n",
       "      <td>0.639344</td>\n",
       "      <td>0.525641</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.581395</td>\n",
       "      <td>0.772727</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.471631</td>\n",
       "      <td>0.754283</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ResNet50</th>\n",
       "      <td>0.824018</td>\n",
       "      <td>0.710799</td>\n",
       "      <td>0.804588</td>\n",
       "      <td>0.698862</td>\n",
       "      <td>0.620690</td>\n",
       "      <td>0.558174</td>\n",
       "      <td>0.713166</td>\n",
       "      <td>0.466667</td>\n",
       "      <td>0.393617</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.565574</td>\n",
       "      <td>0.512821</td>\n",
       "      <td>0.450000</td>\n",
       "      <td>0.511628</td>\n",
       "      <td>0.704545</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.393617</td>\n",
       "      <td>0.746693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SimCLR</th>\n",
       "      <td>0.739976</td>\n",
       "      <td>0.634940</td>\n",
       "      <td>0.693905</td>\n",
       "      <td>0.623902</td>\n",
       "      <td>0.482069</td>\n",
       "      <td>0.505155</td>\n",
       "      <td>0.659875</td>\n",
       "      <td>0.456410</td>\n",
       "      <td>0.308511</td>\n",
       "      <td>0.660000</td>\n",
       "      <td>0.622951</td>\n",
       "      <td>0.410256</td>\n",
       "      <td>0.316667</td>\n",
       "      <td>0.604651</td>\n",
       "      <td>0.704545</td>\n",
       "      <td>0.600</td>\n",
       "      <td>0.308511</td>\n",
       "      <td>0.664064</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ViT</th>\n",
       "      <td>0.827868</td>\n",
       "      <td>0.746458</td>\n",
       "      <td>0.799565</td>\n",
       "      <td>0.732358</td>\n",
       "      <td>0.617931</td>\n",
       "      <td>0.642121</td>\n",
       "      <td>0.786834</td>\n",
       "      <td>0.531624</td>\n",
       "      <td>0.524823</td>\n",
       "      <td>0.700000</td>\n",
       "      <td>0.573770</td>\n",
       "      <td>0.538462</td>\n",
       "      <td>0.550000</td>\n",
       "      <td>0.627907</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.625</td>\n",
       "      <td>0.524823</td>\n",
       "      <td>0.767599</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              pose  background   pattern     color   smaller     shape  \\\n",
       "model                                                                    \n",
       "DINO      0.821561    0.737577  0.772103  0.710569  0.620690  0.596465   \n",
       "ResNet50  0.824018    0.710799  0.804588  0.698862  0.620690  0.558174   \n",
       "SimCLR    0.739976    0.634940  0.693905  0.623902  0.482069  0.505155   \n",
       "ViT       0.827868    0.746458  0.799565  0.732358  0.617931  0.642121   \n",
       "\n",
       "          partial_view  subcategory   texture    larger    darker  \\\n",
       "model                                                               \n",
       "DINO          0.722571     0.519658  0.471631  0.693333  0.639344   \n",
       "ResNet50      0.713166     0.466667  0.393617  0.666667  0.565574   \n",
       "SimCLR        0.659875     0.456410  0.308511  0.660000  0.622951   \n",
       "ViT           0.786834     0.531624  0.524823  0.700000  0.573770   \n",
       "\n",
       "          object_blocking  person_blocking     style  brighter  \\\n",
       "model                                                            \n",
       "DINO             0.525641         0.500000  0.581395  0.772727   \n",
       "ResNet50         0.512821         0.450000  0.511628  0.704545   \n",
       "SimCLR           0.410256         0.316667  0.604651  0.704545   \n",
       "ViT              0.538462         0.550000  0.627907  0.818182   \n",
       "\n",
       "          multiple_objects  worst_factor   average  \n",
       "model                                               \n",
       "DINO                 0.650      0.471631  0.754283  \n",
       "ResNet50             0.500      0.393617  0.746693  \n",
       "SimCLR               0.600      0.308511  0.664064  \n",
       "ViT                  0.625      0.524823  0.767599  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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>pose</th>\n",
       "      <th>background</th>\n",
       "      <th>pattern</th>\n",
       "      <th>color</th>\n",
       "      <th>smaller</th>\n",
       "      <th>shape</th>\n",
       "      <th>partial_view</th>\n",
       "      <th>subcategory</th>\n",
       "      <th>texture</th>\n",
       "      <th>larger</th>\n",
       "      <th>darker</th>\n",
       "      <th>object_blocking</th>\n",
       "      <th>person_blocking</th>\n",
       "      <th>style</th>\n",
       "      <th>brighter</th>\n",
       "      <th>multiple_objects</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>model</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>DINO</th>\n",
       "      <td>0.726197</td>\n",
       "      <td>1.067989</td>\n",
       "      <td>0.927478</td>\n",
       "      <td>1.177905</td>\n",
       "      <td>1.543689</td>\n",
       "      <td>1.642275</td>\n",
       "      <td>1.129062</td>\n",
       "      <td>1.954860</td>\n",
       "      <td>2.150316</td>\n",
       "      <td>1.248049</td>\n",
       "      <td>1.467770</td>\n",
       "      <td>1.930511</td>\n",
       "      <td>2.034863</td>\n",
       "      <td>1.703606</td>\n",
       "      <td>0.924938</td>\n",
       "      <td>1.424404</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ResNet50</th>\n",
       "      <td>0.694739</td>\n",
       "      <td>1.141699</td>\n",
       "      <td>0.771442</td>\n",
       "      <td>1.188826</td>\n",
       "      <td>1.497432</td>\n",
       "      <td>1.744230</td>\n",
       "      <td>1.132355</td>\n",
       "      <td>2.105479</td>\n",
       "      <td>2.393863</td>\n",
       "      <td>1.315925</td>\n",
       "      <td>1.715017</td>\n",
       "      <td>1.923274</td>\n",
       "      <td>2.171276</td>\n",
       "      <td>1.927983</td>\n",
       "      <td>1.166388</td>\n",
       "      <td>1.973887</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SimCLR</th>\n",
       "      <td>0.774029</td>\n",
       "      <td>1.086696</td>\n",
       "      <td>0.911171</td>\n",
       "      <td>1.119552</td>\n",
       "      <td>1.541756</td>\n",
       "      <td>1.473035</td>\n",
       "      <td>1.012471</td>\n",
       "      <td>1.618136</td>\n",
       "      <td>2.058397</td>\n",
       "      <td>1.012098</td>\n",
       "      <td>1.122385</td>\n",
       "      <td>1.755525</td>\n",
       "      <td>2.034119</td>\n",
       "      <td>1.176858</td>\n",
       "      <td>0.879497</td>\n",
       "      <td>1.190704</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ViT</th>\n",
       "      <td>0.740670</td>\n",
       "      <td>1.090969</td>\n",
       "      <td>0.862456</td>\n",
       "      <td>1.151641</td>\n",
       "      <td>1.644009</td>\n",
       "      <td>1.539923</td>\n",
       "      <td>0.917235</td>\n",
       "      <td>2.015381</td>\n",
       "      <td>2.044646</td>\n",
       "      <td>1.290873</td>\n",
       "      <td>1.834028</td>\n",
       "      <td>1.985959</td>\n",
       "      <td>1.936310</td>\n",
       "      <td>1.601083</td>\n",
       "      <td>0.782348</td>\n",
       "      <td>1.613592</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              pose  background   pattern     color   smaller     shape  \\\n",
       "model                                                                    \n",
       "DINO      0.726197    1.067989  0.927478  1.177905  1.543689  1.642275   \n",
       "ResNet50  0.694739    1.141699  0.771442  1.188826  1.497432  1.744230   \n",
       "SimCLR    0.774029    1.086696  0.911171  1.119552  1.541756  1.473035   \n",
       "ViT       0.740670    1.090969  0.862456  1.151641  1.644009  1.539923   \n",
       "\n",
       "          partial_view  subcategory   texture    larger    darker  \\\n",
       "model                                                               \n",
       "DINO          1.129062     1.954860  2.150316  1.248049  1.467770   \n",
       "ResNet50      1.132355     2.105479  2.393863  1.315925  1.715017   \n",
       "SimCLR        1.012471     1.618136  2.058397  1.012098  1.122385   \n",
       "ViT           0.917235     2.015381  2.044646  1.290873  1.834028   \n",
       "\n",
       "          object_blocking  person_blocking     style  brighter  \\\n",
       "model                                                            \n",
       "DINO             1.930511         2.034863  1.703606  0.924938   \n",
       "ResNet50         1.923274         2.171276  1.927983  1.166388   \n",
       "SimCLR           1.755525         2.034119  1.176858  0.879497   \n",
       "ViT              1.985959         1.936310  1.601083  0.782348   \n",
       "\n",
       "          multiple_objects  \n",
       "model                       \n",
       "DINO              1.424404  \n",
       "ResNet50          1.973887  \n",
       "SimCLR            1.190704  \n",
       "ViT               1.613592  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from imagenet_x import get_factor_accuracies, error_ratio\n",
    "\n",
    "factor_accs = get_factor_accuracies('../model_predictions/base')\n",
    "error_ratio = error_ratio(factor_accs)\n",
    "\n",
    "display(factor_accs)\n",
    "display(error_ratio)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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o1NW5ziO4zhOGriBnEcsW7aMZ599lqFDhwIwYsQIrrrqKqZMmcKYMWM48sgjATj33HN58skneffdd5k4cWKlY4waNYrzzz+/0rolS5YwcuRI7r//fqZMmcJBBx3EqFGj2H333RkwYADjx49n6tSpNG/evPwYffv25bjjjmPRokUAfP/993Tr1q38mF27di035BsyK6ywAuuvvz6PP/44YN7jPffcE5EqJ9ZxHMdxHOdPgBvIecCCBQsoLS2lc+fO/PzzzwwePJi5c+fy2muvsccee1BaWsphhx1W7rHdaKONGD58ODfeeCPLli2rdKzIo/zKK6+Ur/v000/54IMPGDx4MKWlpZx//vl89913VWr597//zSeffMJbb73Fr7/+yoUXXpjQWecPUZgFmIG89957p6zIcRzHcZw0cQM5D4hikL/++mtUlWuuuYaysjLatm3L1KlTy/8+/vhjAMaOHcv555/Pt99+S//+/ZkxY0al42V6kVWVXr16lR/n/fff56mnnqpSy0orrYSIUFxczIEHHsibb74JQJcuXfj222/L9/vuu+/o0qVLti9FKuy00048++yzvP3228yfP5/+/funLclxHMdxnBRxAzmPKCkp4corr+SSSy6hpKSEnj17ct999wFm5L777ruAxSYPHDiQc889l44dO1YyXAG23nprZs6cyXvvvQfAmmuuyS+//MKkSZMAC7n48MMPAWjVqhVz5swp/27kpVZVJkyYQO/evQEYOnQot99+O6rK66+/Tps2bVhppZUSvBq5o2XLlmy++eYcdNBB7j12HMdxHMcN5HxjnXXWoW/fvtx9992MHz+ecePG0a9fP3r16sXDDz8MwEknnUSfPn3o3bs3G264If369fvdcUaNGlVuODdt2pT777+fU045hX79+lFaWsprr70GWFq3ww8/vHyQ3rBhw+jTpw99+vRh+vTpnH766QBsv/32rLrqqqy22moceuihXHvttTm6Irlh77335t1333UD2XEcx3EcRFXT1pBVBgwYoJMnT05bhuM4juM4jlMPUppJr8pR+fXOgywirYGtgFXDqi+Bp1V1TvXfchzHcRzHcZyGQb0MZBE5BLgEaEmFxa3AXBE5XlXHZVmf4ziO4ziO4+SUOhvIIjIUuAHzGJ8BfBg29QJGAjeIyDRVfaSaQziO4ziO4zhO3lMfD/LJwMfAQFWdG1v/rIjcArwOnAI0WAN58Vef0rTHmmnLcBzHcRzHySopxfc2WOpjIPcDzs0wjgFQ1TkichvmWW6QzH3i/5j75H2UbLwdrXc9OG05juM4juM4jYo+g4fWuL3lkIE5UlI79UnzVtvcuw02HcbcZx9i8ZcfI82as2zWDOZMvD1tSY7jOI7jOE5K1MdAfhcYLiItMjeISEtgeNinwdGs13q0O+RUpLCQtsNPoNmATdKW5DiO4ziO46REfUIsLgYeBN4WkSuBj8L6aJDeasCu2ZWXG4o6dy3/LAWFNFm5R3piHMdxHMdpUNQW3wse49vQqLOBrKoTRORo4ELgKipCKgSYBxytqg9nX6LjOI7jOI7j5I565UFW1WtF5C5gMNAzrI4mCpmdbXGO4ziO4ziOk2vqPZOeqs4C7su+lPRpZLNuO47jOI7jNBo+e67mMJU1tqg91KWu1NtAzhYi0g24HVgRC9e4QVWvyNhHgCuA7YH5wHBVfTspTU17rpXUoR3HcRzHcZwE+Xb8ibXu023YmDodq1oDWUSewwzXbVR1aViuDVXVLev0y7AUOEFV3xaRVsAUEXlaVT+K7bMdsHr4GwhcF/4nQrtD/pnUoR3HcRzHcRJjeXMM1+adhex6aPOdmjzIqwJlVOQ/XpUs5jpW1R+BH8PnOSLyMdCFiuwYADsBt6uqAq+LSFsRWSl813Ecx3Ecp1FQm/ezrp5PJztUayCrao+alrOJiPQA1gHeyNjUBfg2tvxdWFfJQBaREcAIgG7duvHTTz+Vb2vfvj0AM2bMKF/XokULWrVqxbRp0ygrKwOgqKiIDh06MHv2bBYsWFC+b8eOHVmyZAmzZs0qX9e6dWtKSkoq/U5xcTHt2rVj5syZLFq0qHx9586dmT9/Pr/99lv5urZt29KkSRN++eWX8nXNmzenTZs2TJ8+naVLlwJQUFBAp06dmDNnDvPmzfNz8nPyc/Jz8nPyc/JzytNzqo24/qrOqT7fr+qcckGkYXnvU5pMnz690rPXuXPnKvcTTXlkWphk5EVgtKo+mLHtUeACVX0lLD8LnKKqk6s73oABA3Ty5Go3O47jOI7zJyNp72w28iAvr8blDbG4re/8GrfD8odYJK2x+Y+1G+FVXMcqZ4qu8yA9EVkG7Keqd1WzfS/gLlUtrMcxmwAPAOMzjePA90C32HLXsC6rzLp1DG2Hn1jrOsdxnD8LtVX4PumB4ziNmfpksajSwq7H9so7W4aKccDHqnppNbtNBI4WkXuwwXmzk4g/Xjr994dc+nPW7XDHcRzHcRogy+v5dBoe2Uzztgowpx77bwTsB7wvIlPDutPCcVDVscB/sBRv/8XSvB2YLbEA8yc9zfzXnmLZtB+ZcenJ5evLFsynqNPK2fwpx3Ecx3GqoDbjE+D9pyfmQIlTG3+mgYQ1GsgishOWSSJihIhsVcWuKwBbAa/U9YdDXHGNXueQveKouh6zvhSv2Y/CDisx54EbaTX0gPL10qw5RSt3T+pnHcdxHCdvaAjhNA1Bo9O4qM2DXAoMD58V2CT8ZTIXeA04OlvCckHhCp0oXKETxf+smJ9Ely6hbP5cpKDOodSO4ziO4zhOI6Kgpo2qeo6qFqhqAebt3Tdazvhrrapbq+p/cyM7u8y67RLKFsxDFy9i+oXHMv2CfzDvuQlpy3Icx3Ecx3FSoEYDOYOewISEdKTK0mk/UNC8BYs+mkLT1fvQ6ewbWfDWi2nLchzHcRzHcVKgzoP0VPXrJIWkyjJLEr74iw8pXntdpGkxSL2ScjiO4ziO4ziNhHplsRCRdsDBWMq1dvzeA62qumWWtOWMos7d+HXseSz9+Tta7rAfujg/ZntxHMdxHMdxck99JgrpDrwKrAzMBloDv1JhKE8H5lV7gDymzT4jWfTJVIq69KCguBnLZs2g1Y77pi3LcRynWv5M6ZYcx3FyTX1ikM8H2gJbAqtjg/b2wgzlf2M5kDfOsr6cUbxWKYWt2qKLF1FQ0pKmf+mVtiTHcRzHcRwnBeoTYrElcKOqPi8i7cM6UdX5wCgR6QVcCAzLtsik+fmUfTB7X4mnZu582f1pSXIcx3Ecx3FSoj4Gcnvgg/B5SfjfPLb9aeCsbIjKNZ0ve6D8sy5ZzIIpL1M277cUFTmO4ziO4zhpUZ8Qi1+wGfPAwikWAj1i25tS2WBukEiTppRssCULp76WthTHcRzHcRwnBerjQf4Q6AeWqkJE3gSOFJGJmKE9Avgk+xKTJ561QrWMJd/8F10wP0VFjuM4TmPAp0jODZ89V/N1bPDeOyfn1MdAfhg4QUSaq+oC4FzgSeB/YbsCu2ZZX06oFIMsBRR2XInWux6ctizHcRzHcRwnBeozUci1wLWx5edEZBCwD7AMeEhVG2RcQjwG2XEcJ2ncq+g4jpPf1MlAFpFCoAswV1V/jdar6mRgckLacsqSH79m8X8/BKB49T4Ude6WsiLHcRzHWT76DB5a6z4thwzMgRLHaVjUdZBeE+BLbBa9Rse8lx9n5tjzWPrD1yz94Wt+ve4c5r/yRNqyHMdxHMdxnBSokwdZVReKSIOdKa825r/0KO1PHENhq7YAlM2dzYwrTqPkb9umK8xxHMdxHMfJOfVJ8/YfYIekhKSJNCspN44BClq2QZqVpCfIcRzHcRzHSY36ZLE4GXhaRG4DxgCfq+rCZGTlhqU/fQtA8Rr9mH3PNTQfuBUAC958juK1SlNU5jiO4yTNt+NPrHF7t2Fjaj1GbTG+Ht/rOA2T+hjI07BUbv2AfQFEJHMfVdX6HDNVZt5QeST54s/er1gQodWQBjdrtuM4juM4jrOc1MeYvR0zkBsNHc8cm7YEx3GcRklt3lmom4fWcRoLPplJw6I+eZCHJ6gjdZb+9C2LPv8AgOI1+lC0YteUFTmO4zhO/pONUBXHyTcaTDhEkix46wXmPHonxX9dF4B5zzxAqx33o/mATVNW5jiO4ziO4+QaN5CBec8/TPsTLqawdTsAlv02k5ljz3UD2XEcx3Ec509IagayiNyMpY2bpqq9q9i+GfAw8L+w6kFVPTcpPZFxnPnZcRzHSYfaMkS8//TEGrd7zKfjOH+UND3ItwJXY4P/quNlVU0893Jhh87MefweSjbcGoAFk56msP2KSf+s4ziO49SIx/c6TjqkZiCr6ksi0iOt34/Teo/DmPPgOKZfdBwgFK/Rl9Z7Hp62LMdxHMdxHCcF8j0GeZCIvAv8AJyoqh9WtZOIjABGAHTr1o2ffvqpfFv79u0BmDFjRvm6Fi1a0KpVK6ZNm0bZ0qXw6n8oGnIAKx7QgdmzZ7NgwQIWzlsI836iY8eOLFmyhFmzZpV/v3Xr1pSUlFT6neLiYtq1a8fMmTNZtGhR+frOnTszf/58fvvtt/J1bdu2pUmTJvzyyy/l65o3b06bNm2YPn06S5cuBaCgoIBOnToxZ84c5s2rmOW71nMqKwOgqKiIDh0qzinCz8nPyc8p3XOqjYULF9bpnGpiyZIly3VOtfHTTz/VeJ/qwuzZs2u8T7Ux6PLRNW6/rW+dZFRL/P5V9+wtL3W5TzWxcOHCWp+95WV579OcOXNqfPbygZ9++qnWMiJt4ve0qnIvX6hLWZ4m06dPr1TuVVde1clAFpGWwLvAVap6efZk1sjbQHdVnSsi2wMTgNWr2lFVbwBuABgwYIBWdbJVrevUqRMAM779jPYdOgDQpk0b2rRpU2m/wsLCKr9f1bp27X4fv1xSUkJJye+nrq7q+x2CjjitWrWiVatWdfp+dE5x/Jz8nOryfT+n9M4pk2bNmlX7/eicvq3lGE2aNFmuc6qN+LHrck5VEf1mdfcpbTKvX3XP3vJQ232q7T43a9aszs/eH6W2+zSrlu9H97K6Zy8fiF+v6sqItEn6PmeLP1ru5YoONdh7cepkIAcjtT0wNyvq6vabv8U+/0dErhWRDqo6Pdu/Vbx2f+Y9N4Fm621GQXHFsA1pWpztn3Ic50+ATz/s1BUfSOg4+Ul9QixeBwYANyWkpRIi0hn4WVVVRNYHCoAZtXztDzH3yXsBmPPIHYBgEwYKnS+7P4mfcxzHcRzHcfKY+hjI/wSeE5E3gFtVdbmmnRaRu4HNgA4i8h1wFtAEQFXHArsDR4jIUmAB8Pfl/c3q6HzZA0kc1nEcx3Ecx2mA1MdAvhSYiXmQLxKRL4D5Gfuoqm5Zl4Op6t61bL8aSwPnOI7jZBkPA3Ecx6me+hjIq2KxB9+EZU8U7DiO4ziO4zQ66mwgq2qPBHU4juM4juM4Tl5QkLYAx3Ecx3Ecx8kn6j1RiIi0BrbCQi4AvgSeVtXas4XnKfOen0jzDbakoHkLZt15BUu++S+tdz2Y4rVK05bmOI7jOI7j5Jh6eZBF5BAsb/l9wEXh7z7gOxE5OPvycsOCN5+noHkLFn3+PmVzZtNm76OY89j4tGU5juM4juM4KVBnD7KIDMVmq/sSOAOIpn3uBYwEbhCRaar6SNZVJk2BtRMWf/4BzftvTNOea4HWPsWn4ziO4ziO0/ioT4jFycDHwEBVjc+o96yI3IJNJHIK0OAMZGnSlLnPPMjCt19hhWPOR1UhzDfvOE7DYtDlo2vdZ9KxNc9e5jiO4/y5qU+IRT9sgpDfTTcd4o9vC/s0ONrsM5Ky32bSasf9KGzdjmUzfqZZ/03SluU4juM4juOkQH08yFLL9kRmucsFRZ1WpvWuFkKtS5cgTYtpOXi3lFU5jpMW344/scbt3YaNyZESx3EcJw3q40F+FxguIi0yN4hIS2B42KfBMeu2SyhbMA9dvIjpFx7L9Av+wbznJqQty3Ecx3Ecx0mB+niQLwYeBN4WkSuBj8L6aJDeasCu2ZWXG5ZO+4GC5i1YOPU1mq7eh9Y7H8iMy/5Jiy12Tlua4zgZ+BTJjuM4TtLUZya9CSJyNHAhcBUVIRUCzAOOVtWHsy8xByyzAXmLv/iQ4rXXRZoWg9QWUeI4juM4juM0Ruo1UYiqXisidwGDgZ5hdTRRyOxsi8sVRZ278evY81j683e03GE/dPGitCU5juM4juM4KVEnAznEGE8ExqvqOGxykEZDm31GsuiTqRR16UFBcTOWzZpBqx33TVuW4ziO4ziOkwJ1MpBVda6IrAc0yunlpGkxRZ27sfSHrylqvyLSrIQmq6yetizHyUtqyzPsOYb/HHz2XM33uXmOdDiO4yRBfUIspgJ/TUhHqix483nmPvMgLFtKsz7rUzb7V3574EZWOPLstKU1GNxoahzUNgAOfBCc4/zZ8MaQ82ekPgbyWcBDIvKYqj6flKA0mPfio7Q/4SJ+vfJ0AIpW7ELZbzNTVuU4jRPPMew4juPkO/UxkPcFvgGeEZF3gc+A+Rn7qKoenC1xuUIKiygozmgDFxSmI8b5U+OeeMdxHMdJn/oYyMNjn0vDXyYKNDwDuUUrlk77oXyuwAWTX6Swbft0RTn1Znnz47rx6eQLtXVpg3drO47jJEl98iDXZ9a9BkXrXQ5i1h2XsWzaD0w75zCkaTHtDj0tbVmO0yDxeEXHcRynoVOfNG9XAo+raqNK8QZQ1Gll2h93Acum/QgohZ1WRjzEwmmAeHyv4ziO4yw/9Unz9nfg1YT15JTMCUEKV+hoH5YuRVlqM+o5Th7h3lnHcRzHSZ76xCB/BPRISEcq/HzKPljgscbWRstC58vuT0WX03hZ3jhpx3Ecx3GSpz4G8kXAtSJyh6p+trw/LCI3AzsA01S1dxXbBbgC2B7LljFcVd9e3t+N0/myB7J5OMdxHMdxHKcRUB8DeS3gW+B9EXkU+Jyq07ydV8fj3QpcDdxezfbtgNXD30DguvDfcRzHcRzHcRJDVLX2vQARKavDbqqqdR7dJiI9gEer8SBfD7ygqneH5U+BzVT1x5qO2bFjR91ll13qKsHJEg+//06N23fqs07iGu7/z5M1bm/SrVON2zdrv7TG7W1WXq/emjJJWmPh/GU1bm+52gY1bq9NH+S/xtr0Qf5rrE0f5L/G2vRB/musTR/kv8bG8E5D/mv0csdIW+MfKXduuOEGqWq/+hjI3euyn6p+XacDUquB/Chwgaq+EpafBU5R1clV7DsCGAHQokWL/jvvvHP5tv+88HKNGnLxUDfrMYDFixeXLxcXF1NQUMCCBQuyojEbD3WzHgMoKipi/vyKToHCwkKKi4tZtGgRjzz7Qo3f32WbrSqdE0BRURFNmzZl4cKFLPr1/eXSB1Cwcl8KCgpo1qwZixcvZunSivNu3rw5ZWVlLFpUMfCyadOmNZ7TsmUVv1lSUsLSpUtrvE9lP7xXo77i7v1ZsmRJ+XKzZs0AWLhwYfm6Jk2a0KRJExYsWED07qV5TlD5PpWVWTtYRGjevDlLlizxc/Jz8nPyc/Jz8nNqtOd05513Vmkg1ycPcp0N31yjqjcANwAMGDBA77zzzvJt2RgUdV7fzEiSyjT/cVGN22tLrbW8GmvTB8lrHDduXI3ba82+UIs+SD9FmadQcxzHcZw/B1mb/ENESkRk1WwdD/ge6BZb7hrWOY7jOI7jOE5i1Gggi8jikP84Wm4lIhNFpE8Vu++CDdzLFhOB/cXYAJhdW/yx4ziO4ziO4ywvtYVYFFHZiG6KpWa7fHl/WETuBjYDOojId8BZQBMAVR0L/AdL8fZfLFvGgcv7m47jOI7jOI5TG/VJ85ZVVHXvWrYrcFSO5KTK+09PrHH7oMtH50hJ9dSm8c+Axxg7juM4zp+D1AxkJ3ussUXtBnRtA8wcx3Ecx3EcI2uD9BzHcRzHcRynMeAeZCcn1Obldg+34ziO4zj5Ql0M5O1FpHP4XAIosIeIlGbs1z+bwpzs4vGzjuM4juM4daMuBvI+4S/OYdXsW7dp+RzHcRzHcRwnT6nNQN48Jyocx3Ecx3EcJ0+o0UBW1RdzJcRxHMdxHMdx8gHPYuE4juM4juM4MTyLhZMX+CBCx3Ecx3HyBTeQ60DaKcomHTsq0eM7juM4juM4FXiIheM4juM4juPEcA9yFvDwAMdxHMdxnMZDozeQ3396Yo3bB11ec/iE4ziO4ziO8+fCQywcx3Ecx3EcJ0aj9yDXhg+AcxzHcRzHceK4B9lxHMdxHMdxYriB7DiO4ziO4zgx3EB2HMdxHMdxnBhuIDuO4ziO4zhODFHVtDVkFRH5Bfg6y4ftAEzP8jGzSb7rA9eYLVxjdsh3jfmuD1xjtnCN2cE1Lj/5rg+S0ThdVbfNXNnoDOQkEJHJqjogbR3Vke/6wDVmC9eYHfJdY77rA9eYLVxjdnCNy0++64PcavQQC8dxHMdxHMeJ4Qay4ziO4ziO48RwA7lu3JC2gFrId33gGrOFa8wO+a4x3/WBa8wWrjE7uMblJ9/1QQ41egyy4ziO4ziO48RwD7LjOI7jOI7jxHAD2XEcx3Ecx3FiuIHsZA0RKUxbQ10QEX/ulxMRkbQ11Ibf5+VDDH+nnbygodzjhqLTqR2/kU7WUNVlACKyatpaakJVy6LP+WboiUihiEwUkd8lLc8XRKRA83zwgohIdJ9FpH3aejIJxmdePXtxonusqstEpF3aeqojMkZUtSwy5vPFQAm3uCBzXVp6qkNECvJRV0SkL/Y+d05bU03EdDZPW0sm8QaviBSlqaU68ulZzIuCJB8QkW4i0iRtHVWRTw9MTYjIABF5ADgiXyqpiFjl2UREikXkMoB8MvREpGloZDwFnJi2nuoIxkhrETlTRDZIW09VqKqKSBsRuQE4Id8qg2B8qoisKCIHi0jrtDXFiVXypwFTRGSjlCVVSUznXsDr4R0qq+VrOSHc4jIR6Swiu+epwVSgqmXhWfyriAxMW1MmMX2rishJwBNpa8okXkeLSEsRORHYMEVJVRJzYu0GHJlPzoPIaZBPdXJeGTFpICJtReQ64F7gOhHZKaxP3SiNNITCoYmInCEiW4hIhzzQVpix3A94FnhVVU/Kl0oqdg2XhVUFqroI6CUie8b3SRtVXRw+fg+sKSIHQfr6osZO7P8ewDnYtXw9TW0RVTyP2wMXA/NV9TRVXZqOskqaousXNdaOAUYB7VX1t5S1tRGRDWPLzUTkVOCvwEaq+mp66irI9MqKSCsRGQMcABwce4fygmDQPQNsCvwbGJKuIgiN2y0qFqW5iFwP3AocJiKnicgq6SmsTLjnlwEPASsAzcK7kzrRuxzq6KZh9TxgJyAyRvPGzhKRHUTkJeBw4J9A75QllRNzGmwqIieLSN/IsZFWHZg3Ny5FTgA+VdVBQGvgdBEpzIdWTKQhtOrHAhsAu2MFbaqErtcmwWBvo6rvAi8C64N5Q9NVaMSuYaGIPAM8KCKdgLuBFUWkKK17nfnSi0gfEfkAu89PABeLSOs09UUeJqgUmjI8aBwX7ZeGvojgdYgqo6j7dTbQC5iVlq6ImGckuo5RY+1yoKWqXpSauAraAZuGRvjVwMbAX7DncEsR2VdEjk3D0x09X1IR9lEWvHRNgcVAIbCaqr4X3z/HGn8XphCMzM6q2ht4EhiKXee0KQWeCddzGbAV8KOqDgSmAX8HUnHCVHPv2gIrYg21U4GTgENCOZ4KccdLqAd3wnqq/hbK60eAHcI+qTiLqnAatAOOAc5W1cHYM7mNiPRIQV6kKe55byIi52L2zW/AZcCeoexMpQ78UxrIIrK5iGwSbk5LYKaIPAUosEesAktDW9w70ktEjsYe5KmqOgS4BGgvIvukoC3+MO8FvA/sDVwm1tV+CtBHRNZS1cVptJyr8DB1EZEDwj2djLXqdwLWBYqAZSnprCqOtwvmgT9FVQ8FXgXODfvnrNIXkRKo1EW8toiMFZHDQqV/DLAUaJdm4RURvA4DRORJrFFxBTAFmAAUiUi3tPUFjeuLyBipiC/fF9gmLV0ZFegvmHfzGMxYehord7bEDKoewH7AbrlVCUBTqBRO8W/gUaws7IY5Dz4WkV3D/jk1kKVymMJaIrJu2KTAIBF5GruuB6nqHSLSIpf6MlHVl4AHgevDqmbAeiLyLNYo2kVV3xaRZrnUFS8TRWSr2P0sBjYL/8EabZ9jHtBUiOkcjDmGNsTeoUtF5C/ADODrsE9O6xep8GovCw3JVcK6JcBCYE7Y9d/Yuz0w05jOFbHrGDXKmmON8+nA6sC8NOuXP5WBLCJdQ2E1CuseVswoOR84QVX3UtWvxLohclo4RASDpKOI7IcVYA8Ar2AVFMB3WDjIvpKDmDYRKRKR7UWkfagA2oZrswnmRfwX1lIeoKofA/cBZ0XnkrS+DK1xD1NJWL0C1rLfFPgA+BUzngZhntA2Yf+cVKpSeVBRRxE5T0QGBm9Yd6wQizgZOFREeuWqkBCR7YB/isiKYXkLrDL9H2aM3IZ5ZV8A9gdKqjxQshozBz61wirLCzHv0l7YvX0Au6b9JccxyFV4E48CrsGewX1F5F+qehfWOD8m7JNTjTGv+wlAT+Ba4E7g57DLA6p6kKqeqKrnAy9j71POEOtavz62fCY2wdVmQF/gPKzSfxDYW0Sa5fJ9hvJ3uYWIXBR0XCMWnrIK8BHwuapuraovBONpO0mph00s5n0IcAiwV2jw/ox5tser6h6q+oWIbAmsmQM9PaIGRbiOXUXkdOACYKSInI15E+8FRof9lmD14FYikpMQgeB4iQ9wKxCR3bFetLODU+MmrFH+d+z6bhKdV4409g6/F73X+wOfAFcD/1bVucAPWM9pM1X9DHt3dsXKyZwjItuKyLWYDdEWe+Y+AnYE/qaqD4uFf3mIRQ44CHheVbdS1RfCujOAJkDT4G28FDieHD0w1bQu/w84GjhSVX/EvIhDRaSzWvzsM8CCoDNR1GI3OwD3ichVWEhKZ+xhvgUYjzUurg7nch3WIt0qaW0REgZXxjxMpwL/EZHDMY/x4cCxWAu/B/AlZjz9FTOkEh+sF73gMY2bYhX/2sBh2HV9ANhCRPqEr32HGfQnJ6ktrg8owyrLTcLyOsClqnoh1vB5HmtQXgz0x1r7OSHeuAjLG4jISsBqWNz2SljX5s3AOFX9Engd2BlYI0caNxSRlWKekR3Cpm7AtsCPWOPs27D+cOBMEWmiCcdJV2G0ryEirwCbY+/JPVjDZwMRWS8YLE1FZM+w3ypY2ZSkxgKxQW1jw6obgb4iUhqWFwDfiA2+LAPGqOrXQfcCwuDWJN/nTG+biKyGhcuspaprAyOA9sDfgLeBziJyYGiIPAqspDmIla6mbtkG2ExVZ2HvybXBo/wm8DcRGSQilwBXhXNImr5Am6C3DTARWFNVB2BldktgH6zM2V5EjhAbM9Qa6xHcLAcao16gZcFB1DWUQe9iBmY8a9MY4A5gEdBDRBIvd4Lxvi3QTyyUcKXQWNsKGIjVcSNEZE1sAPguwIEiMgjrneka/nKG2BiHAsyGWVdV9wW+wjzvd6jqAar6TXDYHIX19uacRm8gi3mD+4XFb4GDReQCEblURF7E4teOAg7ECv8iYKiqfpoLfbHKfkep6Ho9AegELBARUdU3gZcInlnMaBqFGaOJkFGZFgEDgE6qegZWKDQBpqnqhqHbsCPWNfczsKuqPpOUtpjGZqH12SO27gysYD8Y2Ag4T1VfA/6DGX1tqfCWHY0Z+IkTr7BF5GBswMldqrob1sLfCiv0r8QMpquAh7Fu5NOS0hUK1/KuTVV9EvMWrycibbEyYudo96Cps9qgshcw4yXRcqSKxsXOInILFUb651glug+wjdqgvCViYT+3YkbKN0lqDLr6Y42dwWF5MObVLMKe0anYYLLtVfU6Eemgqq+E9YclrK2qcRXrAxNVdQdV/Thc33ewa7VD8HZuiZVFZ6nqrqr6XZLenBCq8BOwn4jspaofYUbTmWGXVYEjgMmqurmqThGRXphn7A7gjaS0QXkvVeSh6xJWz8C6rVcO29/HDM5OWI/aWKzMKQWGqOpVCWvsDpXelwGxBsY8wjgRVT0We883AY7DQuYOwUIZ1lfV5xLUGDV2JwJzReRwVZ2NeeAjfe9iPS59sDCQIUHbz1gjZFHQnKjG2PKx2PtxTTDSZ2CDlbeWih5LVdVvMKfG98DMpPQFTU3Ce/0c5mDZGrs+nTFHx0JV/RW4CLhJVR/E7JzNgbOxOnASlY38bGvMbJjvhtV9ZVjDZ9Xg/FuAhXX1FJE7QyN4NPBN6DXIParaKP8wV/0U4HGsgP0X9pIdjXUpbIA9xBNi31kx9rkwQW0S+9wFy/7wIPbA3oq16m7DPHfRfh2xQrhXdcfKgq5SYHhsuT/Wgu8MjAReim07ESv4j8QGDr6DtZ4Lk9BWhdYm4X8HzLBsiRntt2DxYFdhsWGDov0xb2cZsH9S1zDjuAXRfyy26gRg57DuDeCo8Lk51pK+JSyvHp6FwZnHSvB6dgNKw+fumNF+YLi272MVO1jX101J39+qzjtcx5GYV3g7rCdlLOY5PgnzjhRgXvlHMAO6KAca48/8sVihvhZwOtYLBBYCcgPQNCyvTxikFz3LOdBZjBkWPcPy5cDY8LlFbL/1MWPzJ2xMRpX3I4lrGN0vLNb5m/C5FWZwbo4ZAOMxLyjYuIe3o3PK0XXshTUUJ2BxnO3DupuAv4d92gVdHap5jrP+7kTHxIyh7TDv4WjM+J0S3uUWWLjCgLDvAcDPsWM0q+q5zpK+vlidEpWL62COl0FYA6cDVk4/j2UkATPcxmCGVFTm/xV4DKvXV07qOmasWzeUL63C3/3hXeqLlZXHV3GfJwH9E9BXFD8uZi90wsbWPBiexQHhHd4ott9XVJRHJeF5OAb4EFg7AZ2FGcurR88YZi/sEJavwXr8wByWK2PjHY4jR2VjteeQ5o8nckI2KhzMg3hS+LwucAVwWmy/rqFAOybjoRaSqwRWwrysAK3D/22BfcPnO7B44xUxg+UzoG/s+32T0BU7/gjMK70r1hX4JmYcdQvbHwLOCJ+LsNRFV4T1G6dwr5uH/0/HXvxxWMv+oNh+fYC24fM6GcdI1MgDimOfR2OVV6twjadQYRB0x2I8967iGFnVWEXBdV64z3djlX5rzEC5GgtN2BXrzhyHdSsOz8W1i19D4FKs4L+NCiOkL2YEjwjLt4e/ycA/cnyfSzBj7axwPU/EDOLO0XMX3pXnwzv2DqGBlJCebaLfDss7h3t8NWZwnBY0PQmsEttvs/B/BaBVLq4flcvfEioMvUlYDxBYN/FL4fMBmLfsxfB/1QS1FWUsr4b1Rg3FyujJWJgHWE/ku8AWmEPmIaBddeeaZZ3xRtq+2FiGV4HtwroxWFzvWeGdWTm2/yNYo7wgSZ3hvbiHirL4PmDL8PkO4OrweUfMgdAs9iz3C59bAYcCe+XgWVwFuCp8Xj/c9xXC8hDgLqwhtEN4VrtGxwj34M34O5gtfVh5/ErsOt6DjbtYCSuD/h3W/wtrpK8SlneJntWwfDkWwrRCAhrXIdgE4ToehWWlWC2sOwTzejfH6r7JwCZJ3NPlOpe0BWT5pvwLMzL2Cw9QVHCVYJ6HceEhOhjrlh2VI22Rd6Q4/O4VwHuhUDoG60aahHWnN41972LgsaSvW+xz+1CI3QEcE9ZdCdwZPm8IfIHlTjyRDK8NCTYuqtE+AWs1D8Y8OqsDe4QCI/KSnYS1qntUd97Zvs+x5TZYj8ARYXkNzGg6ICw/BpwaPhdhHvy4QZ20UbcB5nmYgMVFEvT9X/h8IXBi+NwZ2JPgEcvF8xiWtw/3bwzmeTgVM+6Kw/YLMKNzzbC8AqHhlOB9Lsj4v2V4py8Oy3tjhuc0rNFxcNC+ItaoPIrQkE/wOh4FlEQ6sRCF9piB904oW9qH6/cqNrDoGcyoixupifWkZehdG/PQXQucHNb1xQZotQ/LE4FTwuc2hMo2IT1DM5Y7hf/F4bptijVwL8PK9A2w8K37w3mcS6yBkaNrWBTe2bOwXpazYtuaA+uFd2UpsFOONBXGnqVmWJk3DHNa3U2Fh31FbGxIaVj+D3BBLq9fTHMLrC4+D+tx3B1zqF0PbBDb74Pw3LYGBmYcI6vvN1a3RnZEV6xePi2sfzVWFm0adG6JhXU9FPT/7j0m1luQZZ0Sfn8C1og9AWvkXErlHuo3qaj/zgJuSON+13g+aQvI0k3ZJBSe52Ct99FYfOTzBMMI63K6PnzuRqzVRHKtesG6BaNWUxcs/ucXKlp1G2LG/NDY94ZFLxzQJSFtmYbIHlh31jrh2kWVVHOsIoi6Q0ZhXYf/ImGPQzW6I49cEdZa3jUs3411b3fEumZeAl7DKqysdx9Vda9jn1enonW/P+blipZHYJ6HzphBPItgAFR1rIS0ro+F9dyFhcg8nLH9a8yQ2gbzyA7KxfWr6hnCPA1lVBgoB2BGwE5h+TCsIN6fWNc1CRl2VBGygRmZ7wJbh+WO4f24FPP2XIMZTf9M+Bo2iX0uCO9D/7D8NOY8eImKHquo92IfzNDbI0l9MW2ZDcnNQ5kyJLw7S4DNw7ZbqGiwbYV5FktyoPFbzAu4eri3j2KDkaPtt1IRLnUflp4RrBF5HdA9854krHedcG0uxwzRbpgzY62M/dbHvIbHZaxPOoRre0IPKhYicyyxHt2wz7nAK+FzdzLKxYR0VVXmXIo5WTpjDcvvwvpR4XkcgvVoPEZGD0HSGrHGWWvMzpmA2Qqnxra3xMrEG7G6ezgZPc9J3+vwGzuH9/iR2LqjsJCkKLznDKz+60oOQuH+0HmkLSBLN2MXrBJdOyx3CRf/Hcwrsg1WQZ1PRiVK8sbIvuG3H8e6slbFBuVEBmd3zNCbhHm5HwoF3V9jx8jaA02GBxAzjK8Jv395WHcKFgP7l7B8EGYkR11ebXNwT1vGfi+6X4OAj6noyjqfil6CgeE6rxdppHJ4SlJxxvGuzRWxhtpr4W+7cL8vJfRWBF3fYKmBAHonfS0z9LbCUnntHT1bmKezd2yfG7FwhuZkxLwnef3C8qrhedyPCg/oy1R4GjphxvAULB/qE2H/axPU2I4QehCW/4J5Og8O97w91kDbi4qwnyFYOMPQsNwiQX2Dq1k/DjOYWmE9Kc/HtjXFeq9+F8OZeU8S1N02/G+GxZ9uj3nDXgVejm0rI8RSEuthS/JZxEKMPsAaOkMww/LecM9bY+V5r9j7/RzWMFoNa2wcm4trGNO7MeY5bIXVKR0wAyoKEYiXhaMifSRvGK+GeREfpSJM4masAfI85gk9kgrHxx3kwHmVeezoPcAcL+Pj5R5mQ5wdPu+PObnuJ+GysQq9ZwL/xXorVsRsnN+AT7GwlKi+Xh/zgCcaklmFPsHih98Iz9+u4V3YJPYs/Cvc/xND+fRPUo4zrvGc0haQxZvzKBVdnEWhEDg6vHxjgQNzpCPTM7sRltrpzti6vTAjuSi2bv9Q0B6ToLb9MG9R5DnaOujYEuviiCYG6IkNcjsg9t1xVI5VTGSgSTh23/AS/a2Kbf/GKoJtMC/JG1TEnV8frmGTjO8k0c0e9xg3xSrNk6hoZByExbhvg/VwvBeu7fFYxbV5Lp7HKnR3xnJjdoitOx5rIA3Guu0mERuwmqCW1YHnousZCs3J4Rm9GbgnbNs4XL/4INrSWMF7BgmFSwVdR4dnqx/WXfkB5tkejTUmWoT391qgT/heMdbQTDSuDgt3moZ554ZgDbMxWBd2G8wI2QKrNO/BDJKDMI/tNeQgpIdY93BY3ij8/v1UxJN3x7zcvcPyL1SEU+yJNUpyMSg0ClMYhnkIn4utH4L1vDTBeivvDTr3yThGzgYMxn5zTSwU6a3wTD6KNR7fCes/IzhdMIP1/AQ0VNWNf3Z0H2PrSrGejKHhfboKcwx1T+G6/SXcx4cxY64D1jtwfmyfEZgh2iUsJ2rAU0XdGsqg+4COsXXrYMZ6ZGg+Ga7rqvH3OkfXsR/mUOkarp9gzoxTgUti+62BlfMPEnMC5utf6gKyfIP+RzCqwgN/cBX75SoUYGh4UEvC54fiDy7mcTgNM6rOrOL7WfPiUGEQRx7ZNcIDPJoKz2Y7rJK/N7ygh2AG3jrZ0lEHnXGj8xrMcOsYvx5YRbUdFgZyChZLGcUbtyL52M7MBtDWWCzV/lgX4VmxbRdQEapyMBZXdzM2OUla70krLF52h4z1x2IDCO8geOhzpOddYNvweRvMC7cZVtHPAHaMPQ93ZXx3s1Ah3J3ENY09c10wo+kfmKemOWbkfYT1WpwSnssbw3VsF/9+Arok4105B2vU3BiuyelYBbQ2FpJyB9Zz0Q3LAnILsGGO7m/cMO6OZSAYiTUWt8KyF7THsn48iA3oWQkz4u4mQY9xFVqjMIWrMM91d6xO6R62t8PCJ6JBUH+hsrGUajcxFn/fNnzuhRmn6xBCf2LPTlYHh/L7MnE1Qvw11rAcGT7HG2OXhescvWNS3fGyqLMHsbCNcC3uwIz0VljD93zMQTQN65UswQy6VwgZX5LUmfG+RPeyKLwLUdhR1LPWCqun74t9J+75TjQ7U2x5Jcx4vz3c1/GxbZuGZ2BUuLbrJ6Epqb/UBWT5xl2H5R68DYuvjHvJctVVsxE2QOI+rCIaFtbfRGXjaVXMUHmA4HUK65McLT4IqzxvwbpohmDdR1GA/7aYR3mPUNjuRmUvd5Kx2pkv3SbhhatUuMc+b4F5R8qoiDOXpHSSYZSEdbtheUW3D8vHhcI00jMEeDq2fzwrQM4GM1ZxHkeGa7sJZrD8H2ZI5SQrRYaeHsB/Y8t7YiEVHbFJND7CPPSrh/c6PoCsF2FQT4L6NsTCZp7GPIobYBXni+Fd3x3z3EQx26eTbDjF7+L+sV6Br6LyBTPkDqUiK8CjVNGDVtV7l0Wd8Yq+ABu4+E24t1OpcBTciXUHd8Qa7C9ihsruKTyLmWEK7TFHyzWx67UhFjoTHwiak5CUujwbmHf771hPwhUZz0tWu7KxnOPx5a2wELiHME97T8xpcBCVPZ/dw/0+D2tsJlZux36zGRZStDfWiD0E87rfgMXLvor1AEVZKo7G6uyvMUfWbkFvEun5SghjLMJyB8yWeRKrU1bAek5vyvheS8zZdTXWwIyuY2I9QbHPReE67klFD+6mWDm5iDAwOaz/G9aTdWoSupL8S11Alm/giuHFjKf4StLgjD8wLcL/M6iIg30rPOQbYt6G57Ewh8cwj3ciOYNDQRkvGPthldBlmKExDstxG2VVODvstxtmPN9KCl5OrCW6OxX5Lk8PBUOPavZfhwxPaA7uczusJbxCKNy/JAzewRogV2PezjWwyv+4jO/nNNNHNedTjA3kuA/z4B6Ssp5xVHjaj6EirnwrrAGUSEqnOujqGgr8IeF+TsS6Mm+mIsvLMKxyPSfH2kaFd3r3sHwU8E5s+/ZU5KveDeuxahvbnmRjN/68/xULpxgb3pl1QhlzYNi+EhZX2T+mO9FMKTVory5MYRrBGEz73a3DOWwU3uvEQ7iwtIGXhM9tw7WLBqreFMq+kZihHoUoPYTVQ7nIT16prMV6gGZjvS1R1ptPsfEM3WL7RZ7awvDMdsPsiiMT0NgRC4k6JrbuDqz3cSDWczUh6PgivB/FWN14ETkIpcAM+DVjy6VYr+k5mP1wAxXxzztiTr87MedblIIzb+OMazz3tAUkcDMPA94Pn3MykQEWeP4K1iodiLXmPgoP0NlYXKxgMZ7XkRH/la1CN1Q28cFWJZg3ZA6x7iEsxnMslkz8r1h851OY12EEFV6UJBsXQ4A1Ysunhmt2I2HaVizg/06slRpPf5er/LuZHuOzg74FhJQ0WDx5PJ9xP8xr8hihKzZf/7AY1dRHD2MxvDMwT/GemHd7PGaQ7pexby7TCK4S3o2ou3g7rHF0PdYwugTzhg7JoaaSUIZEgwInEQY5hXf47LDf8VQe9/AGsYGGOdC5YShP9sEaQK+F9a2w3oqxVGT3uYTYpEgpP4uZYQonYo2RgzP2y0tDmd8Pes2qTsxzGIVFrInN6toJMyYfo2Iw5arhGe2POWUuwAy9nGTPoLJhHL2/G2AG+kgqJuw5COuJjEJqxmPG/QqhPBqCNQSGZVlfvBF5GGbsroeNZXkxpk+wRtpgrKE7HuuhHk8s1j3J5xEL1XoC8xCfhTkB9wjbXsLK68jzfilwaPi8OTkeKJj1c09bQAI3sxjrXkxsEFnst6L0cmdjsX+XYN3V18QeoOOwLsPIY5LkDH3/AN4In0djFdTOQeN9GYXGFVjsZFOs0ooygJwYCrbEWnzhHu0WK2gHUDEByY7Ad+FaNsc87leTw1jooCPTON4/FAbtsLjjX6OXP1yvczP2L4l9zsvKNJ/+sHCKaMT9ppiXKe7VSSP8o114T+IpGCdjce/HhHe7R441rYAZxW3C8nZUVK7bYh732zFjecOwzwDCFK450rgl1mjcJrbuM2DT8HntcA1Hp/3cVaE9HqYwCWus5/zZy8Z5ZPl4fTKWI4fAOOD+8Pk6bLxNFCN7D7F4ZzLCbnJ0Hc7BDM6DsQbvGphxOSS2z43hPN4hNDBj27Kaaq6qehXzUF9ERU/ki8R69TCjNJoISwje2mg5B9ewBdbLMy3UfYdgzqzJVB7IL5iz8JhcaUv83NMW0JD/qDq93CgqUtj0JyS3J5bPmCriWbOkpwUWM/cUFi+1Jebxmohl0hgU23dLYjmCMc/no1jsdlZn1olpWy22HE2vHHVnFYdC4gXMWLodmwSkGDPud0u6UA0aLyQkg8e62MdisV4nZRT2/wKeDZ8HYtPyds44XuKNtMbyF67VLMJ0pPH1KWqKMliMwwzQjuHdOinzXmf5d6ttRGMepnFU5P9uhnl3osGMF5OjfMY1aNwY88INwVI9bRfKmgdj++xKRQq8vGpAUk2Ywp/1XcacFveG8nAzzPA9E3OuNMF6f/pgxvHN2MQQG2AOhXXj1y6pe51Z1mJxvLdhnuu1sG7/qzBP98mYA6kbljGpTaiP4gMus+7Iwnp87gqfW2OxzYNCHbc5YSKS8Px9gfUKNcHSw/6ulypX703QcBbmSS8O7/PDhAF34dr/G+txSTxnfi7/oofW+YOIyKPAx6p6kohEk1f8hMXp9AZuU9Vbc6hnO6wrax1V/UhEumHdnMOwEdk7a7jpIrKyqv4QPnfG4qi/SEhXL8zgnYoVBtdhBdV3WGW6DBv9unXY/01swOWRAKr6YxK6MjS2wQr3zqo6QkQ2AnZT1eNF5GRshPABYd+eWKt6e1V9UkQGqeqkpDU2ZkSkk6pOExFRVRWRAlUtS1lTc8z7tBPWAL5AVW9P6LdEYwWyiKwDfKOqM2LrmmE9RW2AG1X1fyIyHqt4H8s4XqGqLss8btKISHus8l8NC1HpjHnjBwOnq+pV+XBvqyO6brHlvNWaC0RkDawO6Y7dy7FYKN6nmKNgF6xbfX0R2QzrbesM3Kyq9+dYax9sVtCnRGRtYDrW7b8qFhb1H8KkPVg9tAjYRVV/Dt8vADSJ90VEWmP13/lY41GxmOh2qrqriJyJhbCcgxnwXbHen4nYe7M425rqg4iMxsI4D8fCVIZi+cD3wGaTPFxVZ6UmMAnSttAb+h+/Ty/3CGGmqoz9chk7+Ti/zwl9MFZAHJCxb5JxxpmZKV7APNk3h+VSLMY4mjTlByw8ZgTmzd6Byl6BJLzumRrXxrxd22IG/EFhfTNsYMIRVExX/iJhQgP/a9x/mLcpkbAjrAciHv70N2xg221YY7d3xv6rYxXo81gY1UPEZvRK8p2uxznF39vNsDC0TQizaDWEv1yW2fn+F8riSVTkpl4dGyh2WFj+jIrJR1pmfDcXYQDNMA/sFGwcQzTl8blUhC5cgsVJrxK29c/h9YvCCQ/HMmP8I7bt46B5VSyTRhSe2YrKcw+k+l6Heu/dUG/3CNf2MFLK6Z+LvyKc5UJV3xWRJ4D/E5FnsAFxT0TbI2+E5tYD8U9ggohMUNVXRWQQFme1gapOy9CfmGcpOmcR2QJrZb6MdaNfH7ZPFZH3gC1E5HUsg8VxmFE/UlX/l7TWmMbdMSPoFqyRcwrWtXRouIcLReQkKmZlfBkrHM4UkRVU9ddsa3PyB1X9Nonjiohg3dUfAieLSAkW/zpCVSeLyC/AriLyX1VdGLR8DowSkYFYxftahtZ86BYsEJHuWOO8H5Zy7qWUNdWLHJfZqSMiHbCB06+F5aZa4bV8BctKsLaINFfVz0VkMTYBzfVYub1V2Hd++H5U9yXhjc3sFdkSaK2q/WP7FGBjcI4Iq1phY0fWVNVvMGP6dz0GWdJXqdchOr6qjhWRvbGBjRGnYo2LzUTke6CniLRU1TnAnCS92vVBVX8UkTFYiM084ERVfT5NTUnjIRZZQERWxGJ3x6vqzWFdTrs1q9AUTdf7IGFaWVWdHrYl1mUYHVtECrG4rrMIU/Gq6tMickpYvk1VPwzX7grgRVW9LhQMc6NjkXDBEAySsViL+CJVfVREemDekf0IE2dg9/czVX09dCELNpBsnqoenpQ+p3ESfwdFZF1CXDHwM+Ydbo3FRz6gqhdkfPd3ZUsSlfzyErq4twauU9VFaetxqiYW0rQGsC+wEMsgNE5V34nttzGWR/hjtTCZA7GY2cNzUdeJyF+xGNeoju0D/Kqq34vIcCzF3D4h1LFAVReLyInY+JU2WCaX41V1ZoIa4+91ZshUkaouFZFtsdRu26rqdyKyKRbmcayIdIjq6XxFRNYD3tWUQz5ygXuQs4Cq/iwi92Kt6JvTNo4D52P39xpVfQ8qXtgkjOOoYAjGcZGqLgXmishKmGf2k7DrvViM1Roi8iuWtmoCZhgQN46zrbMaI6IjsBTYImgGm9DgfqyVfyYWe7cnFq/2evjOXcDtqnp5NjU6jZvgMa7knVTVt0XkOSzO8GARWRXridpRVX8Skabh8wNh/9+VLflmHAOo6kfYaHcnT8koE2divXhtsNld38nYfQo2ruYcEdkAG5j3j2Bc52LcQH9goIjMwXpZugGFInJc2P6JiKyhqp+Fc1tTVceEHt5WGsaIJFk/x4zjEcDWIvKCql4dti0N/58Qkf2xXufx2LiXG8K2xJ1Yy4uqvpW2hlzhHuQsISLF2OCEceRBd0gmuXrhQmG1FRUZMdpjYQvHYxMZlInIflie1L9jo4wvyuX1EpGhmDf4ExEZjOVg7SMiTYAytYFNK2H5Hhep6nEZ3y/E0hy5V8z5Q4jI5tjAp/eCN25lLLTnEGzU/VZYfPGH2Ajxn7BcvPNTkuw0YkTkDGyCqCFYbvwXVfXBTKdC8Nruh5Xld+dYYyvMCbUmNvvmWSJyJBYP/Q7W49IFG5T3d2yQ6HGq+mXsGFmtB6vwEq8SNLbDMmdcgoU8Pho82pEXuSf2bp+EXesPsqXJyR5uIDdykjKMgydMgsErmCH8LyzlyyVY/tApqnpaKHw7Yx6ymWH/Llgy9C+r/oWsaCyASq36jYK2b7A4uadU9S4ReQ2bSOX2sN8m2KjcNlgIxbcxz5+/ME6dCY2pw4BPVfXZUMnvg1XgN4dtL2G507fFsqZsLyLbY6PEu2MTfoxP5QScRkUVBt1A7Nn7H5YdZQbmRd4UG+j9eeb3sdnbFoblREJ7Muut4NT4CctKcSMwVVVPCNsux+YaeAgz3gdgPTAnquq8bGuLacpsPBRhE4+MAvZRG/8zHIuPPi/m2Y6yy/SODON4fZqUXqf+uIHs1JuMOKuWqjo3GALrYKnPzsCmxJyCFVpPhL+rgPsyCuisxxkH72/7WOHTQlXnBUP9CVV9S0Tewgrb0ViKubuwuLC/Yfkcd4sqhzwJmXEaIKFnqauqfhEqwb2x7Ci3q+qlIe7zGGwq2ycxL/JEVb1CRIrjvRT5GGfsNByqen5E5HhgpqreElu3Fjbb4XQs68PqWLm5JLZPIg6Dqsra0LN3DBYGN0REjsLCK+5U1Q9EZC9sxs0dwv4lUU9LLnpORWQUloHpDeArzDn0g6qeHbbfhmWluVlV51TRSMnbcIo/OwVpC3AaHsFrXCAi/wL+IyIjsZHBkzEvxDxV/Ss2YnhvLLn4tcDizMJPLW4528bnnlioS5S78UkROQTLPjFHRD7C8mG+gU24MAlL4l6IzUTYN+45cePYqQ8i0kZsIA7BwJ0VGmejsJk2XwZWFJE2was0E8tPPh+4EuttAVgSjhf1hLhx7PxhgteynYgcFpwIYBNVdAFzdoT9PsHKx02xlKFL48Zx2CfrYYTBgI9y9LcVkTHBubEEm610nojsg41jaQucEYz5vwMvxt6T+WJkO5yiIGoYhOP3EJEnsdn5VsTyFa+CXbPOYoMawWbuG0rIXFFVHZgtjU52cQ+yU29CCMKJWKv4BWympZWB4ZjH4RZVHS+WSWNFLHzhmRzqa4F5hJtjRvCzQWNXzCvygqreJxYvfTBwuarelHEM99Y59UJE+gHT1NIhXYA9f82whtl8bNKbw7AYz52BN1X1juAB2xCLl/TK0skKIrID8JqGFJTBSfAP7Hlsgg2c/gjr0dgreDcLsSnKXw5G9C9aMXg5F5qLsF69qVj6swmqembQtTVW7+yIhS2cjYWGvKOqoxPWFe81XVlVfxCRAcCpqrpbWH8hsBhLe7c/ZhAfHxxKPVT1qyQ1OtnHPcjOH6E9ljj+XlV9AQtNmBnWXQGcKiKvYp6JE3NpHAOEuLOxmAfk7qDxUmxWr6HAkSLSH5tJ6Q6sxV9O6AJz49ipLwdjIRJgA+32B75Uyz7xOpZk/1hVfRaL9RwlIjdhGWcezYi59LLZ+cMET2dX4Lew3AybiKIvlqFnS2yMxfvY5E13hXjZl4EDgqH6k9qAssIcaV4HeBVogQ1w2wkYJiKrhvL4i7DteCxk7wJg/8g4TuKdiYWSlIlIexG5Drg3eNu7AtPFUpWC1X0HYj0/r2HZkbqF73+VbW1O8rgH2flDSOUptguwvMGzQ+zkFtisY0/G9s95HK+IPA58oHkyDbjTOMnwLn2HDXJahk3vPlNVzwnPXykWZnEBMA3zkH2nquemItxpdEhFik3E0gMejxmbX2FG2zzs2bxCVSeG57IACzEbBDwcL7dzrH1jLA/zicAKwFzgJsyAPwobHzIcM0CP0ZCHN6FxLJmDBDtigwMnAder6iwR6RLWXauqj4b97sWmYZ5FFSGFTsPC8yA7f5RR2Gx9D6vqK6H1/ySAqj4X7SQJzqZUBzJnFNwA+D9VHRnfyQdJOMtD8C6tqaqfYnmzb1fVNcRmGhstIpuq6osh9v0l4DRV3UlEPsRmzVpdM7IFOE5dERsIOlBVXwoe3yaqukQtrdgGWDjF5cDTQD9VHRK+1x4bI3K3qt6B9aZFx0yjTJyG5Zh/DguxWAkbF9IFC91bDUt1+HL8S0nojDV4N8XCop7AvNdPApsGg/ltLIXp7iKyJxaL/DE2eUn5+AGvWxou7kF2/jChu2koNgVpE2Kz9eULUvOMgh5n7NSbzN6QMFDoKWBLtSl438FG2F8iIv/EsqKcjYX8TMZybX8QGpVbYzNwfpfzE3EaBWI5te/EQij2xgy6Z7BxGPOx/MYnY/Hwp2HhPrOxnNsPAOfEDMJUDToRWQF7P2aJzcS4L5b9qKOGCa+S0ikV6deqmwX2cixk4kMs/eK62OyXs7FwkM9U9cVsanLSxQ1k5w8jeTjFdiZhoMnZVDGjYKrCnAZH/LkRSz21EfCWWgrB67GK/QgRWR/zOHXBeumuB9bDDJE7U5LvNCJisbHR83gNNrPde1imlK2xhtkRWFxsVyx0YTUs/ngdYIzm2QQVIVyiEJse+hjgLWKDV5NwamS81+WpFUXkVuAvwDBV/UZ+n3bxUSy/8RuZ5+Be48aBG8jOciEihwFHq81El/eGpxdeTjYQkZ2wSvxuVX08NBafxqbefV5E/g9oFkIpWmPxiAvT1Ow0DuJGYszruRYWY3yCqt4SwicOwbzGF2MpyK5S1YczjpX1+N3lRWxCp2Ox2N7nc/i7I7HexkcwL/HLmIf9OFWdEvZZAWt07IF56U+NhVPkff3n1A8fKe0sL7cCV+b7qHvJmFXPcWpDArHl7UXkXBHpjU2l/l9gPRHpoqo/YxXrxWH3I8J3irG84AtzlQ3AadxEYQBieej/JSLbquUuvhYbGIqqzsAmr2inll/7AeDgMHAPqHAW5KFR97qq7hEZx9muW8JrXZCxbhiW4WM3bBDgv7GBdlFWjzZh1/lYLPK+qnqixvJD5+F1dJaTvDZqnPxHVRep6o15WtCW44axUx+C8aCqqiJSIiJ9gZOwOPbLsBH192GDijYPX3sOKBWRHVT1V1XdKbwfy8An+nCyg4i0w0Lb2gGfYWk1D8SmjG4jIoeHXfsAUSjGdVjc7OrRcfK1TIx5x7Pu1Ii912USJkYJ9McmRzkKG1dzQjB+x2CxxtuEDCELVfW0MIagIN8dQ87y4VksHMdxMggVaAHwL6zy/BY4SVUni+WLPVdVNxWbsnw3EdkFczgM05DyCXwgqJMIbYGeqroXgIjMBDbAQiyuBcaFOPjOWKMOEdkOm1TjlzQE/xGSyk4R3uvzgb+JyP3YzHyfY172o1V1Q4DQKP4AG0OwWGMTpoRwirxsYDjZw1s/juM4GYjNFvkAlov1KiyH8Rqhi/p2YLaIHKmqtwMXYYOjDlXV/wvfjzx3bhw72WY28KmIbBmWX8QM5NbAbZgn+R5V3V5VPwRQ1cdVdWdVnZaK4jwhvNcTsBnvzgR6YD1Cb2Ee5P+F/Q7C3vt1VfUOVZ0QP04+95Y62cMH6TmO42QQPMIPAD3CCPZTsZnHxqmlctsCS63VW8NUvuF7PgjUSZQQyz4KC/e5SFV/E5EJwAWq+nrGvgXBa+oDyKj0XvdW1Y9EZGVsAqn3sMlUzsBmwFuEZah4vbpjOY0fN5Adx3GqQEQeBj5V1ZNFpBtwLvACcJ+qzheRASHkQkKsshshTk4Qm8VtFOYBXRmbtOIoVV0QtvuzWA1SeRbYqLHxm6peHgbV9gyDHv06/slxA9lxHKcKRKQf5iXeTVU/E5GjsYFPZ6vqj+mqc/7sBONuELAgSkPm1E54rycA+6nNAvsQ8ISqXp+xn48f+JPjBrLjOE41iMj5WBzi9sEgaaWqs1KW5TiVCDHvPnCsjkgDmAXWSR8fpOc4jlM91wC/htRaqjYFrtT2JcfJJVHqsrR1NCDOBj4BXlTVfVR1ur/XTibuQXYcx3Ec509FQ5sF1sk9ngfZcRynFjw7heM0Om4ForzIbhw7v8M9yI7jOI7jOI4Tw2OQHcdxHMdxHCeGG8iO4ziO4ziOE8MNZMdxHMdxHMeJ4Qay4ziO4ziO48RwA9lxHMdxHMdxYriB7DiO4ziO4zgx/h/bZvD1k/SJ8AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 720x201.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from imagenet_x import plots\n",
    "\n",
    "plots.set_color_palette()\n",
    "plots.model_comparison(factor_accs.reset_index())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evaluating directly using ImageNetX pytorch dataset\n",
    "\n",
    "To evaluate directly during training, the best option is to use the ImageNetX pytorch dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "534df85ae0a44463b1159601b829d5ed",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating on Imagenet-X:   0%|          | 0/181 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x201.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# imports\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import torch\n",
    "\n",
    "from torchvision.models import ResNet18_Weights, resnet18\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "from imagenet_x.evaluate import ImageNetX, get_vanilla_transform\n",
    "from imagenet_x import FACTORS, plots\n",
    "\n",
    "# Declare dataset\n",
    "imagenet_val_path = '/path/to/imagenet'\n",
    "transforms = get_vanilla_transform()\n",
    "dataset = ImageNetX(imagenet_val_path, transform=transforms)\n",
    "\n",
    "# Load the model\n",
    "model = resnet18(weights=ResNet18_Weights.DEFAULT)\n",
    "device = 0\n",
    "batch_size = 256\n",
    "num_workers = 8\n",
    "\n",
    "# Evaluate model on ImageNetX using simple loop\n",
    "model.eval()\n",
    "model.to(device)\n",
    "loader = torch.utils.data.DataLoader(\n",
    "    dataset,\n",
    "    batch_size=batch_size,\n",
    "    num_workers=num_workers,\n",
    "    pin_memory=True,\n",
    ")\n",
    "\n",
    "correct = 0\n",
    "total = 0\n",
    "with torch.no_grad():\n",
    "    for data, target, annotations in tqdm(loader, desc=\"Evaluating on Imagenet-X\"):\n",
    "        data, target = data.to(device), target.to(device)\n",
    "        output = model(data)\n",
    "        pred = output.argmax(dim=1)\n",
    "        mask = pred.eq(target.view_as(pred))\n",
    "        correct += annotations[mask,:].to(dtype=torch.int).sum(dim=0)\n",
    "        total += annotations.to(dtype=torch.int).sum(dim=0)\n",
    "        \n",
    "# Compute accuracies per factor\n",
    "factor_accs = (correct/total).cpu().detach().numpy()\n",
    "results = pd.DataFrame({'Factor': FACTORS, 'acc': factor_accs}).sort_values('acc', ascending=False)\n",
    "\n",
    "# Compute error ratios per factor\n",
    "results['Error ratio'] = (1 - results['acc']) / (1-(correct.sum()/total.sum()).item())\n",
    "\n",
    "# Plot results\n",
    "plots.plot_bar_plot(results, x='Factor', y='Error ratio')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.6 64-bit",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.6"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "31f2aee4e71d21fbe5cf8b01ff0e069b9275f58929596ceb00d14d90e3e16cd6"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
