{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "177426ae",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "29a2db12",
   "metadata": {},
   "outputs": [],
   "source": [
    "datalist = [307, 45714, 1462, 1504, 40499, 40922, 12, 1497]\n",
    "augs = ['noaug', 'masking', 'shuffling', 'noisemasking', 'scarf', 'rq', \n",
    "        'cutmix', 'binshuffling', 'binsampling']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "id": "981fc585",
   "metadata": {},
   "outputs": [],
   "source": [
    "result = pd.DataFrame(columns=(\n",
    "    \"data_id\", \"aug\", \"p\", \"ris10_train\", \"ris10_test\", \"ris25_train\", \"ris25_test\", \"uinfo_train\", \"uinfo_test\"))\n",
    "i = 0\n",
    "for d in datalist:\n",
    "#     fname = f'/home/SemiTab/bash/results/reproduce_logs/seed=1/0/data={d}..model=mlp..numprep=quantile..catprep=0.npy'\n",
    "    fname = f'/home/invariance/results/reproduce_logs/seed=1/0/data={d}..model=mlp..numprep=quantile..catprep=0.npy'\n",
    "    try:\n",
    "        dt = np.load(fname, allow_pickle=True).item()\n",
    "        for aug in augs:\n",
    "            for p in [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0]:\n",
    "                result.loc[i] = [d, aug, p, \n",
    "                                 dt[f'ris_train_{p}'][aug][1], dt[f'ris_test_{p}'][aug][1],\n",
    "                                 dt[f'ris_train_{p}'][aug][1], dt[f'ris_test_{p}'][aug][1],\n",
    "                                 dt[f'usableinfo_train_{p}'][aug], dt[f'usableinfo_test_{p}'][aug]]\n",
    "                i += 1\n",
    "    except FileNotFoundError:\n",
    "        print(d)\n",
    "        pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "id": "3a5ac435",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzYAAADUCAYAAABOK7ZVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAADLB0lEQVR4nOyddXhURxeH31nfuCsSLMHd3QqlQEuRllL3FlpayteWChXqVKhRFwqUAsWllOLu7q4xCHFZn++PTUJkAwGicN/n2Wd3594799yb/d3MmTlzRkgpUVBQUFBQUFBQUFBQqMyoytsABQUFBQUFBQUFBQWFG0VxbBQUFBQUFBQUFBQUKj2KY6OgoKCgoKCgoKCgUOlRHBsFBQUFBQUFBQUFhUqP4tgoKCgoKCgoKCgoKFR6FMdGQUFBQUFBQUFBQaHSoylvAxQUFBQUFBQUFBTKih07dgRpNJpfgIYonfyVCQew32azPdGiRYsLrna46RybgIAAGRERUSbnysjIwN3dvUzOVRwqkj0VyRaofPbs2LEjQUoZWIYmlQm3qj4rki2g2HMlimOLos8boyL9vUGx50pUJFug5PSp0Wh+CQkJqRcYGJikUqmUBR0rCQ6HQ1y8eLF+XFzcL8Cdrva56RybiIgItm/fXibnWr16NV27di2TcxWHimRPRbIFKp89QogzZWdN2XGr6rMi2QKKPVeiOLYo+rwxKtLfGxR7rkRFsgVKVJ8NFaem8qFSqWRgYGBKXFxcwyL3KUuDFBQUFBQUFBQUFMoZleLUVE6y/25F+i833YiNgoJCxcVqtRITE4Ofnx8Gg4GLFy9itVoBOLp2H9sP7yJdmvAQBlrWbUZk50a5x4aGhiKlJC4uLl+dPj4+uLm5cenSJcxmc255SkoKAFlZWSQlJeU7Jjg4GLVaTUxMTL5yLy8vPDw8SEpKIisrK7dco9EQFBSE2Wzm0qVL+Y4JDAxEq9USFxeHw+HILXd3d8fb25uUlBQSEhJyz6VSqQgJCcFqtXLx4sV8dfn7+6PX67lw4QI2my233Gg04uvrS3p6OqmpqfmOCQsLw263Ex8fn6/c19cXo9FIQkICFoslt1yv1wOQmZlJcnJyvmNCQkIQQhAbG5uv3NvbG3d3dxITEzGZTLnlWq2WwMBATCYTiYmJ+Y4JCgpCo9EQGxuLlJfbD56ennh6epKcnExmZiYACQkJxMfHExwcjMViISEhIV9dAQEB6HQ64uPjsdvtueVubm74+PiQlpZGWlpabrkQgtDQUGw2Gxcu5A/DdvXbAzAYDPj5+ZGVlVXod1HUb+9mo6z0mZCQQEJCAgEBAYo+K7g+c+6NWq1W9FkKCCFaDBw48NLs2bNPAyxatMhz3LhxYVu3bj1yrXU9/vjjVWfOnOkfHx+/x83N7dZ12qSUFfoFVAVWAQeBA8ALV9q/RYsWsqxYtWpVmZ2rOFQkeyqSLVJWPnuA7bIC6K+kX4AE5IIFC6SUUrZp00YC8uFeQ+W4t96Vb7/9du5r3Fvvyod7DZU5x1gsFpmcnJz7Pef122+/SSml7NevX25dH735vnz7rbflp29/JKd9/luhY6Kjo6WUUmo0mnzln3zyiZRSykceeSRfeaNGjaSUUi5fvrxQXXv27JFSShkaGpqv/OWXX5ZSSvnyyy/nKw8NDZVSSrlnz55CdS1fvlxKKWWjRo3ylT/yyCNSSik/+eSTfOUajUZKKWV0dHShuqZPny6llLJ79+75yvv16ydXrVolf/ut8H1JTk6WFoulUPk333wjpZTynnvuyVfepk0bKaWUCxYsKHTMsWPHpJRSenl55St/++23pZRSjhgxIl95rVq1pJRSbtq0qVBdmzZtklJKWatWrXzlI0aMkFJK+fbbb+cr9/LyklJKeezYsUJ1Ffzt5bzuueceKaWUI0eOLHSMi9+eos/r0GdebX489gO5df46OX36dEWfij7LXJ+7d+8+LaXcXt4vQFapUsW0d+/efVLK7QsXLjzSqlWrtGutx2q1bg8MDLQ0b9487ccffzxR3tdV2q/sv5/Lv62QzodZhUUIEQqESil3CiE8gR3AACnlQVf7t2zZUhYVI7xtwXrW7Fyf2+PUpXlHWt3Z8bptq4yxp2VFRbIFKp89QogdUsqWZWdR2dCkSRO5ZMmSQr1y036aTDqmQvsLCb5aLwxqPR5GN9z0RtRqNUaDEYObEaO7Ef+gAPxDAjE5LBxYv4t1h7diF5d7ZtVSRad6bfL1Ll+tR/jC+lNY1sRBmg08Nag7BhDapc519wgvW7aM9u3bAxWjR3jfvn20bt26QvQIA2zcuJFOnTpViB7hJUuW0KRJk3zHFOwRDg8PV/SJU5/+Wm+MWgMeRvdcfRqMBoxubhjcjQQEB+IfGsD2FZtYc3hLPm1qpIoeTTtTvU1kvnoVfVYcfW7cuJH27dtXmBGbktLnnj17Tjdp0iThSvuUBUKIFuPHjz+zceNGj7lz554uOGLz4osvhi1evNgXoH///klffPFFjKt6ZsyY4f3VV18FP/fcc/E//fRT4OrVq48DfP311/5r1qzxzBkReumll8IAvvjii5j4+Hj1PffcUyM6OlofGRmZdf78ed2HH34Y3a9fvzRX56hI7NmzJ6BJkyYRrrZdNRRNCNEc6As0AXyAZGAPsCTb2yxVpJSxQGz25zQhxCEgHOcITiGKGko/unYf6w5lP1QFpGPi3x0rycjMyG3wFHcoPe+Q/PbVm+nQpO01P5hLeig9IyMjd8i4IjyYoeIMpUPFCnXJ+7fKoTIPpV8LWq2WsLCw3O+Bgc7ENenSBKLw/hLwVLlhspqIM18kS5qxCnvhHQEhBSCRBeqxCwebDm3HV7rj4emJh5cnpoRLqN10BBi9ULlpUBk1CL0aIQQZuy5w6L8dbOM46XoTHmYDrVbUxsvLG/dmQfnsz0tISIjLcm9vbwICAgodV/Be5CUoKMhluYeHBx4eHoXK1Wp1kXUFBAS4LHdzc8PNzc3ltqLq8vPzc1luMBiKPCY0NNRluY+PDz4+Prk2BgcHA6DT6YqsK2efguRoviAajabIunJ+ewUxGo0ujxFCFFnXzcL16NMo9GSZskjMSsEkLfkcl0I7F6jDJhys2r2eHsk2PNw98PDywNPbE3NiEmo3LYFu3qiMGlRuGoRWDaDok7LVZ8F7o+iz5Bk5cuSlb775JmTv3r36vOVTp071WblypdeePXsOArRp06butGnTMoYNG5ZSsI6pU6f6DR069NKgQYNSX3jhhernzp3TVK1a1VZwv7yMGTMmrH79+llr1qw5vnXrVmP79u3rl+yVlQ9FOjZCiN7AB4AnsAbYAKRlf68H/CmESAPelFL+Wwa2IoSIAJoBW4raZ+/evYSHh7NgwQL69+9P//792bJlCx+9+T52df4Hrl04WHdoCzs3bMOcZaZ9+3boDXq+/+kHElISiU+6SGxiPB9O+ISHH3+ERx55BH+LB7Xa1svnIC3fvZYTP/zIH/9Nz607OjqasLAwqlevns+B+OSTT3jllVd46aWXmDRpUm55o0aN2Lt3L+vXr6dnz5757NyzZw+NGzemefPm+RyCl19+mfHjx/PBBx/w6aef5paHhoYSExPDoUOHCvVsLF++nB49etCzZ0/27duXW/7II4/w+++/89133/Hqq6/mlms0GqxWK/Hx8YSHh+era/r06dx7773ce++9rFy5Mre8X79+jB49mhkzZvDYY4/lOyY5ORk3N7dCdX3zzTc899xzPPvss8ycOTO3vE2bNmzevJlly5Zx5535M/sdO3aM2rVrU7du3XzO2Ntvv80777zDm2++ycSJE3PLa9WqxfHjx9m5cyft2rXLV9emTZto27YtHTp04MSJE7nlI0aM4Ntvv+Xzzz/n3XffzS338vIiJSWF06dPU6dOnXx1Ffzt5XDPPfcwY8YMfv/9d55//vl8x1gsFjIzMwvdl4qAECIKmJGnqCbwFjA5uzwCOA3cI6VMup5zeAiDyx5hD2Hg0defyf0upcSaZSE9MZWM5DTSk9PISEsnIy2DjMxMtp7a7bJ+s7Ay98jyy9ckBUa0GKUeo9RhlDrchA43jZFkWzpHVdHYhdNZThcm1sqDMF/Q2tgNtYcWlacOtbsWobly/pW8o8TbV2++4VFiBYWClLc+H39jeO53h92BOS2L9KRsbaZk6zMjg7WHXP/btggbS86sz1emliqMZOtS6pw6Velx1xhJsqRyWB2d60Dl1Wcbz+6oPXSoPLSo3LQIlQtvLA+KPhVySEpKUqWkpKhzvgshqF69utVqtRIdHa3Nu29QUJDNzc1NxsTEaCwWS+6PzGg0OoKDg+2pqamqxMREtbe3t93X17cIT/8yer1evvjii3Fjx44Ne/LJJ3N7XVetWuU5ZMiQxJz5MkOGDLm0cuVKz4KOTWJiomr9+vVekydPPqPX62WfPn2Sf//9d7+33nrL5TovOWzevNlz0qRJpwBat26dFRkZmXk1WysDRYaiCSFmAZ9IKbcVebAQrYBXpZSDS8m+vOfywOlgfSClnFNg21PAUwCBgYEtvvvuO7y8vNDpdCQnJ2Oz2di/b7/LHickaIUGK64dWyEFBrQY0KFHQwKp2Fz0SBmljoYRdXHowKpx4B3gi1qtLjQy4O7ujtFoJC0tjYzjiZxLjiEDM+7oqRNaE7eavoVGTHx8fNBoNCQmJuYbsTEYDHh4eJCeno7JZMrN765SqfDz88NmsxUaMcm5L0lJSflGJvR6PZ6enmRlZZGRkZHvmICAAOx2e6EJnp6enuj1elJSUvKNTGi1WtRqNRqNhvT09HzH+Pn5IYQoNCqVc19SU1Pzjf5oNBp8fHywWCyF7ouvr/MeX7p0Kd+ITU5PV859AWfue09PT/z8/LBarbkTy3Pw9vZGq9UWeY8zMzNzR3/A+dDz9/d3eV8K/vZy0Ol0eHl5kZWVxYULF/Ll4vf390dKmTsqNWTIkAoZ6iKEUAPRQBtgBJAopfxYCDEG8JVSvnql44sKFd22YD1Ld6zMpy2NVNG7Rfdramh89s7HLhtgbui599FhpCWnkpacSnpKGumpaaRnpJORmUm6KZNMSyaOK4TmCgk+0h0tGnRSgw4NOrUWg06PXq/HYDBgcDNgcHfD4GXk7NlzbI3eWyj05lqvCUoujHbv3r2sWLGClJQUvL296dGjB40bN77mekqaihQqWsx0soo+r/G3XJQ23THw8PDHSEtNIz0llbSkVOfnbIcoPSuDDFMmWdbCx+ZFSPCVHk5d5uhTo3Pq05CtT3cjRg8jBk93zpw5w+ZzuxV9XoWKpE0oOX0WDEV76aWXwiZMmJA7fOXh4WFPS0vbvX//fn2jRo3ypRb+888/jw8bNiylSZMmdffu3Zv7j/yOO+5IWrx48ckPP/ww8I033qg2atSo2KJCx/LY2kJKucNsNovIyMgGI0aMiJ81a5bf1q1bjzzxxBNVqlevbhk7duwFgPfeey/ozJkzul9++eV83jq+/PJL/9dff72ar6+vDcBqtYqAgADrwYMHD3333Xd+y5Yt85o7d+5pgOHDh4cbDAb5xRdfxNSrV6/+pEmTTrVp0yYLoH79+vXGjx9//qYNRSuOs5Lt9JSFU6MFZgN/FnRqsu34CfgJnA/mwYMLm3R6//Eie5z+984YbDYbmZmZpCenkn4plbTkNDJS0nN7mzKzMsm0ZGHLdO18ZwkL287sRSvVzh5gocdNrcdNa8RNb8TD6I67uzseag889J6cumhid/KZ3IdqBmb2xx6hd1h3eg3udU33J2PXBVKXnsaWbELjY8CrdwTuzVwPlZcVlfFhWJZUNHuugR7ACSnlGSHEXUDX7PI/gNXAFRtORZHTCMjXOGhx7Y2DLs07umyAdWvRierVq0P1oo91OByYTCbGjx/vcrsUEFg9FLPJhMlkIt2ShdmWjNlqxWFxOMezC+Ii9GbJjhXs3LcLvVaHXqvHkOMUGQ0Y3NwwejjnDhm9PTB6u3N40z5W792Qb5R46Y6V+e5bcdi7dy8L5i/AZnc62ykpKSyYvwCg3BtPCiVGhdVnUdrs2qIjQUFBRYZ35WC328nIyOCLL75wuV0K8KsahMlkIstkItmajtlmwWK2IM1AoeAditTn7v17nPrU5dWnU5cGdyNGL3eMXm5Ofa7fx8o96xR9VnLGjh0bN3LkyNzYfSGcP46oqCjzqVOn9ubdNygoyAawZMmS4wVHbACee+65S8OGDUv29vZ2HTftAr1eL0eNGhU7fvz4sCpVqlgAunXrljZ+/PjQ0aNHXwSYNWuW35gxY2ILHjtt2rSAn3/++eT999+f+yuvVq1aw+3btxvq1Klj/vLLL92sViuZmZmq5cuXe/fr1y8ZoG3btmmTJ0/2a9OmTfT27dsNR48eNRbX3opMsdI9CyECgSwpZXp2j9BDgAOYIqW86jDbjSCcv65fgUNSStdPtGJQ1EO1Swvng0ej0eDl5YWXlxdUK7qeonqd9Ghp07AF6elORyjDlEmyOYsYaxJmswVSXVTm4qG6bMdqHLGZeHl54e3ng2eAD1pvA2ovHWovXe48gBwydl1g+9y1l+ONMw20mlublnQud+dG4aZkKPBX9ufg7DlwAHGA6wDrYtLqzhsPA7mRBphKpcLNzQ0vowepWemFtnsZPRj22AMuj7VarZjNZkwmE6bMLDKTM5g2e7rLUWIHEpVQkW7O5FJmMhZpxYKt0NygfBTRANtxZDdatQaNRoNGq0Wj1aDVatHotGj1OS8dWoOOtWvW5jaacuux21i+5L9rbjiVVA91TqdMrWQVsZu3VohOmUpOhdXnjTpHarXa+T/6Cvp84ImHCpVLKbFYLLn6zErLxJScwV8L/i5Snw7pIDkrFXOGFYu0FjmvL5eiOjCO7EGj0aDN1qdTmxq0OqcuNTotWoNTn2tWra5Q+rzVtOnr6+twFTam1WqJiIiwujomLCzMZaiPl5eXw8vL65rbxiNGjLj0xRdf5I4a3X///Snbtm1zb9KkSX1wJg+477778rnoR48e1R05csQ4cODAfK3M/v37J/3666/+33//fXTTpk0z6tSp0zA0NNTSoEGD3NCTjz76KGbIkCE1a9Wq1aBOnTpZtWvXNuWM+rz44othYWFh1ldeeSX/RO1KQLGyogkhtgDPSCl3CSE+BvoDVmCVlHJUqRooREdgHbAPpzMF8LqU8h9X+5d2VrTrGZLP6WlKT093hsAkpbJg6WLXoXEFEBKM6HGX2S9hwEPvjqebB16ensSci2YbxwtlgeqibUTnN+++putSMsaVHZUxK5oQQgfEAA2klPFCiGQppU+e7UlSSl8Xx+WGigYHB7eYPn16wV1KhfT0dJcTea9GfHw8Rw8fwZ6nz0YtVETWjSpycqwrtq3eRAbmQuXu6GnVNf8cL2mXYLbjMNlwmGzYLTYcZjt2i40dCYeKDKMNk77YceR72YQDO3bnZxxXf85I8NS4YdDonS+dHr1eh86gd77c9KiMWtAIEJB8OJ59sUcKPXMahUbhU7f498cjRhC0X6ByXDbQoZJcaChJDyu/bJ3F+d1069ZN0ecNcL3ahHLQpwRsEmmyYTfZcJht2M02HFY7NouNXZcOF6nP0Hz6tOfRZ/arqEQLBerx1no4tal16lOn16E36NEas/Vp0CBVlJg+K6o2oeT0WVGyopUnJpNJCCHQ6/Vy3759+h49ekQdP358//U4ZWXNDWVFyyYS2J39+QGgPZCOc12ZUnVspJTrKZYLcHXKq0c4t6fJywuyk3as/G9FkfHGDz7zCKmpqaQkJpOSkERqUiqpaamkZaQRY0rGYrU6h9VTcHln7MLBWut+0j404W50w83DHQ8vDzx8vPD098Lo64HGW4/KS4dKp87vrN3AULrCTU8fYKeUMic9XrwQIlRKGZudlt3lRMWCoaJl5WDeiDNbErHu7qmaIkJvOtGqa/F1daSIUWIPYeCpd19w5u63OpDZjpHz3Y4027GbrNhNViyZFn5fN5NMVeGGnBY1ATZPMqxZJIokMjEXGj1SSYE7etyFkQSZUqhBZhcOjsWe5PGAZgitCqFWITQCst+FWoVQC9A434VGRfLaExzlHNt1J0kXJjykgZa2mkSdjSB0WOti35+bvVPmGqg0+rzRe1yR9HnsCvp8+t0XkA6JtNhxmO1Ik7PDIkejjmxt2rIsTNo4y6U+NajxthrIsJiIF6mYROHBA61U444Bd2EgXiYVqc8ngpo7E55ka1Co82uU7PeU4ydLRJug6LMic/bsWe2AAQNq2e12IaVkwoQJZyqDU3M1iuvY2AGdECISSJFSnhVCqIDr63Kp5OQ4SDcisCvFG4eEhBSZmhLAbDaTmppKamoqU6ZMcbmPDTvbLEfAgtMBir68TS1VGNA65wKp9MTKxEIJEWzCweqd62nWqSVqT91Vsz/loGSZuam5j8thLgALgIeBj7Pf55eHUaVB48aNbziuvbTnDeWE0QohEDo16NSoPXVF1tN2S13WWPcVXuNH25DOb97tbICZbNgyLKQlpZKSmEJqSgqpKamkpqeSlplOuikDW5rr/3sZwszE/dNx43KmOaNDVzi7Fc7Pp1UXWKc9nC+71TrtYUgF8ZkKlYcWtbszA53KXevMRuehy37XovbQsX3ZJv7bsapEOmXyNpZ37dpVISZuXyOKPq+BMtOnSiAMGlQGDXjri6qGtttd67Nzjj5tDhwmG5Y0E6mJKaQkZesz1dnpmZaZQZopHVtG0fr8fu+MXD0aHXqMUotbtiYva1RHjCqR9dojLrUp33Nk66+wHlXueT57aNnx76YS6zS9CfRZ4YiMjLQcPHjwUHnbUdIU17H5F5gJ+AM549T1yddcVrgWbuShqtfrCQwMJDAwsOh4YzcPRo5+kczMzNwwuIzkNNISnRmhcpMimLKKfhBi4rMvP8ddGvBQGfDUZYfAeXjh5eONj78v3oE+6HyMqL307Fi1hf92lkwjQ6FiIYRwB24Dns5T/DEwUwjxOHAGuKc8bKvIlEQnSEk1wFr07YCca2ebPJ7bC9uK2rTo2wHIboC5adG5afEPdMcf1+tbFDXPUIeGFu1aXQ67TU/nYnpSvmyCV8MuHKzVHmK/NQZHggPHBQcOhwMpHTiQ2cuKy+zPEgs21/Mbdq7gaPwJ3NzdcfP2wM3LPTdbotFoxGg05n7WaDSVfuK2os/ro1LpU6NC7aHD6KHDGOpFMFVd1nMlfTZt3Tx3HnBqejox6cmYzYVHiVxhFw7W6g5xQBeLI8uBI92BdDj16ZASKWQ+bUooUp//7lzJ8YTTuHm44+7tgZune64e874bDAZUKlWl16dC2VJcx+ZxnD0+Vpy58QECgHdKwaZSY8dbz7Jl/0myNBqMNhttGtakxbjvy82ekgiN69mnVz7BA2jUGnr26ZU/IcIVuNKDMLJ6bVLT0kjLSifOEo052epcojUn2aAEN3S4SwOJIr3QELhNOFizcz2NGzZE7a1H7aVHaK8++pMzcdGebEbto7/pJy5WdKSUGTg7NvKWXcKZhUmhlCmJZ4V7syBa0pnIpdVuKINiUT3Ut7XoSqvehW202+3OjJPZzk7Oa8WKFS7rdwiJf0QwKpUKlUqFEAKVUCEcIOyAzYGwATbJrnMHXNchJQnnLmIWMZixXnEug06jxWqzZTfFLnO9E7fLA0Wf5Uul0ecdhW20Wq25zk6ONhctWuSybgcS36qBl3WZrVEVAuzSqU87CKsDbLDrvGt92qWDuNMxmIUVMzakKHrejkFvwGwxU3A+eGXSp0LZUlzH5nkp5Wd5C6SUq4UQL5WCTaXCjreeZd2hM9i1znWWsrRa1h06A289W67OzY2SI+obiTe+4oOwwMM6JwwuJSmF5IuJJCckOYfE01K4mOAq9Ztz1eqJk37EQxrxkHo8tW54GT3x9vTGx9cbb39fdL5uqL11qL31mE+nsmPReiXT2y3GoXWrWDd9MmmXEvD0D6DT0Ieo16lbeZt1U+HeLAj3ZkHZPdTXFiufw7X2UKvVapcrj2/fvr3QelLgXFPqvvvuK5Ytx945UeT8hmcefwpHqgVbsglzciYZyelkpKSTmZZBZmYmJrsFM1bMNiv71edczld0NRp+q6Los/QpD31qtVp8fX3x9b2cV2LdunVFanPYsGHFtuVK+hz+8FPYUy3Yks1kJqWTmexcXiMzLYPMrCzM0oJZWDHZrBxSRyv6VCg2xXVs3gI+c1H+JnDdKZjLki37T+Y6NTnYVSq27D9Ji3KyqaTIiTe+3uH0a3kQ5g2DIzL/tqJGfrRCTVhEFVJSUojOTCbDEguZOF/xZI/66PGQBjykHit2olWJOFys/N4usBdqXwMqN02+tNdFcaulrKysHFq3iv9++BKbzZlWNS3hIv/98CWA0niqgJRED3WPHj1YuHBhocV9e/Qo/iDDleY36KtdHqn2xBlikIOU0plcIcWMPdXC6Sk/ki5cNMAchmu6ppsVRZ+VixvVZ0loE66iz5o+uWUFY0qkQ+LItGJPsWBPNXPur58VfSoUmys6NkKI7tkf1UKIbuT3mWviekm6CkmWxvWlFlV+q1ESDZWiHmK9WnTLV7fNZiMlJYWUlBSSk5NJSUomKSGRlKRkEtNSSU5PLdQ7YxcO1sj9HP8xFg+px0PlhreHJ97e3vj6++EZ5IPO34ja14DGz4DKoFHW+KlErJv8Q26jKQebzc66yT8oDaeblJIYbb7e+Q1CXJ7QrQ12p7UuyuXE7da6qOu4spsPRZ+3FiWhTbgBfaoEag8dag8dhHso+lS4Jq7Wqv81+90A/JanXOJc8Ov50jCqNNDZbFgKjNiAc52Y+JPHCa5Zuxysurko7kNMo9Hg7++Pv7+/q2p45513XJY7hMTsBxcyLmK2WS6P+sSCkAJ3qccDAx7SgKfajQy7ieOq2EIjP2KRms7Nir/Gj0Lpk5aajqtYA2e5ws3KjY42Q8l0ylxt4vatjqLPW4+S0CYo+rwaQogWXbp0SVm9evXxnLIuXbrUXrt2rbeUcsf11unq2C5dutT+448/zhS14OjNwhUdGyllDQAhxGQpZeElfSsRZ0MSCbsYiEN1eeK6cDhQOSR/jnmBlj370P7Rp9G4cH4Uik9JZJm50srSw0c9B4DJZMod9UlJSSEpIYmUhESSk1OIT0/lhDkeqS48IdEuHKy17SPxvTS83b3w8fXFL8AP37AA9IHuztEed22hMLeSzsWvkB+dtaiOB0lizHn8wqqUg1UKtwolNXH7ZqUofaocEnNmJno3t3KwSuFWoaLoc+rmM35frzgWfjHNrAv01FtG9qgT/UDb6ok3Wm9CQoI2OjpaEx4ebouOjtYkJiaWSkN0zZo1x6++V+WnWHFYld2pAdjT3Re58iLV4/ywaDTobDbOBCdi15loediXbSv+5djmddzx2jhC6yjDm+XJlTK95WAwGDAYDEWuNG2323nvvfdcbrMJB3vtp3CkSkjFmQh1B7hJ5zwfL+GGl8EDH09vfPx8uZB8kU3xe53D4DeYxlqZ8+OaujGJ7K9auONBSJjyykg63f8ozXr3RaiKt56SgsK1UhITt29WXOtT4hCCya88x+3DR1G1fqNytFDhZqe89Tl18xm/9xYdrG62OVQAF9LMuvcWHawOcKPOzcCBAxN///13vzfffPPCb7/95jdo0KDE/fv35/YW3H777TXPnz+vN5lMqo4dO6ZOmjTpHMDkyZN93n///TCVSoXD4WDRokXHIyMjLTnHZWZmiv79+9ds1apVxscffxwXHh7eaOXKlUeioqIs4eHhjYYMGXJpxYoV3snJyepPPvnk3LBhw1IA3nzzzeApU6YE+vr62urXr59lNpvF7NmzT9/INZYlxXJshBBeOFM7d8E5BzO3O1tKWa1ULCthXmj+Au+Y3sFkj8ktM6gN3Fa9P9P2LmXQvxlkWQKZ9sZLNO/Wi06PP4tGV/RidwqlR0nE96rV6iuO/Lz48kukpaWRlJRE0qVEEmMTnKM+KcnEZ6RywhyLNAMJ2Qe5yMW/fMca3OIkft6+GL3dUXvqchcmU2cvKpg3yYEy56do3GQmjc5d5EioHyatBoPVRlRsIt5ZWRxsU5VVk37kxPbN9H72RbwCAsvbXAWFW4qi9Kl2WDnmqWPmuNdpccdddBz6kPJ/U6HS8fKsPVWPxqVdcdjxYGyqu9Uu87UEzDaH6t2FByL+3n7O5T+lyBDPzE8HNzl3tfM/9thjiXfddVetN99888KsWbP8FixYcOLdd9/NDVP4/fffz4aGhtrsdju9evWqNX36dO+hQ4emvP/++2HLli07Vr16dWt6erpQ5el4uHTpkrpv3761Bg8enPi///0vwdV5tVqt3Ldv36Hly5e7P/HEEzWGDRuWsmHDBuPUqVMDd+3addDd3V22b98+MiIioniLHVUQijtz/jugCjAOmAo8ALwMzC4lu0qcvjX7AvDVzq+Iy4gjxD2EF5q/QN+afUlq9TLf1v+Qi/OX0OaQHztXL+P41o3c8cpYwus1LGfLb01KYmXpK438qFQqvL298fb2JiIiotCxdrud1NRUkpKSmPzHZJepJs3Cyt8xKyAGdFKDpzTiJY25717SiCdueLp7ovXUcejiSdapDuZbzXmtPIhYrMz5sT51LwET/iL80GVH1KoGmwqarT/N7saexBzZz+SXn6P7o09Tr1O3YmXFU1BQuHFc6dOmApUD9LuPcKRxEDsWz+P0np30GfGSMmdV4aajoFNztfJrISIiwuru7u6YMmWKj6enp7169er55sB88803AXPnzvWz2+0kJiZq9+7dmzF06NCU9u3bpw0bNiyiX79+yYMGDUrJO1rTsWPHqFGjRsU+9dRTSUWd94EHHkgE6Nq1a8b58+f1ACtXrvTs2bNnsp+fnwPg7rvvTtq1a1elijUtrmPTC6gnpbwkhLBLKecLIbYDC4EJpWdeyWJNaUrG8TGkJWfh6WPEWssZcuZr8GVst0853PARvpk7nOaLYjFZApj+9qs06didLk+PQKtX0gpWNm5k5EetVufm9vcQBpdprN3Qc+fQu0lMTCQpKYnEi5dISkriTFoCDsfl7C0qmwrPVDfSVZmFFgq0CwdbLUfofIPXWtlJbv4409qf5f5dmwhIc5DgqeLPZu247b5n8Jj6Bq02nCXGL4sTkVVZMvELjm/bTM8nR+Dm5V3episo3PQUpc9ut91O4M8f0HZTPAdqpBKfoGbam6NpN+g+Wg8YgkqtLm/TFRSuSnFGVVp/sLzRhTRzoeHIIE+9Zf5zHY/cqA333nvvpeeffz7igw8+OJu3fPHixR5z5szx27BhwxF/f3/7k08+WcVkMqkAJk2adG7Dhg3GJUuWeHXr1i3ql19+OdWnT590gHbt2qX9888/Po8//niSuggdGgwGCc6ETna73eU+lZHiOjYqIGe1pnQhhDcQC1Sabpl5u6J5bc4+sqzOP150chavzdkHwIBm4QDUDWzAt0+uZmnjCayd8SsND/ixZ8Mqju/YzB0vv0m1hk3KzX6F66MkMrsUlca6W4tO1K1bt9D+DoeD1NTUXIcn53XggOtVmNNVhZ2mW41Plx4h2u9u/uuRf+TqwJZUNvy6lH3Lp6Ma9z4dN59iR10fTmzfTPSRg/R6+nlqtWhTTlYrKNwaFKnPE0bWLdnOmm9eIWLSP9Q8d5ydjYPZMHMqJ3Zupc+Il5TEHwo3BSN71InOO8cGQK9ROUb2qBNdEvU/9NBDSfHx8doHH3wwOW95cnKy2svLy+7r62uPi4tT//PPP7733nvvJYC9e/fqO3TokNWhQ4esEydOGLZv3+6W49j89ttv5x566KFqgwcPjpg1a9bpopybgnTr1i39gQceqJmUlBTj5uYm58+f71utWrVKFYpW3Jm4e3DOrwFYhzM07XvgaGkYVRp8uvRIrlOTQ5bVzqdL8zvaQghub/sSY99dRsbdanxN0ciUVP5+7w2WfP4hFlNWWZqtUAFodWdHerfojgcGkOCBgd4tuheZOEClUuHj40PNmjVp0aIFPXv2ZMiQIXgZPVzuX1T5rURMsmtd5ZQ36jmUDsu2cmZIExqdSKbVsTPIjETmjX+PpT98jTkzsyzNVVC4pbiSPlVqNd1e/JzqixcQ3cSbDjtjqXMhjoTTx5ny6kh2/bsQ6XC4PF5BobLwQNvqiWP71T8T5Km3CJwjNWP71T9TElnRAHx9fR0ffvhhnJeXVz6xDBo0KNXLy8tWs2bNhnfddVet1q1b564f+dJLL1WpU6dOg7p169aPj4/XPvvss5fyHjt58uSz7u7ujiFDhkQUd0SmY8eOmcOGDUto2rRp/datW0dVrVrV7OXlVamGc4o7YvMkl2cZvAB8CPgAlSZb2tUaTgUxeoXx5DOrON/oC+bN/ImwQ4Ec3LKBE7u34RPqT9KJ81jUavZ98zFhTSMZNPbr0jRfoZwpiVz8xcn2dqsS5mMk2oUWQ7wvh4Dq9G70eW86p4eu5+zrz9F55yn21vBj/+r/OLt/D32Gj6JKfWVOnIJCSVOUPsN8LuszMLwO/f/cyObZn+P5xa903nOSbXWDWfn7jxzfvoXez7ygJP5QqNQ80LZ6Ykk5MjkUtVZNTrnBYJDLly8/4Wqfosrz1jl16tTc0Lbo6Oh9rj4XPObVV1+98OGHH8aZzWbRu3fvWrfddltqca+nIlCsERsp5Ukp5YnszxeklE9IKe+VUh4sXfNKjjAfo8vyIC990QcJQZWOo3nuzXnUvj2LYHM0Mj2L+DNxWDQaEAKLRsPZvceZ/d7IUrJc4WahcePG3HnXnXh7O+eFeHt7c+ddd95wkoSyQAjhI4SYJYQ4LIQ4JIRoJ4TwE0IsE0Icy373vd76X+4dhVHrYqhcSs4n5R+NiWjQkf7zdhH/fDeqJiTS7uh5TBdjmDHuNVZP+ZX9q5bz04hH2fH9Z/w04lEOrVt1vWYpKFQKykufIV4GTAUiIdoOGk3rpRs43TOIVodjiIq5wPn9u5n88giW//Kdok0FhQrO448/Xq1evXr169atW79q1aqWJ598skSdudKm2ItCCCF6CSFeEUKMy/sqTePynPt2IcQRIcRxIcSY66mjqAdzhtnGgZgUF0fkIagerUau594nuiFE4UUfHSoVMbtveO6Ywi1A48aNGTVqFF27dmXUqFGVwqnJ5ivgXyllXaAJcAgYA6yQUtYBVmR/vy4GNAvno4GNCPcxIoBwHyPPdKlJusXOgIkb2HEm/3NVCEGP4d9Rf95sopuq6XjgDGGJyexYNJelP3xJWsJFANISLrJk4udKA0rhZqeM9Wmgb6MQdpxNZtjPm7mYlj8E393Dl7u/XInhuzHYPdPpdPAMpCazZ9k/ijYVFCo4s2bNOn3o0KGDp06dOjBlypSzGk1xg7sqBsVybIQQ3+JM89wCqFrgVaoIIdTARKAPUB+4TwhR/1rrcdVweq1PXbwMWob+uJnNJy9duQKtEW3/CZiL+ANb1JXrD6+gUFyyk4V0Bn4FkFJapJTJwF3AH9m7/QEMuJHzDGgWzoYx3Tn1cV82jOnOmD71mDu8Ax56Dff9tIU5O88XOsY/rD5DftuB+a078XQkoLPaCu0jJSz/sdIkb1RQuCbKR589mHh/C76/vzkHY1MZMHEDh2ILR6vU6/wwd8zdSsyQKuAiK66iTQUFhZKmuCM2w4AW2eFnj+Z9laZx2bQGjmeHw1mA6Tgf2NdMwYbT011qMXt4e4K9DTz021b+3R931Tp0tsINJwCEYNp7r3Ip+qpZAxUUKhs1gIvA70KIXUKIX4QQ7kCwlDI2e584ILikT1w7yIN5IzrQorovL83cw/h/D+NwFB41bXvPx3SfvgCLxnXmF4ulUs19VFC4FspNn30ahTLrmfbYHZJB329k2cH4Qvto9R7cOXZJ0Z2CijYVFBRKkOIOMyQAyaVox5UIB/J6C+eBEsvvGupt5O+n2/HYH9sY/ucOPry7EUNbVyty/zD/RM4mB+LIs8KryuEgOCWD+L37mDT6WRr3uoOOQx7A6OlVUmYqKJQnGqA58LyUcosQ4isKhLVIKaVwFacJCCGeAp4CCA4OZvXq1ddswOO1JTqLhu9Wn2DLodM81UiPXlO4B9hgtWHSaQuV62z26zpvSZGenl6u5y+IYk/RVCRbikm56/PV5oKvd0qemrydIVFa+kRoCy2gW5Q2hZQsXTAffTmuSVXR/uYVyZ6KZAtUPHsUKh5CSpfPuvw7CfE00Bf4CMjXJSOlPFk6puWeezBwu5TyiezvDwJtpJTP5dkn74O5xfTp06/5PGab5NvdZvYl2BlcR0vfmoUfzABB8Ws4+O8cYlNCsGg06Gw2Qr1jaWO4wNmd/kR7+HEuwAu0Wqq06khgw2ZltkhZeno6Hh4VI3VwRbIFKp893bp12yGlbFmGJhWJECIE2CyljMj+3glnw6k20FVKGSuECAVWSymjrlRXy5Yt5fbt26/LDiklv284zfuLD1I3xItfHm5ZKCnIvG6tOBWQv+MBKUEImvcfQOehj6Auh3jhG1lHqTRQ7Cma4tgihFD0WYAsi53/zdrD4r2xDG5RhQ/ubog+zwiqK22K7DTQwqjjjmdHE9Wu03Wd+0apSL8/qFj2VCRboOT0uWfPntNNmjRJKEnbFMqOPXv2BDRp0iTC1bbi/of/Pvu9X4FyCZR2qz2a/HN5qmSXXTZCyp+An8D5YL5eEXbv5uDlv/cwa3cMXkFVeLNvPVSqgs5NV+rXqwcrxiFTziO8q0CPtyCkMWFzX2LvkkNEHPZkT/UAzm9cTcqJQ3R78Alqt2zr0lEqSSrSA6gi2QKKPTeClDJOCHFOCBElpTwC9AAOZr8eBj7Ofp9fmnYIIXisYw1qBLrz/LRd3DVxAz892IJm1S4ne/K5vT515x/kZLAfJq0Gg9VG7bhEEjwN7Fw4j6M71zN0zMd4B4WUpqkKCmVGRdGnUafm2/uaUTvQg69WHOPMpQx+eKAF/h7OzKNFaTMgw8TGOsEs+vITDm5bTb9nXkGru0K2UgWFm4yJEyf6ffXVVyFCCKxWq3jwwQcTWrVqlTlu3LiwrVu3XlNmqv/++899+PDhEVqtVs6aNevE/PnzvX7++eegoKAg69ixY2Nz6ly7dq3bxIkTA2fMmHGmtK6rvChuumdVEa+yGIrYBtQRQtQQQuiAocCC0jiRVq3ii3ua8miHCH7bcIqXZu7GanexsFjje2DUftZ0nQej9ju/B9VF/dRimr3/OZG3WWkeF02rkzGkx59nwWcfMHPca8SfcplyXEGhMvA88KcQYi/QFOdaVh8DtwkhjgE9s7+XOt2igpgzvD0GrYp7f9rM/N2X+zm6vvoHxrvq0zT6LLfvPUnT6LO4d6pG07QMGp+LIyXmAj+Nepxty2aVhakKCmVFhdCnEIJRt0Xy9X3N2Hs+hbsmbuBInHM9QVfa1A+oT43XX6br4RhCUpI4uWEL3z5/L7GnKs3a3wq3Ett+9eOzyEa849OCzyIbse1Xvxut8tSpU9px48ZVWb169dEjR44cPHjw4MG77rrrKql6i+aPP/7wf+qppy4cOnToYIMGDcy//PJL0Jw5c05s2bIln6g6d+6ceTM6NXAN6Z7LCymlDXgOWIozheVMKeWB0jqfSiV4q199Xu4dxbzdMTw5eTuZliISBhRECGg4EJ8PttHs7cGEVk3ktr1nqH7xImeP7mPqay/y73dfkp54lQxsCgoVDCnlbillSyllYynlACllkpTykpSyh5SyjpSyp5SyzHLdRwZ7Mn9ER5pW8eGF6bv5YtnR3KQCXV/9gw5bD3Hxh+/psPUQHcfPJmrRMmpXrUGPg+fAYWbtL5P4/q1hmDLSrnImBYWKT0XT551NwpjxdDvMNgeDvt/IqsMXgMLa7PrqH/gNfYjaf06jRYqNZmdjMKeZmfL6i8yf9BbFCZVXUCgTtv3qx9LXqpMerwMJ6fE6lr5W/Uadm5iYGI1er3f4+fnZwbkgZ/PmzU0AZrNZDBgwoEadOnUatGzZMio2NlYDMGjQoIivv/7aP6eO1q1bRy1atMjz/fffD1q0aJHfhAkTQtq0aRN59913R5w7d04/ePDgWk8//XSVvOddtGiRZ+vWraNyPjdp0qSuq3PFx8eru3TpUrt27doN7rjjjpqNGzeuu2jRIs8buebSpshQNCHEHOAjKeW2K+zTCnhNSjmwNIzLQUr5D/BPaZ4jL0IIRnSrjb+7jtfn7uP+X7bw+yOt8HHTFa8CvQeqvh9Qp/XDZP78HI4Fp4nclc7qBr7sX7eCI5vX0fquwXj6+bNx1l+kXUrA0z+ATkMfol6nbqV7cQq3FEKI5jjnxzUBfHAmAdkDLJFSXl8wfQXBz13HlCda8+bc/Xy94hgnLqTz2ZAmGHWFB5I1/v5ETPkT/bhx3DFrNlvqB5B0BD4dOZjb7r+btt2fKYcrULjVuZn12bSqDwue68ATf2zn8T+28fod9Xi8Yw2XIdnGpk2pNXc++uEj8N13hBWNgzi+ZCcf7r6dR194n7AarcrhChRuGeaNqMqFg25X3CdunzsOa/4fr82sYsmrEeyaGujymKD6mQyYeMVUuW3bts2qWbOmqWrVqo3atWuX1qNHj9Snn346EeDIkSNuU6ZMOdW4cWPzsGHDqn/11VcBH3/8cZHpe998880Lu3btcuvSpUvayJEjLwGEh4d7/vPPP8eioqIsV3JIijrXmDFjwurXr5+1Zs2a41u3bjW2b9/+mpdbKWuuNGLzI/Bd9sKYPwkhRgshnsp+/1EIcQT4lsvzb246hrauxvcPtOBATCpDfthEbErWtVUQGInba0tp9ONH+DV10ONAAi1OniZNl8rGmX+y9IevnYuVSelcrOzHr5TFyhRKBCFEbyHEduAvnHPUNuBMlb4h+/ufQojtQojby9HMG0avUTN+cGNev6Mu/+yP5Z4fNzFp4yk6fLySR/7NoMPHK5m3yxmqJnQ6Qt97j9DXX6fd4USapaSgMalY8/MCPv6wN6kXlUV2FcqGW0Wfod5G/n6mHb3qh/D+4kMM+3kz7T9aUUibANqQEKr/OZWg23pxx45YwshEF6fhl3ffZPJvD2E3Z5TjlSjc8hR0aq5WXkzUajWrV68+Pnfu3ONNmzbN/Pbbb0O6d+9eG6Bu3bqZjRs3NgO0atUq49SpU6U2+ayoc23evNnzkUceSQRo3bp1VmRkZGZp2VBSFDliI6VcCiwVQrTEuThmG5w9SknAXmColHJXWRhZnvRuEMLkx1rz5B/bGfTdRiY/3obaQdeQXUsIVE0GUWXS7QT89Sbip0UMWn+eJY2rI0X+2y+tNv6b+qMyaqNQEjwJPFuMEddXgX/LzKpSQAjBU51rUTPAg+F/7uCdBZfDk6OTs3htzj7AuY6VEAK/hx5EV6smqlEvcUdqMqsa+GLfo+Xd956ma/e69LtjAkJnLOp0CgolwS2jTzedhu/ub87TU7az7NCF3PKC2gRQGY2Eff45+jp1aPrV10TUq8FavYr4/y7xv5O9ePLOB6jf6hln2LeCQklxlVEVAD6LbOQMQyuAR7CFp1bdcK9Yx44dMzt27Jj59NNPX6pSpUqThISEizqdLjcWU61WS5vNJgA0Go10OC7P/zabzTcsiKLOVRm56hwbKeV2KeV7Usp7pJS9shfp/OBWcGpyaFvTn+lPt8Vilwz5YSNfrTjqskf4iujcMTw8gXpzFhPQLRBZRDI5a7IS869w40gpB1+p0ZS9zzYp5eCysqm06Vk/2GW4aJbVzqdL8//f8ejQgYgZ0/Hw9qXXpnNE1qhCyAV3dsw7zcivOzJp1j30+q0hjSc1pNdvDVm8emxZXYbCLcCtpk+VSnAwtvD/NlfaFEIQ8OyzhH/zNb5n4ul/OhPfUG+qHPPl10mz+OTnjsxe/IyiT4Wypcur0Wj0+bNJafQOurxajAZg0Zw+fVq7Zs2a3DC4LVu2uHl6etp9fX2LXLm2Ro0a5m3btrkD7Nq1y3DkyJErh9HdAG3btk2bPHmyH8D27dsNR48erfC9fmW/oEMlpUGYN7Ofbcfd321gwrJjueWuep2uhAiOJPC7NegG3Y5FW3ixMpVDkhQbjW/o1etSULhWhBC9gMbASWCuvMlm515MM7ssj0kuHEaqr1GDiBnTiR79P2rPW0PEgP6sSDiO+/YQtp27QIfkKrib1GQY7PwW+x8Afbu+V6r2K9za3Mz6dKXBK5V73XYbumrVOP/scDqsPEjCA4PYsmsLpnU6FoTvp0Osok+FMqTV487kG2s+CSf9gg6PIAtdXo3OLb9OLBaLeO2116rExsZqdTqd1Gq1curUqSdUqqLHHV544YWEfv361apTp06D+vXrZ0ZFRZVaeNhHH30UM2TIkJq1atVqUKdOnazatWubfH19i5lRq3xQHJtroLq/Ozq1GrDmK8/pdSqOYwOAENSNSWR/VReLlUn4/eURdLnvEZr16Y9KVTaLeyrc/AghxgFtge1Af+Bu4MFyNaqECfMxEu2ioeTjpkVKWWjistrLi6o/fM+FTz8jcdIk+rZtzRT3VGrGXQ439TBpaL3fnxnyP6XhpFBq3Oz6LEqbapVgf3QKDcO9C20zREURMetvzo8cScCv0+j/4P38fWQ9jU/55O6j6FOhzGj1eOKNOjIFiYyMtGzcuNFlfvN+/frlDmeOHDnyUk5CgNDQUNuOHTtchr/Nnj37dN7v0dHR+/LUl5ZTZ1GfC57Lx8fHsXz58uN6vV7u27dP36NHj6hGjRq57kGsIFT4dM8VjfhUk8vyonqdiiLYnk6jcxcxWKwgJQaLlcbnLtLl8FnMpLJ68i/88eaLJMacLwmzFW5BhBADChR1zg4nfR3nuhYFF9yt9LzcOwqjNn9ngBCQlGnl6Sk7XI7oCLWa4DGvEvrhh9h37CIg2UVWNYeKWsd84dBCcBQZIaCgUGxuNX260qZOrcKoVTFg4ga+XH7U5bpxGj8/qv/2Gz5DBuOY8ifuWYUHsXL1GbO7tMxXULglOXv2rLZZs2Z1o6Ki6g8aNKjWhAkTznh5eblY4LHioDg210iYj+vwQje9mlST1eU2V1R/ZCCh6Wl0P3SWO/aepPuhs4SmpeHtZeOu7bHUuBjPxVPH+e1/z7JmzlQcSmNK4drpI4RYIISonv39kBDiByHEE8DvwNZytK1UGNAsnI8GNiI8W6fhPkY+H9yE1/rUZfXRi/SasIbFe2NdHusz8G6q/fEHVrXrgWx3k5rnV73IyYnNYctPYE4vtetQuCW4pfTpSpvjBzdm3avd6dc4lC+XH+Pu7y4v6JkXodMRMm4cwW+8gUMUrc8v/r6LlEl94MgScFTotpeCQqUgMjLScvDgwUNHjhw5ePTo0YP333//dS8eWlYU27ERQkQJIe4RQjyW91WaxlVEXPU6qVWCDLOd7p+tYe6u88VaVMx7xAdUeXYQGg8AicYDqgwfRO21e6k+uj+NslK4bd853LPS2T5jOl//7xHizp4onYtSuCmRUj4NfARMF0KMBV7BuUZG8+z3IeVoXqkxoFk4G8Z0Z9Lt7mwY052BLarwdJdaLH6+I1X93BgxbSfPTdtJYoal0LFuzZuh07p+LArAcrYa9xgk72z7iAtfNYBlb0PKDc0dVbhFuRX1WVCbA5qF4+Om48uhzfjhgRbEJpvo/816Jq46jq3A6I0QAr8HH0CnLjpZ04a0MO5wnGPS4icxT2wJ234FS4XPTqugoFCCFMuxEUK8jvNBOxpnzG/O64HSM61i4rJHeEgTFjzXgXBfI6Nm7OHenza77HUqiPeID6iz/RD1Dh+mzvZDeI/4ADQ63J8cT+0lq4joX5Mup2JociYe+/kEprw6kimTPsBur9DzthQqEFLKTUAHIA1YBZyQUg6XUn4qpUwtX+vKljrBnsx5tj2jb4tk6YE4ek1Yy38HCq911jDRjKpAb6/K4cDPZCfytAdDN9Vib2oofYO8+frgJNK+bgJznoLYPWV1KQo3CYo+L3N7wxD+G9WZnvWD+HTpEQb/sInjFwqPijZMtrjUp4fNQft9/tyxsw6T1MH087Qzf81Y7BPqw4r3IC2+rC5FQUGhHCnuiM2LQGspZRspZbc8r+6laFuFxVWvU+MqPsx9tj0fDWzE0fg07vh6HR8sPki6+fqcEOETju9HC4j66wca17bT/fBZgpMzuLBkEx8+P5D1e/4r4atSuNkQTgYCLwFHgLuAJ4QQM4UQoeVrXfmgUat4vkcd5o/oSKCnnqem7OClGbtJybwcRhpy+nyh+W+Nzl2k7ZEzdE4yE4CRDnv8GLi7LrNU/txRvRpTzy3H8mNnmNQPjvyrhMEoXBVFn4Xx99AzcVhzvr6vGacvZdD363X8su4kdsflKIii9Nn5wGlaCgO+qWr6bwyl+fEavOcdyJDQQNZtn4j8siHMGw5x+8vxChUUFEqb4mZFywIOl6YhNwMqleC+1tW4vUEI45ce5pf1p1iwJ4Y3+tanf+PQQhmZioO6XjeCJm/D59+v8P/6B46d8WK/PZDNH37FsjbTePyxd1m/Yg4nFy3HkAnr//iUmv16MmzQqFK4QoVKxmSgBrAOeANYI6W8J3s183+EEFOllJ+Xq4XlRP0wL+aP6MC3K48xcfUJNpxI4JNBjekaFYQmNJTwmBjCk/P3Fqt8fAgOr4r75s2c83HnqAxiQGwYqbX0fFHzGFMDQhiZdIrb/7oXlX8daDccVDpY8zFdUs7DrirQ4y1ofE85XbVCBUPRpwuEENzZJIy2Nf14fc5+3l98iKUH4vhsSBOq+7sXrU9PT6pmWPDde4JjoX4IvHngdA0O1zczIsxEK50fLx1dSIPdf0LNrtDuechKhBXjFH0qKNxEFHfEZizwjRAiVAihyvsqTeMqK77uOj4a2Jg5z7YnyNPAyL92MeznLRyLv87FN1VqdHe8RLU5m2l3fyN6xp0kNDkDry0JTHnuKaJnLsOYKRAIjJmC6L+XMW32hJK9KIXKSF+gm5TyNZxZlvoCSCn/BdoBXuVoW7mj06h4qVcUc4e3x8ug5ZHftzFm9l48n3seYTDk21cYDIS88TrVfvuVyDWrafXMc9yGG1UTUvA8buLRZdXottmdcWrB0Ppt2GTQwaJRsGAEpJxDICHlHCwcCXtnltMVK1QwFH1egSBPAz8/1ILPhzThcFwat3+5jsmbThPw4ouu9fnWWGouXEDk3Ll0umMAXRKz8E5Ko84eNcOXRuC918b9Ad683LAL5y4dgT8HOUNIFX0qlCNCiBaDBg2KyPm+aNEiz9atW0dd7bh77723+tq1a0ttYc7KTHEdk0nAk8B5nIu4WAEbBRd0UchHs2q+zBvRgfcHNORgbCp9vlrHR0sOkXGd4Wm4+eH2/O/UnzmTvg3sNI+JwWDRoCrwZ1RJFefnLC2BK1Co5GwF3hVC3Aa8C2zJ2SClNEkp3y5uRUKI00KIfUKI3UKI7dllfkKIZUKIY9nvviV+BWVA4yo+LHy+I890qcXM7ecYdNSL7YOfIcHdFweQ4O5L9OOj8O7fHwBNYCB+Dz1E3ZkzuevXKdzRvAPuNonmgp6nFofQf3oyv51IYXhgGHMv+LLhnzAOTA9jwz9hrD6rgxXjyveCFSoKij6vghCCQS2q8N+ozrSq4cdb8w8wIj6QIw88V6Q+DVGRBI0eTfOly7jnnY9pH1YDm8VG+EkfXv07kOpzzvJypp6PAkNYGuet6FOh2Mw4MsOv28xujRr/0bhFt5ndGs04MsOvJOrdunWrx759+/TXZMuMGWc6d+6sZMZwQXFD0WqUqhU3MWqV4IG21enTMIRP/j3Mj2tOsmB3DGP71cdstfPZf0eJSc4izMfIy72jirXIpwhrgs/na+mybRo7P5vm+rxWZWFPBe4Bnsa50N9+4K0brK+blDIhz/cxwAop5cdCiDHZ31+9wXOUCwatmjF96nJb/WCembKdN9OrwG1v5G43XlDz0a7oQvrURURQb8zrRNnt7Jo2mU1L5mO26em9TU/E4kQMNiPq7OkBfqlg3uDOalLpaskAnXtZXqJCxUPRZzEJ9Tbyx6OtmL7tHG/P389Ge8hV9SlUKtxbtaJdq1Y0S0lm7bcT2L93BxqLkUf+uYRPhgV3ixua7Olw+fQppXMBLAWFbGYcmeE3ftv46ha7RQWQkJWgG79tfHWAe6PuvaFFO0eOHBn31ltvhc6dO/d0wW0vvvhi2OLFi30B+vfvn/TFF1/EALRu3TrqrbfeiunXr1/aiy++GLZo0SJflUolAwICrBs3bjwG8MknnwROmTIlwG63ixo1apimTp162s/P76afAFosx0ZKeQYgO/QsGIiXUt70N6ck8ffQM35wE+5tVZWx8w4w/M+dqATkzImMTs7itTnOBWKL49wgBKrW92OwTsak0xbabLAqmdNudbKzKn1aiqe4C+ia/fkPYDWVtOGUQ4vqvmjVhQeys6x2Pl16pEhtqtRqWjz4KPXvHsyG6ZPZu/xfYnw8CE5OJ8HLDZNWg8FqIyo2EcMukF83Q3R5BZo/DOrC+lW4+VH0eW0I4ZzD+uXyo8Sn5l9o92r6NHj70OuNd2l+7gwrfpnIAfVBPLO8CE5O57y/VyF98lNX6PkO1OpW6telUP6M3TC26vGk41cM6zqcdNjd5rDl83Ytdovq460fR8w7Ni/Q1TG1fWtnvtfhvXNXO//IkSMvffPNNyF79+7NN2ozdepUn5UrV3rt2bPnIECbNm3qTps2LWPYsGG5a8nEx8erFyxY4Hvs2LEDarWaixcvqsEZ0rZ+/XqPXbt2HdJqtbz66qshY8eODZ04ceJNvz5BcdM9ewkhJgMmIBrIEkL8IYTwLlXrbkJaVPdjwXMd8DZqcRRY7ibn4Xwt1E5KLJT6EkA4JO///CAp5gq/lpJCKSCE+EIIEXKVfUKEEF8Us0oJ/CeE2CGEeCq7LFhKmbPaZRzOTo9KT2yKyWV5dHIWC/bEYLIWvViu0cOTnk+M4P6PvkRjs3M+wNvZ8SAEJp2WfVUDyVJ50NvXwDtbPmDFjy3J2P2nkkXtFkPR5/VzoYBTk0N0chZbTl7CUfAfax4Cqlbnnnc+oe/Il8nUajge6u9Sn4PUCXy16GF2/tEb27ltpXUpCpWIgk7N1cqvBb1eL1988cW4sWPHhuUtX7VqleeQIUMS3dzcpJubmxwyZMillStXeubdx9/f3+7m5uYYOnRoxPfff++nUjmb9QsXLvTevn27R6NGjerXrVu3/qxZs/zPnDlzTeFulZXihqJ9DbgDDYEzQHXgg+zyh0vHNBBCfAr0ByzACeBRKWVyaZ2vrNCoVaRmuZ6eFJOcdU11tR3SC9WfSzka7J/b6xSYlkmsjwfu/13ix/W30+a5R+nS6qmrV6ZwM3EE2CqEOASsyf6eBngCkTh7cqOA94tZX0cpZbQQIghYJoTIlyVRSimFEC5bFNkNracAgoODWb169bVfzXWQnp5+XefyMwgumQpfigoY+dcujBpoGayhfZiGKD8VqiJCVuyawuUOlYqjoX68+3Mcs9t7MrqhHdXuj2i67WOiPFpTw78XQbrSb39e770pLSqSPWVkyy2tzxu5x0XpE+DenzYTYBS0C9PQIUxDiHvRfbdqJAW7KHL0+fjfdqZ0FPziE4PXsodp6fCgpl8Pant3xF1d+iGkt6Aeik1p2FOcUZVuM7s1SshK0BUsDzAGWP7q99e19Ui7YMSIEZe++uqrkIMHD+am+yuoWVeZdTUaDTt27Dj877//eixZssT7vffeC9+1a9dBh8PBk08+eWHcuHG33AJOxXVsbgdqSilzJiodFUI8itPZKE2WAa9JKW1CiE+A16jEQ+l5CfMxEu3CiRECpmw6zdDW1VyGxBTEe8QHtAYifp+DLV2i8RAEPToQR/v+LPj4XRJM/hx+fzr7Gv7GI499gEetHqVwNQoVDSnlj0KI33CGo/QBBgA+QBKwF/gBWCilLFbMopQyOvv9ghBiLtAaiBdChEopY7PX3bhQxLE/AT8BtGzZUnbt2vUGrqz4rF69mus511jvaF6bs4+sPCMzRq2aDwY0JMTbwOyd0fy7P5Z10SbCfYwMaBbK3c2qUDvII189O77/zGX9Jp2WlKo1eHDpMR7dHcC+rj5MDzvBVMtWiN1KdWMwnSJuo1OVTrQMbolOrWPxycV8tfMr4jLiCHEP4YXmL9C3Zt9rvrYcrvfelBYVyZ6ysOVW1+eN3OOi9PnunfXRalTM2RnN4uMJLDxhpUlVHwY1D6df4zD83PO3Sa+kT2OGD29Oi8XSuBar25iZ5xPDyrRFqNIW0civHp2r96Rzlc5E+UYhhLip9VmRbIHys+eZJs9E551jA6BT6xzPNHmmREK79Hq9HDVqVOz48ePDqlSpYgHo1q1b2vjx40NHjx59EWDWrFl+Y8aMic17XFJSkiotLU111113pfXr1y/tv//+8z558qSuX79+KaNHj642fPjwhJCQEHtqaqrqxIkTumbNmrkOSbiJKK5jYwICcY7W5BAAuB4TLiGklHlXodwMDC7N85UlL/eOKvRw1mtUhPsYGTv/AL+sP8XoXlH0axSKSnXlkU7vER/gPeKDQoJ/aPo/bPn2MzavXYU4YmD6y6/RqLOBNv3ehlrdlcmRNzlSSiswK/t13Qgh3AGVlDIt+3MvYBywAOeI7cfZ7/NvzOKKQU6c/qdLj7hM7NG+dgDvDWjAsoPxzNkZzferTzBx1QkaV/FmYLNw+jcJw99Dj2dAIGkJFwvVr9ZqOWC1crhJbcItkoi5p/k8pCqqnhFs0q1kbeZpZmb9ydRDU3HTuBHhFcGx5GNYHc5R3tiMWN7Z+A7ADTWeFMoXRZ/Xx9X0eXezKsSnmpi/O5o5O6N5a/4Bxi08SNeoIAY2D6d73SAMWnWR+hQqFTt93TAE16daQgpdf4tjUKuWpLa0sta2kbWWvXyTeIhvdn1DkFsQ1T2rs/vibkWfNzk5CQJ+2PND+KWsSzp/o7/lmSbPRN9o4oC8jBgx4tIXX3yRuzjv/fffn7Jt2zb3Jk2a1Adn8oD77rsv3/yCxMRE9d13313LZDKppJTitttuS2nTpk2WSqXi+PHj8V26dImS0jnw8/rrr8cojs1lfsE5vP0Fl0PRRpHdy1NGPAbMKMPzlSpFPZzvahrGqiMXGP/vEUb+tYsf15zgldvr0rlOwDUv8CmEoO3zLxM18D7mvvU/ktJVHPovg5O7RnBn2yDcu70KkX1ApSxHpHBFgoG52b8/DTBNSvmvEGIbMFMI8TjO58JNs7LdgGbhV0zi4abTcFfTcO5qGs6FVBML9sQwZ2c07yw8yPuLD9ElMpCIOt3RXpqNNk+nu1VoCLr9Qfp0acHupYs4sHYlZyOr4meHqn9vp7V/bfr1rI4maQHbNHbWVm3ErKTDOArkajHZTXy18yul4aQAij4LEexl4KnOtXiqcy0OxaYyd1c083ZFs/xQPF4GDX0bhxHQ8Dasa2YW0mfYHQ/SqVEEu5cu4uiu7RzzrkHoxRiq/ZZAv6ZdeKyZjfS4Jaz38mWtuxvL47cjyR8ap+jz5uTeqHsTS9KRAZBS7sj5rNVqOXv27P6827/88suYL7/8MqbgcVu3bs0Nf9u7d+/hgtsBRo8enTB69OgEV9tuZorr2HwAxADDgLDsz+OB327UACHEcsDVJMo3pJTzs/d5A+e6OX8WUUeliuHPwQf4oK0K5/QlIOUYa9YcQwW80kSyOUjPnGNpPPzbVur5qRgSqaOmT9FpnK9kT40HnsZt8xpidm1Dk16Df2cnUOvQk9SuGsDZaoNB2ql56k/05gTM+gBO1nyQC8FdrvvaboW43BuhotlzJaSUJ4EmLsovAbd8bGOQl4EnOtXkiU41ORyXytyd0czbHc2KVD/q+HehfdIWPO3ppKk92OjbhszzPjxYtTo9nxhBx/se5uCaFexaupg9ajjskFSdt5va3k1p3jmQzscW8Xe1YJejq3EZsS6sUbjVUPR5ZeqFelEv1ItXb6/LhuMJuU5OltXbtT6jfXnowRbUaNqCpLgY9vz3D/tXLSPGXc/BS/FUn5ZIZIP+3N4gmQH7V9M4oqqiTwWFCkRx0z1LnE7MDTsyLurueaXtQohHgH5AD5kznla4jkoVw19cugOjbXb+2nKWb1YeZ9xmE30ahjC6V1SheP5i2dOtG0mx0cx6bwynNWqyjrgTe+4SnS9NwN0gIbvXyWC+SP3j31O/Xj1ofH2dfEpc7pWpaPYolAx1Q7x47Q4vXrm9LrVe/4djnpEc84zMv1NyFmabHb1GjcHdg+Z33EWz2/tzZu8udv67kOO7tnNCSkKWnaKOezu6mY6hTfKgerwfFo0Gnc3GmZBElrXOYt7xedxZ605UQhl1VVC4EmqVoHNkIJ0jA3l/gI0Gby91qU+RnIWUEiEEviFhdH3oCTrc8wCHNqxm1+L57NNrOJx0kSoLUmlQsz+N3XYQctqD6nH59bmidRZ7Lu6hSWAhn1NBQaEUKdKxEUI8KKWckv35saL2k1KWuLOTx4bbgVeALnkSF9xS6DVqHulQg8Etq/LLupP8vPYkSw/EcU/LqrzQsw6h3kbm7Yrm06VHiE7OInzzyisu9OkbGs7j305i4+xpbJk1g0SbEdU6PTq/ZHRxWnzSINkLrM0y6Lpi3HU7NgoKtzJqlSC8iAQhAC3eW07XqEB6NwihW90gPPQaIpq2IKJpC5LjYtm9dBH7li0h1mqhzqFqWDQaLFpnr7BFqyX8YiADN11grBjL7KOzeaPtG9T1q1uWl6igUGlx12uK1KcEOny8kl4NQujVIJjWEX5oDQYa97idRt17E334ADsXzuH4jm2cSk2i87pw0g06LFpn50KOPvtsucgD4gEG1hnIC81fwM9QIovUKygoXIUrjdjcB0zJ/vxgEfvkjOSUFt8CepzzewA2SymfKcXzVVg89Bpe7BnJg22r8+2q40zdfIa5u6LpUMufjScvYbI6Y/CLs9CnSqWm45AHqdu2M7M+fYv9GjU+6d6YqmhyU0bX3JfIai7kru6mUHkRQmhxpo71AZKBI9kTlxVKEVcJQgxaFQ+1rU6qycayg/Es2huLTq2iQ21/ejcIoWf9YAJCQun68JN0GPogh9asYPnP3yELJBBxqFQEXvRnXPJxJogD3LvwHobWvY/nmj2Hp86zoCkKFRhFn+VDUfq8u1k4F9Ms/LX1LJM2nsbXTUuPesH0bhBCpzoBVKnXkCr1GpKWmMDuhXPZunheoVA0h0pFlXg/HjHHMvXYXJaf/o8XWoxiUJ1BqFVFh5MrKCjcOEU6NlLKO/J8Lpfld6WUtcvjvBUZfw89b/dvwGMdajBh2VHm7CqcafBqqzDnEFC1Ok9+8St/3NWTJHf33IezSaflcHggNY4CZ7dAtTalcSkKpYwQoi/wDM44eyuX18nQCiFWAj9IKReVo4k3NXkThEQnZxFeIHvTB3dLdpxJYumBOJYeiGPVkX2o5u6jZXU/ejVwNqQa9+rLsl++c1l/lkZDf/+OdD/9L994G/nr0DSWHpvL6Oaj6Fdv6DUnG1EoWxR9li9X02eG2caaoxdz9Tlrx3ncdOp8I62dHn7S6di4IEuj4SV1Fe46v5UPAvx4b/N7zNn7G292/pCGwc3L6jIVFG45ijXHRgixS0rZzEX5dilly5I3S+FqVPVz44t7mzJ3VzSuJh4Vd6FPtUZDlk7vsscp2scP2w990HR7Hrq9DppbYtHamwIhxAaca2JMA56WUsbk2RYGdAGeEUK8JqXsUE5m3vTkZG9yNadKrRK0ruFH6xp+vNm3HgdjU1m6P46lB+J5f/Eh3l98iPqhXtxhc2DWuujlFYLfZsVRv8ZgXmpcnbvjF/KBOZ7Xt33IrB1f8UbDZ4lsfD+oi5sjRqGsUPRZMbiSPt31Gu5oFModjUKx2BxsOnmJpQfiWHYwnn/2xaFVC9rVCqC1XWJ2sRgvwJ+LoEmrZ/gpDP47M5fPbGcZtuQhBhurM7LdG/hUa18GV6mgcGtR3BmnhUZOhLM7sGbJmqNwrYT5GF2Wexg0pGQWL5rBpHXd8DFpNexbHMyWyZOwf9cF4vZdt50KZc4zUsp+UsppeRtNAFLKGCnlX1LKfjh7jBXKGSEEDcK8ealXFEtHdWb1/7ryWp+6GLQqjunqoHLkT/escjiw4YXaw4MtMWf45Y9VnNlYnS+CXudtj0acsKVzz55PGf9zY9L/exMuZa+lvHcmTGhIl9UDYEJD53eF8kDRZyVCp1HRJTKQD+9uxJbXejD72XY82qEGZy5lcExb26U+kQaSdWr+27Ob337bjtepnsys/j/u1wYzJ+sM/Zc/wZxf2uDY8hNkJTkPVPR5SzJx4kS/yMjI+lFRUfVr1qzZ4O233w4u7XMOGjQo4uuvv/YHePHFF8P+/PNP79I+Z1lxxa48IcTk7I+6PJ9ziAAOlIZRCsXHVZywSkCayUaHT1byYLvqPNGxBv4eRY+26Ix6LCZL4Q1CsL+mDy23wdbDKTgO9KftfSNQdxql9AJXcKSUxfJCi7ufQtkSEeDO011q8XSXWtQ4m8ydp6G25RgWjQqdzcFxXR3mR/SmSRVv2phP4bN3KYcykjj819+EoeG7Hk8yL3QnU5N28u+5Ofxvz6/00YchUs6C3YIASDkHC0c6T6gkCSlTFH1WXlQqQYvqfrSo7sdrfepS87XMIvXZqaYPrWM2wZENbD1/gp0/HKWBZyi/9buXr2x/87Ypjtm7P+ONVe9QP6A+xO4Fu1nR5y3EqVOntOPGjauya9eug2FhYTaTySQOHjxYpuExrtbJqcxcrXV6oojPEtgA/F3iFilcE0XFCUeFePLtquP8sOYEkzac5v421Xiqc02CvAyF6uj5xPMs+W4CMk+vk1AJPHz8uZAk2H5fC4LXrKPqGlh16Fc0XWfReeRUVAF1yuw6Fa4PIUQv4BGgAc74/TScHRK/SymXlaNpCsUkzMfI/IjeQO985R56NUadmr8SgkgLvQ9/UwJ9Y1ejsl8geuUyQix2xtboxMJm53g16DSzTWl0cNcz3SuAOI2aEJudF5KS6atkPywXhBAi7xIGQoh2wEBAAPOllOvKzTiFYiGEKFKfbjo1SWYH31gbYKlWl7opx+mesJGjGUkcmTGf7nYDtzXrzq/VtjHUoOee1ONEGTX87OOv6LOCkvjXdL9L330XbktI0GkCAiz+w4dH+9039IYW7IyJidHo9XqHn5+fHcBgMMjmzZubjh8/rr3vvvtqZmRkqKxWq2rkyJFxzz///CWA1q1bRzVr1ixj69atHvHx8doPP/zw3IEDB4yLFy/2sdlsYvbs2ScaNWpk/vrrr/1nz57ta7PZRExMjK5p06YZf/311xmDwZBvBsOgQYMiunTpkjZy5MhLgwYNinBzc3McOnTIGB8frx08eHDihAkTYgDmzZvn+dJLL1UzGAyObt26pc6bN88vOjq6wnW+XNGxkVK+CyCE2CylXFo2JilcK0XFCU8c1pzjF9KYuOoEv204xeTNZ7ivVVWe7lIrXwhbvU7O3BDrpk8m7VICnv4BdBr6ELXbtGflbz+yf9V/6Lr0QQRqcftjDn4zU1mw7U48hnam2wMTUSujNxUSIcQonOnSfwZmAymAF87F/P4QQnwipfyqHE1UKAauRmWNWjXvD2jEgGbhSCk5l5jF/pgU9ke3YfeZCwRsXoDGepi06LO0PGOnubo665qd4eBZb/rnWQ9nXbAHsuZ5+iUchwAlV0sZk6NHhBADgUk4F6GWwCIhxBNSSqXzsIJTlD4/vNupT4vNwbELaRyIbsKBmJ6cOnKCGjvmoxZx2PedYMh2L5K9/VjU+jTJJ4yu9ZmZCG5KuujyJPGv6X4XPv64ujSbVQC2ixd1Fz7+uDrAjTg3bdu2zapZs6apatWqjdq1a5fWo0eP1KeffjoxJCTEtnLlymOenp6OS5cuqZs2bVrvnnvuSQ4ODrYDpKSkqHft2nV47dq1br179476/PPPzxw8ePDQm2++Gfzhhx+G/PXXX2cAdu7c6bF3794D1atXt/bp06fWZ599Fvjmm29euJJNp0+f1m/atOlIenq6qlatWo1Gjhx5MTg42PbUU0/VWLRo0bHWrVtnPfvss1fOTlWOFHeBzqVCCB3OlJQBOHuUcratLCXbFEqA2kGeTLi3KS/0qMP3q0/w55azTNt6lsEtqjC8a22q+rkBTucmx8HJS+9nRlKlXgOW//IdSTFu9P7hD2KW/EG1mcvRf7yWqf80JWjEcG7r+BQaleLgVDBeBrpJKQ8XKJ8jhPgLWAUojk0FJ++obExyFmEFsjcJIajm70Y1fzfuaBQK1EU+1Ym4FBPbZs0hbsU80hxZtN9ZDQT51sMJTghki4S+37ZAVGkFTYZCg4FKI6psyDvj/DXgXinlEgAhxDzgE5SoiArP1fSp06hoEOZNgzBvoCrQELvjTo6dT2DP779waf9G9CbJkFXVkCpRSJ9bJfT7LBKibocm90Ht20CjK6ervTmJef2NquZjx9yutI/p8GF3rNZ8WSKk2ayK//DDiJQ5cwJdHaOvUycz7MMPzl2pXrVazerVq4+vX7/e7b///vP89ttvQ2bMmOG3ePHiE08//XTV3bt3uwshuHTpknb//v2G4ODgDIAhQ4YkAbRv3z7TZDKpHn300SSAVq1aZa5cuTJ3vky7du3SatSoYQV48MEHL02ePNkfuKJjc+eddyZptVp8fX0dNWrUMB09elQfFxenCQgIsLZu3ToL4JFHHklcsGBBhfxHUdysaB1xPmD1OHuYUnGGtZxDSSBQKYgIcOeTwY15vkdtflhzgpnbzjNz+3kGNA1nRLda7D2fUuSDuUGXHgTVqMXCLz5i7ifj6DD0QRouf4vdbz1K89UnsI34hu/a/UrEc6/gseUQ+l9mEZhiZ4O3GutT99D18bfK+epvWdyBomJn44ArPsgVKg45o7LFRQhBqI+RO5+4H564n4sH9/PnWy9jL7CGhkOlIuiCH9071KWj+RIdVo+l3dLX8K7TW2lElT55w0FqAHmjIpYByszxSsK16lOtEtStFkjdt19DSsmJfxez8LfvkC6ykwZe8OPujlo6XtpOh3n/0Vy4o2s02NkJEda8UEZThVKigFNz1fJrpGPHjpkdO3bMfPrppy9VqVKlyfvvvx+sUqk4cODAQa1WS4MGDeplZWXlJvzS6/USQKNxNuONRqMEp6Nks9luyKacunPqs5bQNZYVxe1inwCMl1JOEEIkSSn9hBBvAZmlaJtCKVDF1433BzTiuW51+HHtCaZtOcvsnedRC4E9O9zb1SKfgdUieOCjCfz34zes/+sPYo4c5PbxfyFO7ubAW89z29pMMja9g84O2uypOn4pdswT/mI1KM5N+TAbWCiEGAfsJX8o2pvArHK0TaEMCazfELvKdRJMi0ZDhxX+7GyQwrzAAFQCGqbtosO/a2nv0NIo6m7UTe9TGlEljz5bmzl440wBDc5OB1eZ/BVuMoQQ1O7TD8fv37vcbtFoiNjgxbwGZiaFajGiotXZ+bQ/PI2O+hCqNboP0WQoeFcpY8tvHq42qgJwrFPnRraLFwv18mgCAy01/p555HrPffr0ae2ZM2e0Xbp0yQTYsmWLm6enpz05OVkTGhpq1Wq1rFy50v3IkSPX1RG5efNmzzNnzmirVq1qnTZtml+XLl3SrqeeJk2amBISErTbt283tGzZ0jR58uQKOVoDxXdsIikcsvIxcAr4rEQtUigTQrwNvN2/AcO71qbbZ6tJN9vybXe1yKfO6EbfF14hvF4DVv/xC1PHvED/F8fQYs4OMqe+yfFP5uU6NTnobaD9aQYojk158AzwLjAZCOVyQykWmAK8XU52KZQDersDs6bwejgqKfHLEHTf7gsOX1L93DjbyMbP3sf5XiXxil9C23lz6Kj2pn3U3QQ3f4zFu37kq5NziVNBiANeqHk3fbu+Vw5XVamZhjM2CWAhUJ3Ljs3tQIWblKtQehSlTyGhSqKGKutCcUgViVXdORaVyMd+MSAshB/9lY57JtLeqyZtGj6Ae8PBLN40XtFnCeM/fHh03jk2AEKvd/gPH154lfRrwGKxiNdee61KbGysVqfTSa1WK6dOnXqidu3a5kGDBtVevHixT1RUVFbDhg0zrqf+Zs2apQ8bNiwiJ3nASy+9dPF66nFzc5M//PDD6XvuuaeWXq+X7dq1S/Pw8LBf/ciyp7iOTU5PbzIQK4SoD1wCPErJLoUyItBTT0YBpyaH6OQsMsw23PWXfyZCCJr17kdIrTos+vIT/nrrFbo+9DhNH/wQ9YfzXNbjk+LAbDejVysLfJYlUkoLztj914QQPjj1mi6lTL6e+oQQamA7EC2l7CeEqAFMB/yBHcCD2edUqIC063Iba9ctx5Fn5EblcNCpY09qtWrDgb+mcfr4YdTSgdc6FQ2pjrpKMCn1NWzw2MN/pMPZvwk6+ReecV50OFoFd5OaDIOd32L/A1AaT9eAlPLRK2ybjXPEtdgo+qzcFKnP9t0IrVKNvfPnE5sUj+qcnYDzWtqpa6OuF050lWQWeh5gBhfQ7Pucqjs/QX3BW9FnCZOTIKCks6JFRkZaNm7ceNTVtkOHDh10Vb5169Z8I0RSyh05n/v165fWr1+/3O0BAQG22bNnny5YR96yoj4XPFePHj3ST548eQBgzJgxIc2aNbsuZ6u0Ka5jMwe4A2cP0284Jx1bUUJZbgrCfIxEJ2e53Nb2wxUMalGFB9tVp1bgZT82tHYUD3z8Ff9O/IKVv//I+cMH8fYWBKYUjp6QAr4a0Z7wR55kYMuHMWpcLyqqUHpkOzPJN1jNC8AhsjM54ZzcPEFKOV0I8QPwOOA6nkKh3Gkx8iUAtqxdTpZKYHRI2nTumVvesX0H2ptMXPx3Kdun/UVaUiwXrTY8zqu5XQQSENmWzAgVK89voNUhP1TS2QDzMGlou8+fGfI/peFUvij6rMRcTZ/hQ+7FlpDAiWkzOfTvItIcySTsNROyX8UwXU38GkdyMSCJ9XG7aHfAX9FnKeB339DEG3VkKjPff/+9/6RJkwJtNpsICwuzTJky5XR52+SK4mZFezHP58+EEFtw9v4qKaBvAlynq1TxZOeanE7I5M8tZ5i08TSd6gTwYNvq9KgXjFolMHp4MuDlsWxdMJsN06egq1WFKtFpRPt5YdJqMFht1IpPxJcU+q/OxLz+KyY1+Q7PoQO4+/ZXcde6l+NV39oIIfRAppSycOyD6/2rAH2BD4CXhBAC6A4My97lD+AdlIZThabFyJdoMfKlQqnhc1AZDAQPuIu+A+7CFBfP5l/+ImnFEhwigzizBdMRDa3xR5B/ro1Kqqh/0Adb4mk0fhFlczGVHCGEBzAe6IBzbamxUsoTebbvk1I2KmZdij5vAq6mT01AAFEjhxM1cjgJew6w5afJOPZsJN1NRfyWLKRaRXsCitQnlgzQKf93bxVGjhx5aeTIkZdKqr4xY8ZcHDNmzHWFspUlrmeTXgUp5Top5RIppePqeytUdAY0C+ejgY0I9zEigHAfIx8NbMxLt0Xx9X3N2DimB6Nvi+RYfDpPTdlB5/Gr+G71cS6lmxEqFW0GDGHIWx8g1e6cCPHDpNOCEJh0Wg5WDcTr6WHU/OgR1PWMdNxtodnLfzN3cCumfXcvaYknrmqfwvUhhKhW1AtnPP+1zAT/EueaODma9weSpZQ5cYzngQqb117h2jGEBNP1zRcZsPJfgl79FJ2xLo1OJSKKmNKutWm4c04f5s8YiC1uf9kaWzn5AojA6XBcALYKIbrm2R5xDXV9iaLPW4qAJg3oO/ETei5bjtvgkXhn+tHk9IUr6vOJSS3Z9e8oyCixtq6CQoWjuOmeq+GcaNyMAvNqpJSRpWCXQhlzpXSVgZ56nu9Rh2e71mL5oXgmbzrD+H+P8OWyY/RrHMpD7SNoWr8ROg8vLIn5H5gSFeu2nqHexN9pdPerWI/v5ujXb9NgzVEMX+9l1ex+ZLb14vY7H8enyb1gyE6/vncmrBgHKeed2V56vKWsvnztnMaZMKAoB6ZYWZeEEP2AC1LKHQUaXsVCCPEU8BRAcHAwq1evvtYqrov09PQyO9fVqEi2wHXYo4c6Tw3geMIdGP783Nl5UQCVlDQ85s3bkUf5edFghtn8iQy+j3TfhiVvTylShrb0A+pJKVOAuUKIxcBMIcQjUsp/iltJZdRnRfp7Q+W3xzvSH4//Pc6uM+kYF3zrUp9qh8Qab+Qh3TLaTlnMEE09PKvcj9kQVKK2lDYVzR6Fikdx59j8DRwG3gJcT8ZQuOnRqFXc3jCU2xuGciw+jSmbzzB7x3nm7IqmcRVvuiS67gVKu5SQ+1lbuykNvp6PIyODIz+8T/Dfi/CancqulRO41Gg83To1xz+gBimzpnFhlwFbZggaNzNB+0fj/QKKc3NtxAIDcU4oLogB53pUxaEDcKcQ4o7s47xwZkn0EUJosnuFqwAus8NIKX8CfgJo2bKldBViURoUFc5RHlQkW+D67ekKzP76A84Gq/NNchYOiXBIgk8HMPywF26kciA0mXXh39I3NIA+HV9DHdkHikg5XZHuTxnaYgTMOV+klMuEEHcC84QQz1P8dM+VTp8V6e8NN489PYDZv39WWJ9SYheCxvtC6bHVhEWXzOKqx9FdeoMHarSgSZexENygRG0pLSqaPQoVj+KGotUFHpVSLpJSrsj7Kk3jFCoudYI9GXdXQ7a80ZP37mpAlsVOqtp1kjy1u3ehMpW7O/VGf0Tr9bsQ7/0PtYc7DdZqOf7FPlZ+PYfzm92xZWoAgS1Tw/nN7qT88E7pXtTNx3agmZTSXvAF2ChmKJqU8jUpZRUpZQQwFFgppbwfZxKRwdm7PQzML/lLUKhobIjqQ93oRAwWK0iJwWKlXvQlTuia07x1V1Te3sQbAgiLr0rf/3wJmJjE3NGjWT+8GZkLJiBtlxNzpSxcyLHuPQh65lmOde9BysKF5XhlZc5+oHPeAinlZqAP8A3FXEBX0adCXlzq8/wlLqrq0aheE1I8PEjRhNLoRCh95niT9PkeZj07kP2vdsG6YzFkr2d3i2tToRJT3BGbhUAXnA/KMkcIMRrnejmBUsqEq+2vUHZ46DU82C6CB9pWZ/D/9tIqegVaeTl9tAQyM7O4eOYUgdVrFDpeaDTUHfI4UYMf48SahaR8P4Gqe+IK7aeyC85ssdO4NC/m5uNpLsfc50NKaeY659jl4VVguhDifWAX8OsN1qdQCeg8/EHmTrAxbN9iArOSuWj0YUqDvqyt1oJlyYLnH72T/p4p7F7wN0eOHOS4CCAwNQXjhiTOrP4J+9s/4dOoDiKsHmmL/0FabQjAFhND7BtvAODdv3/5XmTZ8BFQaJE7KeUuIURP4KUbrF/R5y2IK31ObtCXlVWas85o5O0xzxAUt4/t82exy82ADqhyIQG58CLH5/8P6fcqblVqYDp4Cmmz36raVKjEFNexGQlsFEKcAOLzbpBSPlbiVuVBCFEV6AWcLc3zKNwYQgh2amuS6m+jfdIWPO3ppKk92O9Zn8ZpB/j99f9Rbchw7rqjK0adi0XIhKB21zup3fVODtat53IoQZOhgqxkMPqU9uXcFEgpC3uIN17namB19ueTQOuSPodCxWZAs3AY9ShvLG1PTHIWYT5GXu4dxbgafry38CCfLj3GnEB33nv4FbqqU9m+aC5HNq4lzssbm5sJj9QEWhw8ivfWY0T7eHAk1C83i2JUbCLqTz64JRpPV5pHI6XcD1zz/1ZFnwpF6fNpbwNj5+/nqb/20bNeMG+N+wbLqf1sXzSXkxzgVHgwZk0SYQlJtNp7jBgfz1tWm2WJEKJFVFRUlsPhQKPRyAkTJpzr3bt3es72n376yfezzz4LtdlswuFwiEceeeTiO++8E3+lOm91iuvY/A7YcebIL+s5NhNwZntRhtErOGE+Ro4RyTHP/PkkzvvXp3f0Qs7+9RX3rtpHrfZduatpGB1rB6BRFx40SPCCQBezP7J0EPdFC0JuGwMtHgV1cX++CjlcSwpZBYWiKCrZyA8PtmDV4Qu8veAAw37ewoCmYbz+8Ag63fcwu/5dyN7l/2JS6/mntYPGh1I4F+CdOxfApNOyr2og8txFfH/4AfeOnTDUr4coYl7OzYiiT4WSoCh9Lh7Zid/Wn+LL5cfo9dU6nu9ehyfHfsSl08fYvmgexzavJ8HTm021Mkl107vUpuG55/Do2AmPTh3Rht9aifb2rTnvt/2f0+GZKRadm7fO0vKOiOhGXarc8Lo2hw8fPgjw6aefBjzzzDPVT506dQBg3rx5nu+8806VpUuXHm3UqJH53Llzmttuuy3SaDQ6Xn311Qqfdrm8KG7LsDsQJqVMK01jCiKEuAvnKsp7nGn5FSoyrtfDUfPawHb0qt2baR+Oo8vJ5excl84jO5vi76GnX+NQ7moWTrOqPuT8jZf08uOeeYkYLke0YRfgZoFzf+tYf/wTOjX9keA7PoI6t5X1ZVZ2qpe3AQrlx9EtcWyaf4L0RAdn/ttAu7tqEdkmpETP0a1uEO1q+fPd6hP8sPoEKw5d4H+9o3jgvkdoO/Be9q1cxo5/5nMmqLDD4lCpOBrqR5Uvv+Lil1+h9vfHo2MH3Dt2wr1jBzS+viVqawVE0ectTGnrU6tW8XSXWvRvEsZ7iw7y6dIjzNl5nvfuakj/F18l5cIj7FyygJ2L50GBNpdDpeJIqB9h29aQvtw5vVpXsyYenTrh3qkTbq1aotLrS8zWisa+Nef9Nvx9vLrd5lABZKZYdBv+Pl4doCScG4AePXqkv/XWW1Vzvn/44Ydho0ePjm3UqJEZoGrVqraPPvro/DPPPBOhODZFU1zHZi/OvPgl7tgIIZYDrpT7BvA6zjC0q9Vxy6eThfK3xwd4sJ6a2UcdXDI58DeoGBSpxiflGFt3QM2et3NmFTQ/tpnm7ulscu/Mn1vO8MemMwS5CdqGamgXqsGv7QB+tkxh6Gor/qlwyQumd9VSp0ZXopZsp8GmJI7vz2DloadpUTec5DpPkule7Yq2lfe9KUg52nPT9xCUReO9MnJ0Sxyr/jyMzeKcdpWeaGbVn4cBSvz+GLRqXrotkrubhfPW/P28veAAM7ef4/0BDWnR9y6a3d6PL4bdWWghQYAsnYZRjxtoFZNFu1OJVF22mJT5C0AIDA0bZjekOmJs3BihVpOycCEXJnyJLTYWTWgoQaNerMzhMje1PhVtFk1Z6jPMx8j3D7Rg1ZELvD3/AMN+2cJdTcN44456dHv4SXb8M8/lD9Gk0/DqACNaTHQ+Y6b56TME/nmaxD/+QBgMuLVuhUdHpz51EREIISqFPldMPlQ1MTr9isk6Es6nuzvsMt9tsdscqvUzj0Uc3hgb6OoYv3CPzB4P1TtXXDtmz57t06dPn6Sc70ePHjW2b98+I+8+nTp1yrhw4YL20qVLan9/f3vhWhSK69isBP4TQvxO4Tk2v92IAVLKnq7KhRCNgBpAzmhNFWCnEKJ1wbkDSjpZJxXBnq44vdGibJHdu7N++mS2zvub+/2M/PjKKFYeT2H+7hgWnUhgwQkrVXxacNHPzJonlyK0yUirDzKxD73aPswdz4ZzevViHOM/pOnqRM7tTSC61bvc3r03QT3HgXuAS7sqwr3JSzna06c8TlocLjd6zHj46a+r0VNSjYOSsCV/PTfWkLsee+xWBxmpZjJTLWSmWFg742jufcnBZnGw7u9juPnoMXpoMXrqMHhoUamu3L4urj01AtyZ/Fhr/tkXx7hFBxj4/UaGtqrGq7dHYdVp0FkK/18WCG7bHo5dByurZhHdOAuNw0y92CzanDlI6Pf7SPjuO1ReXmgjIjAd2I+wO6/LFhPD+TdeA659knMFaXTftPosyYb7zaBPi8lGZoqFzFQzGVfRp6e/AaOnDqOnFp1Rw9UiWIprT7eoINqN8uf71Sf4fvUJVh66wEu9IovUJgi67Xaue5PlLvm7fgYX2prwyjLR4pyZZgc24b12HQDaqlXQVqlK+rYtqGyVX58FnZqrlV8LdevWrZ+cnKxJT09Xr1279lBxjhGiqKVYFYrr2HTEmQO/4OiJBG7IsSkKKeU+IHflKCHEaaClkhWtciOEoNN9D+MVEMSKX78n45O3uPvVtxnSsg0XUk0s2BPDJ/8exmpvhjm5Wb5jP116hAHNwono2pfqXe7g9MIZuE/4nFZL09m6dxXxm9pzV5/HCOgwCjQ375D49SCE8AH6AmFCiOrAP1LKpCsfVXa4avSsnHqY9GQz1Rr4Ix0Sh0M63+0y93vBsnV/H3PZOFg/6xjeQW6otSo0WlWhd1WeuV7X2wDLscNud+CwS45ti2fD7OPYrfmvyZRhpVaLIFQqgch5CQp9z2m8FHVvLsWm4xfqke24OB2YjBRL7ndzpq1IW/NiSrcyf8KuywUCjB5aDB463Dy12Q0qZ6PK6KkjKS6DA2ujsdtk/r9VipmIhgFIKZES57vD+bmFpxt/3d2MGdvOsWTTeYbtjOM2Q08clhU4M4/noEHr3Y5uQ5sRfeQg0YcPEnokxnl/VZI1tc1ENzfhaTIRGZtOl317OVS1EWf9BFJmIIQ71RIl8i1nBidtSAiakBA0wcGodLoi78HRLXH8++PfWLM2giMNU4on//7YHhhSJo2nSqHPqYexFfgtpyWbqN7AP1t/ZOvRgcMB0p5Hn1fRpoe/walHjQqNToVao3Z+16nQaFSIPI729egz57fosF9+Hd0Wx8Y5JwrrM9NK7RbBCJVTg5d1CUIlUAlxVXtWTjnMxfNp+IW659NkXo3azMXrbDelW5nz2c7c7yq1yKfH3Pfsjomk2Az2rY7GbivwLM2nT+ffK0er99UKpou/F7+sPcmvcw8zQN8DLCspqE2db3cGvngbcccPE334ID5HDlAj2jkhNk3rYHbzLJKMZgJSTTQ6H02zTec5VM2FPt9+A6HTow0NQRMcgibAH6EunFQo7z0uTX0WZ1Tl91fXN8pMsRR6iLh56yxDXmt15EbOf/jw4YN2u50RI0ZUeeihh2rs37//EEBkZGTWxo0b3du1a5c7t33dunXuNWvWNPn5+bnMeKoAQsorO31CCDXOHPjTpJSmMrHKtR2nKYZj07JlS7l9u6v1CEseZRSgaIpjy4kdW1n01Se4e/sw8LV38QurAkCNMYuLXJlu02vdCfU25n6XNhsnZ/xO0rff4Z5kYl8EJLVXM+iu1whoPIzFa97iq5NziVNBiANeqHk3fbu+VzIXeQNc7f4IIXZIKVuWxLmEEN2BOcAR4AxQDefaVIPKei2qovT5x+sbSE80uziibBAqkevomDOtSBf/MoRK4Omnx26TOLKdl8svB1d5lF67TcJ5Tof96hWrtSrcvXW4eelw89bj5qXL/q7HLbv8n+/3kZFc+B67eevo9VgDMtMsZKVZyUrPfk+zZL+cn4vrKF0LNvMhbKb14EgDlScaQ0c0+noIlUBnVKM3alBrTDisMVhN58hKO0tW6vnctTZUDi0OlY38a1lqCMkIoObFOCQChEAisLrrsHm5I729wM8Xja8fOr8ADP7BbPxvH5aMNRRsyOk9OvHcr6ML2a3os2xRaQQajVOfpoyi9enho3dqM7eT4bJWi73caTHJcXYctqtXrDNqCunTzVuHe57vC7/Z41qfXjp6PFIvjyYvazMzzYop3fleXEepuBSlTQC1RoXOqEZrUKNWpWK3nseSeY6slDOYM51NNCkEWrsOm8pK/lUHNIRkBlDzwmV9OlQqLB4G7N7u4OONys8Pja8/Wr8A3PyDWbd4R4nrc8+ePaebNGlS7I7ygnNssu+Do8OQ2mduZI6NEKKFlHIHgMlkErVr12742WefnR06dGjK3LlzvUaMGFE9b/KA22+/vc6bb74Zc99996Vc7zlvBvbs2RPQpEmTCFfbrjpiI6W0CyG+uNGQsxsle/ExhZuIWi1ac+9bHzHnk3f5a+zLDHh5LOF16xPmYyQ62XXyvQ4fr6RHvWDub1ONznUCUWk01Lr/SRyDH+LUbxOJ/Pl39NNsLNz5Pkc7fEx6vJ0318rcuTqzOs8GqBDOTRnyLfCUlHJmToEQYggwEWcDqty5UqPp9qcaOntK1Zd7T1UqgSjwXaUWLPh6N5kplkJ1GD21dH+oHnarA5vVgd3mwGZxYLc6sNvs2CwObDbn9/1rXC7QjnRIQmv5OO1QC1RqVZ7P+b+r1SrW/32syGvqcl+ks1fb4ew9zenZzulFzft959IzRdYz7J02uHnr0RnUVw1PaX93rXw9ywAanYoOA2sTHnX1Sfl2mwNTupVJYzYUuU+vJxoghMjt7c5xznI/C5G7etL0r3fhpq+X21jKwaKCdr2qYcmyYTbZsGS6Y87yxpIViVpvQ2PMxJRxHmmNxmbaSuEWq4049zji3FWABoQaUCOExrmvJQPizYj4iyBOAGoc1lPkbzQ56zFnlEknWeXW59MNL+tQnUePBcoWfbvHtTa9tNz2aIPL2rTaseV+vvzu/GznwLoYl3ZIhyQs0seFFgtq1fl5/cyi9dl5aGTuqEauFnNGfXJ0m122c2nRK1E8+H473Lx0aFwscVCQIvU5qDbV6vtf9Xir2U5WmoUpb24qcp9eTzRw/l2EgFxtUkiz07/ehdGFNs0q6Ny/JpYsW+7LnOWGJSsAtb4Rar0VdUYK1sxzOGwx2My7KbyUmo04tzjiItQgNIDzXaAGYYeMVMjMQJyPzd3usJ6kHPUJXE4QUBpZ0XIwGAzy9ddfj/7kk09Chw4dmnL33XenxsXFRQ8cOLC21WoV0dHRuu+///7Ure7UXI1iL9AphOgvpVSWnlUoUUJqRzLsvc+Y8/Hb/P3+G9zx3Ogis6v9r3ckCekWZm47x7KD8VT1MzKsdXWGtKxCgIeeWs++hP2BJzk58XNa/jmTVodtIECd3e4JTIVH/5XMZPat5tiEAbMLlM0Ffi4HW1zi4ad32Xjy8NNTq3mQiyNc02FgbZeNg46D6xDRyPX8q4Kc3pdQpC09H61fbFt2rzhbZD0Nu1Qpdj1Ht8UVWY9viHux68kJ2bjeuQlqjQp3H/0V/1Z1WgYX256Veiu9s7Ro80xTtiL5T29l1IBaVzxWOiRWs51vHhlQ5D51W3fGYcnCYTVjz37ZbGYsVjNWWxY2qxWb1YbDZsfheh1bKJtEoJVbn82Kp88itTmoDlXrFVqntEjOHLhUtD4fuQZ9Li9an426Xos+44usxyvA6OII19yoPrV6NVq9sUT0uaIIbS7TW3mpT8RVj3fYHVhMdiY+dneR+9Rt2QG71YTDasrVqMVmwmq1YLVZsVotOKz2bH0WMSpWtol6adSlSmJJOjIAOaM1OQwfPjxx+PDhued49tlnE5999tlEgHfeeSf4k08+CevXr19qSEiIkjigCIrr2BiAWUKITcA58nSRSSkfKg3DFG4dfEJCGTruU+Z9+h4Lv/yErg8+wUcDW/Lp0iP5FhjLycs/qmckSw/E8eeWM3zy72G+WHaE2xuG8kCbarSu4UedMe9gfWw4+3p0wWjNfy6DDfqsveXm3E0BRgBf5yl7FphcPuYUpt1drnsr29115QZuQW60cVCStlS0esB5fyLbhGSHQna45uNL0p7UYB3/xlvobNLgJQWpQrLWYOOS/9X/LTlD1TQItQfSnl54u9qDvqP/V2xbvhp8JzZ1YedGYy+TNXRuCX2WhDZLypaKWA9UHH0Wpc1T7pKEdDMBHleew6pSqzC4q66sz5dfKbY95azPCsM777wTryzOeXWK69jsz34pKJQKbl7eDBn7AUu++ZzVk3+mepMdPBx9jrRLCXj6BxCV/hDgdGx0GhX9m4TRv0kYxy+k8eeWs8zecZ6Fe2KoHeTB/W2qMbB5FQxW1+cKSAWr3YpWrS27CyxfmgHPCCFewZkEJBxnYo4tQoi1OTtJKTuXk30l1ujJqetGGgclZUtFq6ekKCl7ckZmf9Jf7l0WgMiwM2nDKR5uH3HV8LqmvYaya8kkCsbeN+019JpsqVLTyJlTGcg87SThcJaXAbeMPkui4V7RdHUz6tOVNrVq53y/vl+v49thzWkVcfVRtptEnwqVjGI5NlLKd0vbEAUFrU5Pv1GvMuejdzmz53IWmLSEi/z307cA1OvULd8xtYM8ebt/A17pXZeFe2P4c8tZ3l14kE/+PcxkTz2eaYWH5O0qeP2tVnQf9jK969+HStz0vT4/U4HCWooip9FTESgpW0qiIVeS9pQUJWFPzgjsp0uPEJ2cRbiPkRHdarHi0AXeWXiQbaeT+HhQIzwNRXdAdM8ORduzbCYOWyoqjRdNbrsnt7y4DBo/g9mv3EvM8WQsGg06m42w2j4MGj/jei/vWlD0eY0o+rwyN2qPK22+3DuKOsEeDP9zJ0N/2syrt0fxZKeaV+x8uEn0qVDJKO6IDUKIrkBOt3k0MEVKuap0zFK4VVGp1CTGFM68aLOYWTd9ciHHJgejTs09LatyT8uq7I9O4c8tZ/j+5EBe3D0Dnf3yELZNJbDoVTw228yhLe/zv94TGTz0Y9pXLbfO0FJHSvlHedugoOCKAc3CGdAsPF+WwKGtqvHD2hN8tvQIh2JT+e6B5tQN8Sqyju6PDLjmhpIrchpJZZ1dUtGnQkXElTYBFj7fkVf+3suH/xxm++kkPh3SBG/jlTsfKrM+FSofxeqqFkI8AcwE4nCmpYwF/hJCPFmKtincoqRdcp2BsajygjQM9+ajgY1ZXbUFE5reS7zRBwcQb/Th82ZDuee2Dwl+eQR1klQ8+WsSh59/htG/9edAwoESvIqKhRDiUSHESiHEkez3R8vbJgUFV6hUguFdazPtybakmW0MmLiBWTvOl7dZpYqiT4XKgpdBy/cPNGdsv/qsPHyB/t+sZ3+0kqRLoeJQ3BGbV4DbpJR7cgqEEDNwZnKp8EPoCpULT/8A0hIuFir38C1+5hyAMB8jq2nB6qot8tejV6O9/2nq3/soF8ePofWc5bT67DhLVg5h2v/bu/O4KKv9geOfwzCALIqAoCCisgwi5gZuqQiWmlfTMs2u2XK9WVk/Wu61tD0rW8xKy9umpWWmFWallVaK5hqamoqgpJKCCi4oyDrM+f0xA43IMgLDDHDer9fz4lnP850Hvg9znuWcWwYyNe5JgloG1ekz2BMhxJMY77bOxdhPRhDwmBDCX0r5kgXbuwCbAGeM54yvpJTPCiE6AcsBb2AXMFlKeWV7ropSC/06e7MmfiDxn+/mv1/uJenoOZ4f0xUXbc1N5zYmKj+VxkYIwZSBnegR2IoHl+3m5ne38tzortzWJ7DG9+IUxdosfbnAG0iuMC8VuLpvmopigUET78DR6cpWV0r1ei6eybK4nOnDdbSo8CVI4yDIKyolbu5Gvj18Hr/n56Nbu5ZW/YMZucvATc/+ysLHRzJ74zOcKbC47y57929gmJTyAynlWinlB8AIYKqF2xcBcVLK7kAPYIQQoh/wKvCmlDIEOA9Mqf/QlebM18OFpVP68kBsMCt2Huem/23l6JlLtg6rvqn8VBql3kFerP6/gfTt5MUTX+/j0S/2kl9c/x35NnX5+fni3//+d/vAwMDI8PDwiMjIyC5z5syptn+CWbNm+Z45c6b8C864ceM6Ojo69k5PTy9/LnDhwoWthRC958+f7w3w8MMP+3/22WetrPdJ7IOlFZvNwBtCCFcAIYQbMAfYaq3AlOary6BYhk19EA+fNiAEHj5t6H/LbRj0epY/+zjnT1begWJFY3sG8PLN3QjwNLacEuDZgrnju/PNA9fi79mCR1bsZcL72zgkWtFh0WqCl75P6w4e/HODgYHTv+TFZ4fy9q755BXnsebIGoZ9NYxrllzDsK+GsebIGmsegvrmBlS8BXYWsKhJGWlU1man1jRIIA74yjR/CTC2zpEqSgWOGgemDw/no7uiyMwp4Ma3N/Pj/pO2Dqs+qfxUGi1vd2cW392HR64LY9WeDMYu2EJa1pVNPDcFe3763uu9eyd3m3vrqN7v3Tu5256fvq+Xi/uTJ08OOn36tPbgwYMHUlJSkrds2ZKq0VR/Z/r999/3O3v27GUrhYSEFHz88cflMS1btsy7S5cu+WXTb731VuakSZOa/HODllZs7gO6AxeEEKeBHNP0vVaKS2nmugyKZeqCj/nP8u+YuuBjBoyfxPhnZqMvKmLFczM489cxi8oZ2zOALTPiWDzCjS0z4hjbM4DugZ58ff8AXh3XjT+zLzH67c08881+CrsMIPi73+jw4oP4OQvu/baYzo++y4OvDuL79x7nqdeO8/nLJTz12nHWvjfT7is3QoiyZn5+BD4TQuiEEC2EEOEYv+isvYqyNEKIPUAW8BPwJ5AjpSy7PHeCsva4FcUK4sL9WBM/kM5t3Lhv6e+8sDqZktIqOtZsBFR+Kk2FxkHw0HWhfPKvPpzJK+bGdzbz7d5MW4dVr/b89L1X4pIPgy7lnHcCuJRz3ilxyYdBda3cpKSkOP3444+tFy9e/Je7u7sEaNWqleHRRx8906dPH93q1as9ytYNCAjolpqa6vT000/7ZWVlaUeOHBkaHh4ecf78eQeAcePGnUtISPACOHnypGNWVpa2S5cuBWXbjxs3ruP8+fO9S0tLiYqK0i1cuLA1wOLFiz179+6t0+ubxt22Kt+xEULcKKX81jR5Rko5WAjRHmMvyZlSyqb9Nqdid/w6BXPrc6/w5YtPseL5mdzy5Av4dQ6pVVkODoJbozswoms73vgplU+3p7P6j5M8PkLH+JunETb6bi7OexS5YgOPf1ZIqQCNqV/PNhfh7u9L+ELzLP94+R/1+Anr3Q9AS+BB4B3gD4w5X4KxMZB4SwuSUpYCPYQQnhh7RQ+3dFshxFRMj9X4+fmRmJho6aZ1kpeX12D7qok9xQKNO54HIyTLHRxZtPkoG/en06ethrXH9JwtlHi7CMaFaRngX/s+qhrw2DTb/GzMf38NwZ7iudpYno7W8L89euI/382qLfvo1FKwKs2+83Ptu28Fnjme7lrdOlnHjroZSvWXvUBUWlLisOHjDzoe2PBTm8q28QkMyh9+/8NXNvNq5vfff28RGBhY5O3tXWppvC+88MLpjz76yPf7778/rNPpyt+b8/PzK/H09NTv2rXLZe3atR5jx449d/DgwSvu/Go0GpYtW3Y0NjZW17Fjx+Inn3wycP369amOjhY3lGzXqvsUSzGedMF4W7ylqTKjKjSKzXi378DE517lyxef5ItZT3DTjGdpH9611uW1ctXy/JhIbo3uwLPf7ufxhH0s++04L4zpyjWPvYfHHYfZNfxG3Ct0h+Oihxt+sftn/QWAlPIicIcQ4i7AB+OFilpd6pZS5gghNgD9AU8hhKPpqnB7jM3AV7bNB8AHAFFRUbKhmuq0p2ZB7SkWaPzxXB8H3+3N5D9f7CEt5++eeM8WSj49WEpEl4jyvjisHUsdNNv8bOx/f9ZmT/HUJpZR1xt47ccUPvz1KEKANF0UbGT5eZmKlZqa5tvKxIkTz3700UfeW7du9Vi5cuWf//3vfys90GFhYcVPPPFExogRI8LnzZt31LyC1NhVV7E5JYR4EGOjAY5CiFhMJ2JzUsr11gpOUSrj2bYdtz73Kl+9+BQJs59h7H+fJuiaHnUqM8K/JV/c259VezKY/X0KYxZsYWJ0INOHh+N2ZR+fAPhchA+TFjDhmttp5WyX7+MJU8tIFfPWvazlGinlEQsKaQOUmL40tQCux/hi8gbgFowtL90JfFOPsStKtUZ39+eF1clkVeiEt6CklDlrU2v9xakBqfxUmiStxoEn/xFBwu8ZnLt0+fdle8zPmu6qALx37+RuZY+hmXPzbF08afabqbXdd69evQqOHz/ufO7cOQcvL6/LLmg4OjpKg+HvWUVFRTW+PnL77bfnhIeHB3Tq1KmoU6dOJdWtu2fPHldPT0/9iRMnrvhcjVl1B+kujC8bvg84AR8BiyoMC60bnqJUrqVPG2597hVa+7Xj61efI23njjqXKYTgpp7tWf+fGKZc24kvdp4g9vVEStyrWB/ofs87fHjfIN798Xl7bEXNFUirZjhsYTntgA1CiD+AJOAnKeVq4HHgUSFEGsaWExfVb/iKUr3s3MqvOmTmFFQ6386o/FSatPOXKr8J0Ejy8zL9brktQ6PVXlbx0Gi1hn633GZZa0ZVCA8PLx42bNj5f/3rX0F5eXkC4OLFiw5vvvmmT1BQUNGOHTvcAFavXu1x9uzZ8psRbm5upTk5OVe0MNCqVSvD888/f+KFF16oNq5Vq1Z5bNy4seXevXsPfP755z6bNm2q9lG8xqTKio2UcquU8jopZShwTErZqZKhcwPGqiiXcfNszfhnX6ZNx858O/clUrZsrJdyPVy0PDUqgh8eGkREu5ZsDO+NoewFGxODRqLt44NHO7hhezGDH1nO9xNjeH/hVDJy63Seq0+XpJQaKaVDFYNFHYJIKf+QUvaUUl4jpYyUUs4yzT8ipewjpQyRUo6XUlZxb0tRrMPfs/KGw6qab2dUfipNWiPPz8v0uH7kuSF33pPu5tm6GIx3aobceU96j+tHnqtr2Z988slfXl5e+vDw8MiwsLCIvn37hkspefLJJ0+tXLnSS6fTRSQkJHi2a9euvKZ4zz33ZN16663B5o0HlJk6der5oUOHVvms/KlTpzQPPvhgx08//fRoQECA/sMPPzx69913d7p48aKlDYrZNYveFDK1g68odqeFuwfjn3qRr1+dxZq3X6ekqIhuccPqpewwPw+W3dOXXqcuAjAseScyH4Qr/BIRxYqIf7Fl+mBKNn/OscULuOb3HJxf/5X9S65j3ZDODJ72KsHtIuslllqSNa+iKI3X9OE6Zq7cR0HJ3+/dttBqmD5cZ8OoLKbyU2nSGnl+XqHH9SPP1UdFpiIPDw/DRx99dBy44pG4gwcPmvchWb58+vTpZ6ZPn17+mEhCQsKxyso2n28+fuLEiX1l49dff/2lP//880Atw7c7FlVsTM8Bv4Sx86/LHsyRUnao/7Au2/f/AQ8ApcAaKeVj1tyf0vg4tXDl5pnP8e0bL7Pu/fmUFBbQa+SYeilbCEFOfglvtL+NN9rfdvmynALQOKKNmUxozGQMmckc/+A5Wv38Bx2+PMK578aTFOVJt/tm0jXqRgAuLHiSrI9X4pcnOewu8L37Zlo9UGPn4rUO31oFK4o9KHtOf87aVDJMj7dMHx5mV8/vV0Plp9KkVcxPRwfByzd3ayz5qTRSlrbttgxju/j/AfJrWLfemBosGAN0l1IWCSF8G2rfSuOidXZhzH+fYs2819iw5ENKioroe9OEeinb37NF+Zcmc+1auVw27eAfQdBzX9DhiQJOfzmH0198ReSWHNj8OKvDniYwMADHjUdw0AtAoM+DE+8mAFirchNhjUIVxZ6M7RnA2J4BpGXlcd0bG3FytOgJLnug8lNp8sry8+MtR3n+u2R6dvC0dUhKE2dpxaYrcG1tm6Csg/uBV8qeDZZSZtWlsEM7TrHtmz/JO1eEu5cz/ccEE9a3bR3KMZC+bks9lGP7eOwpltrG46jVMvqRGfz47ltsXv4JxQX5DLztTspaGKqtym6nAzhrHbiQX0Ir18vb5BdOLWg76RnaTnqGnN+/J+m92fgmncXp0FFO+UbzZ+cbKXL2wrnoHMFHvqV08UquqeeKjRBiJfAyldzaNlsnGpgppby5XneuKDYQ3MaNQK8WJKZmcXu/IFuHUy2Vn0pzE6vz5fnvkklMzebOAW62Dkdpwiyt2GwCegK7rBhLZcKAQUKIl4BC4L9SyqTaFHRoxyk2fJaCvthYN8s7V8SGz1KMO7mKL95NsRx7iqWu5ThoNNww7RG0zs789s1XHNmdzLnMExj0F9n94Qd0v34CcXeNtTgWMF5xunT4AhkbT+FaKsnXCPRdPViccYYJ72/jkyl98GvpUum2nr1Gcv0HI8k/l8H2sTNI1f0Tg8YZgCIXb1J0/0RX64Yiq/U+8D8hREtgI5AK5AIeGPNqCJADPGWVvStKAxNCEKfz5YudJygsKcVFa9d3blR+Ks1KRx83Ovu4sT4lizsHdLR1OEoTZmnF5hjwoxDia+CU+QIp5TN1CUAI8TNQ2bfVJ03xeQH9gGjgCyFEZynlZS9dWtJz8qFvDegrtDyoLzbwy9Jk9u48iLTwNc6zqRJDhZbBzcu58gNWPn0muYpyPktm/76DCOPTSjX+zNghKa3kc61flkxqmulzyb87yCq/51Y2T8KpvRJDFcfmj91mn0ma3naVf0+XL5LVH5s9SX+Xc8UNFHH5eFXHZv2yZA4dOYjQgIOjcSgf1xjHy+7OOIZ0pcWeFM789fd7dwb9RXb/sJiMjAwCr7W8U8+cYwYuJIFbqTFAt1IQB3J5qIsTb5/MZeTc9fynlwu+LgKpB0OpcZClYND/PX4ybHx5paY8Jo0zacE34lDPPSlLKdcCa4UQUcANQF/AEziPsYfziVLK3fW6U0WxsSHhvizZls6Oo+eICau0M3C7oPJTaY6G6HxZuiOdguJSWjjZ9YUHpRGztGLjBqwGtEBgfQYgpbyuqmVCiPuBlaaKzG9CCAPGnpmzK5RRY8/JB5ZX3o+ooQSy9tW9cZp6K6cYTu6sezmlRfDXr3Urx1ACp/fUz7HJ3l8/nyl9YzXlCHB0ckDr5ICjVkPhubOVrKQne/9m3F36l8+RFWu1ZhVBkGT9lYssvXwdWQocEDykccWgl5z/Ac7X1MiRY+Ud4hQ7e1mtJ2Up5U5gp1UKVxQ707+zNy5aBzakZNl1xaaMyk+lOYkNb8NHW46y7cgZ4sL9bB2O0kRZ2tzz3dYOpAqrgFiMnY+FYewotFa9ILp7OZN37spm/N1bOzP5RdOX3CrexTCf+8lTW6stx+z7cPkdDfn3SPmPZc9uJ+/8leW4eTozfkYUBoNEGiRSSqTB+OXbOI/y+QaD5Pt391Fw8cpOsFxbOvGPB65BCIFwEAhBhZ8C4WC8w5Hw2i4u5VT+mSY+09f4+YXpbojg7+myCdOPT5/eVvmx8XJm8osDTB9eVn2MTOOfVXFsXFs5MWJqN/TFpeiLSykpLkVfbDCOF5mNm35m/5l7RRkA0nD5fAcHYfZLNo6Y/ykY9FVUWCR0jw0kT1/KV3szuFCsZ2L/DnTt4ImjVoOjkwOOThoctcafX8zdRmnelc3EO7a0TquvQgg3ACnlJdO0AP4NRALbpJTLrbJjRbERF62GAcE+bEjN4lkZUef366xJ5afS3PTp5IWrk4b1KVmqYmMihOit0+kKDAYDjo6O8s033zw+fPjwPFvGNG7cuI4xMTG58fHxZx9++GH/6OjoS5MmTbpg6fabNm1yXbBgQZsVK1akp6amOq1du9YjPj6+sivN1erTp4/umWeeyRw1alTlX+aqUG3FRghRY2c9Vm5Q4CPgIyHEfqAYuLPiY2iW6j8m+LL3NsB4db//2GAcNJb3SVRv5YytvJwBNwXj5ulczZaXGzgupNJyrh0Xgm9QS4vKGHBT1Z/JuYWlN/WqOTZjgo2VB8CSFk6rOjbX3hxCu+BWFsez76eWGPQXr5jv4NiSm/7Ty+JyljyxpcoK24Bxxi6eeowM4q6Pkpi+6wivd+7O2B5XPl0ZNz6Snz89gNT/fQyEoyRunNX6ullhGj41Tb8O3AWsB+YLIQKklHOttXNFsYVYXRvWp2Rx9MwlOrep/C6pnVD5qTQrzo4arg3xYUNKNlJKu77w0JBSUlKSAebMmeNz3333BR09etRu+pR56623Mq92m8GDB+cPHjw4HeDw4cPOS5cu9alNxaa2avomrgdKqhjKllmNlLJYSnm7qTflXlLKyp8ns0BY37bETgrH3ctYaXD3ciZ2UvhVt9jVFMuxp1jqs5zu10+gsrp7aHTsVZXTf0wwjk6Xp0pZha2Mr4cLK+7tR3RHLx5esYeFvx65opywvm25bnLXyz7XdZO71qrVOAv1Br4DEEI4AfcAt0gpxwOjTNOK0qQM0Rl7BdiQml3Dmjan8lNpdmJ1vmTkFJCWZdObEnZp6NCheadOnXIqm77zzjsDIyMju4SFhUWMHj26U35+vgCYP3++d1xcXMjQoUODO3fu3DUuLi6koKBAABw6dMipd+/eutDQ0K6TJk3q4O/v3y01NdUJICkpyWXAgAFhkZGRXbp169Zl7dq1NV75GTduXMf58+d7l43ffvvtHaKionTt2rXr9tJLL/nOnTvXp1u3bl2CgoIif/75ZzeA1atXe/Tp00cHMH369MD9+/e7hoeHR0yZMiUQ4Mcff3Tv3bu3rmvXrl2ioqJ0u3btcgE4ffq0ZsiQISHBwcFdhw0bFlxYWFirmm9Nl+M71aZQexXWt229fIksKycxMZEhQ65tEvHYUyz1FU9Z62d7f/oCg/4iDhoPNFrJiYObuHhmLC19LHsGvyyOmpqf9nDR8vHd0Tz6xR5eXHOQ7LwiZowIv+yqVH0dHwu5SilzTONRgF5KuQFASvmbEKKdtQNQlIYW6OVKqK87G1KymDLQrv+FqfxUmp3YcOP/3fUpWYT6edg4GvuSkJDgecMNN5wvm37llVdOtmvXTg9wxx13dJg3b57PzJkzswH27dvnunfv3uS2bdvqY2JiQpcsWdL6vvvuO3f//fcHTpgw4dzjjz+e/cUXX7RctmxZG4CSkhKmTJnSMSEh4UhoaGhxcnKy0/XXX687fvz4PgcHy582Sk9Pd962bVtqZmamNiIiIjI+Pv7kvn37Di5cuLD1s88+63/dddcdNl9/zpw5x2fNmuX/22+/pYKx8vLYY4+1/+WXXw63adOmdN26dW5TpkzpuGfPnpQZM2b463S6wsTExLQtW7a0GDx4cK36+qq2YiOlTK9NoYpiL+LuGkvcXWNNFYkhnPnrGJ8/M51Vc15g4vOv4uTSwqJyLK1ouWg1vH1bL7zc9vP+xiOcyS3mlXHd0F7FY4r1KFMIcY2U8g9gGPBr2QIhhCdw5fN1itIExIb78vGWo1wq0uPmbPnjtA1M5afS7LRr1YLwth5sSM3i3pjgmjdoBsLDwyNycnIc8/LyNJs2bSpvQnbFihWtFi5c6FtcXCxyc3M1er2+fJt+/frl+vv76wF69ep16ciRI84ASUlJHl9++eVRgAkTJly85557SgH27t3rkpaW1mL06NEhZWWUlJSIjIwMx8DAwL8LrsGNN954XqvVEhQUVOLh4VE6ceLE8wD9+/fPnzVrVo3vUWzYsME9PT3dZdCgQbqyeRcuXNAAbN++3WPx4sVHAa699tqCsLCwK3tGt4BNvm0piq34dOjIqIdncCb9GN+//ToGQ2nNG10ljYPghTGRPHJdGAm/n+DeT3dRUFz/+7HA68A6U2eA04H/mS0bjrFZ2RoJIQKFEBuEEMlCiANCiIdM872EED8JIQ6bfrau90+gKLUwRNeGklLJlrRatTXTUFR+Ks1SbLgvO4+d52KhVd9maDRSUlKSMzIy/rj99tuz77jjjk4AqampTrNnzw5Ys2ZN2qFDh5IffPDB00VFReXf2Z2cnMrfN9doNOj1+mof2zIYDCIgIKA4JSUluWzIysr6IzAwUB8XFxcSHh4eMWDAgLCaYnV2djbfr3RxcZEAjo6OsrS0tMZHxwwGA7169cozj+PkyZP7atruaqiKjdLsdOrRm9i77uHPnTv4ddkSq+xDCMFD14Xy0k2RJKZmMWnhds5furL1OmuSUi4CbgW2AMNNfWeUKQCet7AoPfAfKWUExj6lHhBCRAAzgF+klKHAL6ZpRbG56I5euDs7siE1y9ahVEnlp9JcxYX7ojdINh+26wsPDUqj0fDWW29l5OTkOC5fvrxVTk6OxsXFxdC2bVt9bm6uw/Lly70tKSc6Ojp30aJFXgAJCQktL168qAHo3r17YVFRkVixYkV5C0ybNm1yBVi/fn1aSkpK8tatWw/V9+fy9PQszcv7uznYuLi4vP3797tu2bKlBUBpaSmbN292Bejfv3/u4sWLvQC2bdvW4vDhw5Y9UlOB3d6jVxRr6jliNOcyT7Dzu5W0bhfANUOHW2U/k/oG4e3mRPznexj//jYm9e3Awl+PkpFTQMD29UwfrmNszwCr7BtASrkRY8/mFed/exVlnAROmsZzhRAHgQBgDMYe0gGWAInA43WLWFHqTqtxYFCo/be+pPJTaY56BnrS0sWRDSlZjOymXiUr4+LiIp944omMV199td3u3btTBg4cmBsSEtLV29tb37Nnz0uXLl2q8WbEggULjv/zn//s/OGHH/pGRUVd8vb21nt5eZU6OzvLlStXpsXHx3d45plnAkpKSkRUVFReWetl1tK3b998b29vfVhYWMSgQYNyFy1adHzp0qVHHnzwwaD8/HyHkpISMXr06PMDBw7Mf/nllzNvvfXWTsHBwV1DQkIKIyIiLtVmn1dVsRFCBAIBUsrttdmZotiT2Duncv5kJr8s+h+efu3oEHmNVfYzIrIdS/7lxF0f7eD575LL52fkFDBzpfEOrDUqN0KIWTWtI6V85irL7Aj0BHYAfqYvVQCnANUxgWI3YnW+/LD/FCmncunSzrKm7xuSyk+luXLUODA4rA2Jh7IxGKRZdxD2LW97ptfFX44HGHKLnRw8nIpbDg3McO/nf64uZUopd5lPT5s27dy0adPOASxbtqzSSkd8fPxZ8+aT33jjjfImmQMCAvRJSUkpGo2GdevWuW3dutWjTZs2pQBRUVGFltyVSUhIOFbTOEBGRkb5I2Q6na64bHrUqFG5o0aNSgXQarX8+uuvlzUoMHz48Lzhw4enVNyvn59faWJiYlpN8dXEooqNEKID8DnQA2M3iu5CiFuAEVLKf9c1CEWxBQeNhtGPzODzp6fz3Ruzue3FuXj5W+fuSf9gb1q5OpGVe/n7wAUlpcxZm2qtuzaB9VmYEMIdSAAellJeNL8KLqWUQohK+5gSQkwFpgL4+fmRmJhYn2FVKS8vr8H2VRN7igWaRzxOhcZ+sBZ9v51RwU41rG3dWKrQbPOzOfz91YU9xWOtWNrJErJzi/nku/V0bKWxeTw17nd7plfO6qNB6A0OAIbcYqec1UeDAOpaualPSUlJLaZNmxZkMBjQarVy4cKFR20dU0Oz9I7N+8AaYBBQVkv8CVCdhymNmrOrG2Mfe4ZlTz7Kqtee57YX59LC3TpNUGbnVt7IUWZOrRr+qJGU8u76KksIocX4pekzKeVK0+zTQoh2UsqTpqZpK32hQUr5AfABQFRUlBwyZEh9hVWtspbw7IE9xQLNJ56Fh38lvUTDkCEDbB5LRc05P5vL319t2VM81oolMq+Ihft/5qJ7B4YMCbVpPOe+OhRYcuqSa3XrlJy85EapvPzWkt7gkPPdkY6Xdp6utO8IbVu3fK9bwo7XY6g1iouLu1TW4WdzZWnjAX2AV6SUBox3bJBSXgAs7wZeUeyUp19bxvz3KS5mZ/Hd3NmU6q3TUou/Z+XvwVU135qEEN2EEF9auK4AFgEHpZRvmC36FrjTNH4n8E39RqkodROr82VX+nku5Deu1pdUfipNnY+7M9e097TrBj4uU7FSU9N8xWYsvWNzGggByp/NM7W68pc1glKUhhYQHsGw+x7ih3fm8vPC/zHs3vh6f+F4+nAdM1fuo6Dk76afW2g1TB+uq2ar2hNCuAIzMT5Cehh4DvDBeKf1eowvFFviWmAysE8Iscc07wngFeALIcQUIB2YUE+hK0q9GKLz5e31aWw8nM2N3f1tHc5lVH4qzV2srg3zfjnM2bwivN1r7ALFaiy5q5L50o5uhtziK55pdfBwKvZ7sGdqXfa/YMECr3nz5rUVQlBSUiImT558Jjo6Ot+8Y0tLrVu3zm3atGkdtVqt/Oqrr/785ptvWn744Ye+vr6+JU8//fTJsjI3bdrkumDBgjYrVqxocv1VWlqxeR1YLYR4GXAUQtzG3ydORWkSIgbFcj7zBNtXrsArIJDo0TfXa/ll79HMWZtqbBXNs4W1W0VbgPFF4rXADUA3IBzjF6Z7pJQWtbUppdwMVFXLG1oPcSqKVfQI9KS1q5bElCy7q9ig8lNp5uLCfXnr58NsOpzNTT3b2zqcarUcGphh/o4NAI4OhpZDAzPqUu7Ro0e1s2bNar979+5kf39/fWFhoUhOTnbOzMzU1qa8JUuWeE+dOjXrscceywYYPXq078qVK//s2bNn4erVq8ufsx88eHC+tVtEsxWLHkWTUn6EsQOx8cBxjLe1n5ZSfmbF2BSlwQ0YP4mwfgPZ9NnHpCXVf+N/Y3sGsGVGHItHuLFlRpxVm3rG2MnfMCnl48BIjF9y/imlfMrSL02K0phpHAQxZq0v2RmVn0qzFunfCh93JzakZNs6lBq59/M/5zmqU7qDh1MxGO/UeI7qlF7XhgMyMzMdnZ2dDV5eXqVgbPK5V69ehQBFRUVi7NixnUJDQ7tGRUXpTp486Qgwbty4jvPnzy/v16ZPnz661atXe7z44ou+q1ev9nrzzTfb9u3bN+ymm27qePz4cedbbrkl+N57772s5rh69WqPPn366MrGu3fvHl7Zvk6fPq2JiYkJCQkJ6Tpy5MjO11xzTbh5BckeWdxBp5TyGynlSCllVynlCCnlKivGpSg2IRwcGDHtYdp2DmHN23M4ffRPW4dUF+5SyiwAKeUJIE9K+auNY1KUBhUb7su5S8XsPZFj61AqUvmpNGsODoKYMF82HspGX2qwdTg1cu/nf87/yb772r8yaJf/k3331UdraP369Svo3LlzYWBgYLcbb7yx07x587wLCwsFQGpqquusWbMyDx8+fCAsLKxw3rx5PtWV9dRTT2Vdd911OTNnzszcsWPHoa+//vqYr69vyffff3/4/fffP1HdtlXta8aMGf4REREFaWlpB5577rmTycnJbnX9zNZWZcVGCPEvS4aGDFZRGoLW2YUx05+mhXtLVr02i7xzZ2veyD45CiFihRBxQog4APPpsnmK0pQNDm2Dg4ANqXZ3VVjlp9LsxYX7cqGghD3Hc2wdik1oNBoSExPTvv7667QePXrkv/POO23j4uJCAMLDw/OvueaaIoDo6OhLR48etdqLSFXta/v27R533XXXOYA+ffoUhIWF5VsrhvpS3Ts2ky3YXgIf1VMsimI33Ft7Mfaxp1n+zGOsmvMCtz73ClpnF1uHdbWyuDw/z1aYlkDnBo1IURpYazcnenZoTWJqFo9eH2brcMyp/FSavYGhPmgcBBtSs4jq6GXrcGxm4MCB+QMHDsy/9957z7Zv3777mTNnsp2cnMqfn9VoNFKv1wsAR0dHaTD8fYerqKiozi0dVbWvxqjKio2UMrYhA1EUe+PbsTP/eGg6q+a8yIrnZ5J/IYfcs2fw8PZh0MQ76DLIvlNEStnR1jEoij2I1bXh9XWHyMotxNfDPi5QqPxUFGjVQkvvoNasT8lm+vBwW4fT4I4dO6ZNT0/XxsTE5APs2LHD1cPDo7R169alVW3TqVOnoqSkJDfg7O7du11SU1Or7YOnLvr165f7ySefePXt2zdj586dLocOHWr4/imukqWtoiGE8AT+AfgDmcAaKWWOdcIq32cP4D3ABdAD06SUv1lzn4piLrh3X8IHDCZly8byeblnsln3wTsAdl+5URTF+J7N6+sOsTE1m/FRgbYOR1EUM3HhvrzyQwqnLhTStpV9XHhoKMXFxWLmzJntT548qXVycpJarVYuXbr0TweHql+Bf+ihh86MGjUqODQ0tGtERES+Tqez2uNhL7/8cub48eM7BwcHdw0NDS0ICQkpbN26td5a+6sPFlVsTM/6rgRSMbaH3wFYIIQYJ6X8xYrxvQY8L6X8QQgx0jQ9xIr7U5QrZKRe2YmvvriIX5d/oio2itIIRLRria+HM4mqYqModidWZ6zYJKZmMbFPB1uH06DCwsKKt27deqiyZaNGjSrvwyY+Pv5sfHz8WYB27drpd+3aVWn/NgkJCcfMpzMyMvaZlZdbVmZV4xX35enpafj555/TnJ2d5b59+5yHDh2q69atW1GtP3ADsPSOzTvAVCnlF2UzhBDjMbbDb817hxJoaRpvhfFOkaI0qNyzlbe8WtV8RVHsixCCWJ0v3+87SUmpAa3G4gZBFUWxsjA/d/xbubA+pflVbOzdX3/9pR07dmxwaWmpkFLy5ptvprds2dKum7CztGLjDyRUmPc18GH9hnOFh4G1QojXMbbgNsDK+1OUK3h4+5B75soWlTy8q215UVEUOxIb7suKncfZlX6efp29a95AUZQGIYQgNtyXVbszKNKX4uyosXVIiklYWFhxcnLyQVvHcTUsrdh8CjwAzDebdz/wSV0DEEL8DLStZNGTGDsse0RKmSCEmAAsAq6rpIypwFQAPz8/EhMT6xqWRfLy8hpsX5awp3jsKRaoWzze3aPJ27gOqTd7rFQ44N09utZl2tvxUZSm7toQb7QaY+tLqmKjKPYlVufLZzv+Yuex81wboi4aKrVXZcVGCPErxkfBwHi35D4hxGNABhAA+AF17ppdSnlFRcUshk+Ah0yTXwILqyjjA+ADgKioKDlkyJC6hmWRxMREGmpflrCneOwpFqhjPEOGcLBLF35d/gm5Z8+gdXampLCQ3n360rFH74aPR1GUq+bhoiW6oxeJKdnMvKGLrcNRFMXMgBBvnBwd2JCSpSo2Sp1Ud8emYiXC2o+dVSYTiAESgTjgsA1iUBS6DIotbyigpLiIz2Y+wg//e5M7XnsbN8/WNo5OURRLxIX78uKag2TkFBDgafetlipKs+Hq5Ei/zt6sT83iqVERtg5HacSqfINSSrnEksHK8d0DzBVC7AVmY3rcTFFsSevkzKiHHqM4P58f//cm0mDX79EpimIyROcLwIaULBtHoihKRbG6NhzJvkT62Uu2DkVpxCxuGkYI4SeEGC2EuFsI8a+ywZrBSSk3Syl7Sym7Syn7Sil3WXN/imIpnw4dGXLnvzm293d2rVll63CsSgjxkRAiSwix32yelxDiJyHEYdNPddtKsXvBbdwI9GpBYmrTqdio/FSailjThYfE1Csb62mqhBC9w8PDI8LCwiIiIiK6rF271t3WMY0bN67j/PnzvQEefvhh/88++6zV1Wy/adMm11tvvTUIIDU11amsrKvVp08f3erVqz2udjuLKjZCiLHAn8As4H3g/0w/J1/tDhWlqbjmuhsIie7Pr59/wqk/m/RTkouBERXmzQB+kVKGAr+YphXFrgkhiNP5siXtLIUlVXbs3dgsRuWn0gR09HGjs48b65vZHdWUlJTkQ4cOJd99993Z9913X5Ct4zH31ltvZU6aNOnC1WwzePDg/BUrVqQDHD582Hnp0qUN+tKUpXdsXgTullL2BC6Zfk4F1B0UpdkSQjDsvnhcPT1ZM+81igus1vmvTUkpNwHnKsweA5Q9iroEGNuQMSlKbQ0J96WgpJQdRyv+STdOKj+VpmSIzpdtR85SUNxkLjxYbOjQoXmnTp1yKpu+8847AyMjI7uEhYVFjB49ulN+fr4AmD9/vndcXFzI0KFDgzt37tw1Li4upKCgQAAcOnTIqXfv3rrQ0NCukyZN6uDv798tNTXVCSApKcllwIABYZGRkV26detm0d0h87s348aN63j77bd3iIqK0rVr167bSy+95Dt37lyfbt26dQkKCor8+eef3QBWr17t0adPHx3A9OnTA/fv3+8aHh4eMWXKlECAH3/80b137966rl27domKitLt2rXLBeD06dOaIUOGhAQHB3cdNmxYcGFhoajNcbS0YtNBSvllhXlLgDtqs1NFaSpauHvwj//7LxeyTvPLondtHU5D8pNSnjSNn8LYSqKi2L3+nb1x0To09fdsVH4qjVJseBuK9Qa2HWl+HWAnJCR43nDDDefLpl955ZWT+/fvP3jo0KHk1q1bl86bN6/8zse+fftcP/300/S0tLQDJSUlYsmSJa0B7r///sAJEyacO3z48IExY8bknDx50gmgpKSEKVOmdFyyZMmx/fv3H1yxYsWf//rXvzoZrvId4fT0dOdt27albt++PWX2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\n",
      "text/plain": [
       "<Figure size 828x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "labels = [\"Masking\", \"Shuffling\", \"Noise\", \"Sampling\", \"RQ\", \"CutMix\", \n",
    "          \"Range-limited\\nShuffling\", \"Range-limited\\nSampling\"]\n",
    "\n",
    "fig, ax = plt.subplots(1, 3, figsize=(11.5, 3))\n",
    "plt.subplots_adjust(wspace=0.3)\n",
    "\n",
    "for i in [0, 1, 2]:\n",
    "    ax[i].set_axisbelow(True)\n",
    "    ax[i].grid()\n",
    "    ax[i].set_xlabel(\"Augmentation Strength\", fontsize=12)\n",
    "    \n",
    "q = result[result[\"aug\"] == \"noaug\"]\n",
    "avg = q.groupby(\"p\").mean(\"ris10_test\").reset_index().mean()[\"ris10_test\"].mean()\n",
    "ax[1].plot([0, 1.1], [avg, avg], label=\"No Aug.\", linestyle=\"dashed\", linewidth=1.2, color=\"k\")\n",
    "for i, aug in enumerate(augs[1:]):\n",
    "    q = result[result[\"aug\"] == aug]\n",
    "    avg = q.groupby(\"p\").mean(\"ris10_test\").reset_index()\n",
    "    ax[1].plot(avg[\"p\"], avg[\"ris10_test\"], label=labels[i], marker=\"o\")\n",
    "ax[1].set_xlim(0.05, 1.05)\n",
    "ax[1].set_ylim(0, 75)\n",
    "ax[1].set_xticks([0.2, 0.4, 0.6, 0.8, 1.0], fontsize=11)\n",
    "ax[1].set_yticks([0, 10, 20, 30, 40, 50, 60, 70], fontsize=11)\n",
    "# ax[1].set_xlabel(\"Augmentation Strength\", fontsize=12)\n",
    "ax[1].set_ylabel(\"RIS(Top-10) (%)\", fontsize=12)\n",
    "\n",
    "q = result[result[\"aug\"] == \"noaug\"]\n",
    "avg = q.groupby(\"p\").mean(\"ris25_test\").reset_index().mean()[\"ris25_test\"].mean()\n",
    "ax[2].plot([0, 1.1], [avg, avg], label=\"No Aug.\", linestyle=\"dashed\", linewidth=1.2, color=\"k\")\n",
    "for i, aug in enumerate(augs[1:]):\n",
    "    q = result[result[\"aug\"] == aug]\n",
    "    avg = q.groupby(\"p\").mean(\"ris25_test\").reset_index()\n",
    "    ax[2].plot(avg[\"p\"], avg[\"ris25_test\"], label=labels[i], marker=\"o\")\n",
    "ax[2].set_xlim(0.05, 1.05)\n",
    "ax[2].set_ylim(0, 75)\n",
    "ax[2].set_xticks([0.2, 0.4, 0.6, 0.8, 1.0], fontsize=11)\n",
    "ax[2].set_yticks([0, 10, 20, 30, 40, 50, 60, 70], fontsize=11)\n",
    "# ax[1].set_xlabel(\"Augmentation Strength\", fontsize=12)\n",
    "ax[2].set_ylabel(\"RIS(Top-25) (%)\", fontsize=12)\n",
    "\n",
    "result = result[result[\"data_id\"] != 1462]\n",
    "result = result[result[\"data_id\"] != 1504]\n",
    "result = result[result[\"data_id\"] != 40922]\n",
    "result = result.replace([np.inf, -np.inf], np.nan)\n",
    "q = result[result[\"aug\"] == \"noaug\"].dropna()\n",
    "avg = q.groupby(\"p\").mean(\"uinfo_test\").reset_index().mean()[\"uinfo_test\"].mean()\n",
    "ax[0].plot([0, 1.1], [avg, avg], label=\"No Aug.\", linestyle=\"dashed\", linewidth=1.2, color=\"k\")\n",
    "for i, aug in enumerate(augs[1:]):\n",
    "    q = result[result[\"aug\"] == aug].dropna()\n",
    "    avg = q.groupby(\"p\").mean(\"uinfo_train\").reset_index()\n",
    "    ax[0].plot(avg[\"p\"], avg[\"uinfo_train\"], label=labels[i], marker=\"o\")\n",
    "ax[0].set_xlim(0.05, 1.05)\n",
    "# ax[1].set_ylim(-10, 0)\n",
    "ax[0].set_xticks([0.2, 0.4, 0.6, 0.8, 1.0], fontsize=11)\n",
    "# ax[1].set_yticks([0, 10, 20, 30, 40, 50, 60, 70], fontsize=11)\n",
    "# ax[1].set_xlabel(\"Augmentation Strength\", fontsize=12)\n",
    "ax[0].set_ylabel(\"Usable Information (nats)\", fontsize=12)\n",
    "\n",
    "# fig.text(0.5, -0.01, \"Augmentation Strength\", ha=\"center\", fontsize=12)\n",
    "ax[2].legend(ncol=1, loc=(1.05, 0.0), fontsize=10.5)\n",
    "plt.savefig(\"figs/labelaware-test.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "id": "68e86a08",
   "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>data_id</th>\n",
       "      <th>aug</th>\n",
       "      <th>p</th>\n",
       "      <th>ris10_train</th>\n",
       "      <th>ris10_test</th>\n",
       "      <th>ris25_train</th>\n",
       "      <th>ris25_test</th>\n",
       "      <th>uinfo_train</th>\n",
       "      <th>uinfo_test</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>639</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>1.0</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>638</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.9</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>631</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.2</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>632</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.3</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>633</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.4</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>630</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.1</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>635</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.6</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>636</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.7</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>637</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.8</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>634</th>\n",
       "      <td>1497</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.5</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>80.525980</td>\n",
       "      <td>78.753012</td>\n",
       "      <td>1.166674</td>\n",
       "      <td>1.057116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>547</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.8</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>542</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.3</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>543</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.4</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>544</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.5</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>545</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.6</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>546</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.7</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>548</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.9</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>540</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.1</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>541</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.2</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>549</th>\n",
       "      <td>12</td>\n",
       "      <td>noaug</td>\n",
       "      <td>1.0</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>78.417279</td>\n",
       "      <td>74.494840</td>\n",
       "      <td>2.297011</td>\n",
       "      <td>2.180471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.9</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>99</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>1.0</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.7</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.6</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>93</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.4</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>92</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.3</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>91</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.2</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>90</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.1</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.8</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94</th>\n",
       "      <td>45714</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.5</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>35.769212</td>\n",
       "      <td>35.727555</td>\n",
       "      <td>2.269012</td>\n",
       "      <td>2.271112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.1</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.9</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.2</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.3</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.4</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.5</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.6</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.7</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.8</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>307</td>\n",
       "      <td>noaug</td>\n",
       "      <td>1.0</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>56.779110</td>\n",
       "      <td>56.462980</td>\n",
       "      <td>2.379268</td>\n",
       "      <td>2.361984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>368</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.9</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>360</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.1</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>361</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.2</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>362</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.3</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>363</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.4</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>365</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.6</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>366</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.7</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>367</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.8</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>369</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>1.0</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>364</th>\n",
       "      <td>40499</td>\n",
       "      <td>noaug</td>\n",
       "      <td>0.5</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>59.239793</td>\n",
       "      <td>59.871589</td>\n",
       "      <td>2.395555</td>\n",
       "      <td>2.383983</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id    aug    p  ris10_train  ris10_test  ris25_train  ris25_test  \\\n",
       "639     1497  noaug  1.0    80.525980   78.753012    80.525980   78.753012   \n",
       "638     1497  noaug  0.9    80.525980   78.753012    80.525980   78.753012   \n",
       "631     1497  noaug  0.2    80.525980   78.753012    80.525980   78.753012   \n",
       "632     1497  noaug  0.3    80.525980   78.753012    80.525980   78.753012   \n",
       "633     1497  noaug  0.4    80.525980   78.753012    80.525980   78.753012   \n",
       "630     1497  noaug  0.1    80.525980   78.753012    80.525980   78.753012   \n",
       "635     1497  noaug  0.6    80.525980   78.753012    80.525980   78.753012   \n",
       "636     1497  noaug  0.7    80.525980   78.753012    80.525980   78.753012   \n",
       "637     1497  noaug  0.8    80.525980   78.753012    80.525980   78.753012   \n",
       "634     1497  noaug  0.5    80.525980   78.753012    80.525980   78.753012   \n",
       "547       12  noaug  0.8    78.417279   74.494840    78.417279   74.494840   \n",
       "542       12  noaug  0.3    78.417279   74.494840    78.417279   74.494840   \n",
       "543       12  noaug  0.4    78.417279   74.494840    78.417279   74.494840   \n",
       "544       12  noaug  0.5    78.417279   74.494840    78.417279   74.494840   \n",
       "545       12  noaug  0.6    78.417279   74.494840    78.417279   74.494840   \n",
       "546       12  noaug  0.7    78.417279   74.494840    78.417279   74.494840   \n",
       "548       12  noaug  0.9    78.417279   74.494840    78.417279   74.494840   \n",
       "540       12  noaug  0.1    78.417279   74.494840    78.417279   74.494840   \n",
       "541       12  noaug  0.2    78.417279   74.494840    78.417279   74.494840   \n",
       "549       12  noaug  1.0    78.417279   74.494840    78.417279   74.494840   \n",
       "98     45714  noaug  0.9    35.769212   35.727555    35.769212   35.727555   \n",
       "99     45714  noaug  1.0    35.769212   35.727555    35.769212   35.727555   \n",
       "96     45714  noaug  0.7    35.769212   35.727555    35.769212   35.727555   \n",
       "95     45714  noaug  0.6    35.769212   35.727555    35.769212   35.727555   \n",
       "93     45714  noaug  0.4    35.769212   35.727555    35.769212   35.727555   \n",
       "92     45714  noaug  0.3    35.769212   35.727555    35.769212   35.727555   \n",
       "91     45714  noaug  0.2    35.769212   35.727555    35.769212   35.727555   \n",
       "90     45714  noaug  0.1    35.769212   35.727555    35.769212   35.727555   \n",
       "97     45714  noaug  0.8    35.769212   35.727555    35.769212   35.727555   \n",
       "94     45714  noaug  0.5    35.769212   35.727555    35.769212   35.727555   \n",
       "0        307  noaug  0.1    56.779110   56.462980    56.779110   56.462980   \n",
       "8        307  noaug  0.9    56.779110   56.462980    56.779110   56.462980   \n",
       "1        307  noaug  0.2    56.779110   56.462980    56.779110   56.462980   \n",
       "2        307  noaug  0.3    56.779110   56.462980    56.779110   56.462980   \n",
       "3        307  noaug  0.4    56.779110   56.462980    56.779110   56.462980   \n",
       "4        307  noaug  0.5    56.779110   56.462980    56.779110   56.462980   \n",
       "5        307  noaug  0.6    56.779110   56.462980    56.779110   56.462980   \n",
       "6        307  noaug  0.7    56.779110   56.462980    56.779110   56.462980   \n",
       "7        307  noaug  0.8    56.779110   56.462980    56.779110   56.462980   \n",
       "9        307  noaug  1.0    56.779110   56.462980    56.779110   56.462980   \n",
       "368    40499  noaug  0.9    59.239793   59.871589    59.239793   59.871589   \n",
       "360    40499  noaug  0.1    59.239793   59.871589    59.239793   59.871589   \n",
       "361    40499  noaug  0.2    59.239793   59.871589    59.239793   59.871589   \n",
       "362    40499  noaug  0.3    59.239793   59.871589    59.239793   59.871589   \n",
       "363    40499  noaug  0.4    59.239793   59.871589    59.239793   59.871589   \n",
       "365    40499  noaug  0.6    59.239793   59.871589    59.239793   59.871589   \n",
       "366    40499  noaug  0.7    59.239793   59.871589    59.239793   59.871589   \n",
       "367    40499  noaug  0.8    59.239793   59.871589    59.239793   59.871589   \n",
       "369    40499  noaug  1.0    59.239793   59.871589    59.239793   59.871589   \n",
       "364    40499  noaug  0.5    59.239793   59.871589    59.239793   59.871589   \n",
       "\n",
       "     uinfo_train  uinfo_test  \n",
       "639     1.166674    1.057116  \n",
       "638     1.166674    1.057116  \n",
       "631     1.166674    1.057116  \n",
       "632     1.166674    1.057116  \n",
       "633     1.166674    1.057116  \n",
       "630     1.166674    1.057116  \n",
       "635     1.166674    1.057116  \n",
       "636     1.166674    1.057116  \n",
       "637     1.166674    1.057116  \n",
       "634     1.166674    1.057116  \n",
       "547     2.297011    2.180471  \n",
       "542     2.297011    2.180471  \n",
       "543     2.297011    2.180471  \n",
       "544     2.297011    2.180471  \n",
       "545     2.297011    2.180471  \n",
       "546     2.297011    2.180471  \n",
       "548     2.297011    2.180471  \n",
       "540     2.297011    2.180471  \n",
       "541     2.297011    2.180471  \n",
       "549     2.297011    2.180471  \n",
       "98      2.269012    2.271112  \n",
       "99      2.269012    2.271112  \n",
       "96      2.269012    2.271112  \n",
       "95      2.269012    2.271112  \n",
       "93      2.269012    2.271112  \n",
       "92      2.269012    2.271112  \n",
       "91      2.269012    2.271112  \n",
       "90      2.269012    2.271112  \n",
       "97      2.269012    2.271112  \n",
       "94      2.269012    2.271112  \n",
       "0       2.379268    2.361984  \n",
       "8       2.379268    2.361984  \n",
       "1       2.379268    2.361984  \n",
       "2       2.379268    2.361984  \n",
       "3       2.379268    2.361984  \n",
       "4       2.379268    2.361984  \n",
       "5       2.379268    2.361984  \n",
       "6       2.379268    2.361984  \n",
       "7       2.379268    2.361984  \n",
       "9       2.379268    2.361984  \n",
       "368     2.395555    2.383983  \n",
       "360     2.395555    2.383983  \n",
       "361     2.395555    2.383983  \n",
       "362     2.395555    2.383983  \n",
       "363     2.395555    2.383983  \n",
       "365     2.395555    2.383983  \n",
       "366     2.395555    2.383983  \n",
       "367     2.395555    2.383983  \n",
       "369     2.395555    2.383983  \n",
       "364     2.395555    2.383983  "
      ]
     },
     "execution_count": 198,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result[(result[\"aug\"] == \"noaug\") & (\n",
    "    ~result[\"data_id\"].isin([1462, 1504, 40922]))].dropna().sort_values(\"uinfo_test\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "id": "a443a7e3",
   "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": []
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "e36ee53d",
   "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>data_id</th>\n",
       "      <th>aug</th>\n",
       "      <th>p</th>\n",
       "      <th>ris10_train</th>\n",
       "      <th>ris10_test</th>\n",
       "      <th>ris25_train</th>\n",
       "      <th>ris25_test</th>\n",
       "      <th>uinfo_train</th>\n",
       "      <th>uinfo_test</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>48.336373</td>\n",
       "      <td>50.845730</td>\n",
       "      <td>42.918112</td>\n",
       "      <td>44.151358</td>\n",
       "      <td>0.538697</td>\n",
       "      <td>-0.038267</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>37.135394</td>\n",
       "      <td>42.886036</td>\n",
       "      <td>33.314471</td>\n",
       "      <td>38.041467</td>\n",
       "      <td>-1.567900</td>\n",
       "      <td>-1.856173</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>31.271007</td>\n",
       "      <td>41.712744</td>\n",
       "      <td>27.947840</td>\n",
       "      <td>37.039683</td>\n",
       "      <td>-2.772070</td>\n",
       "      <td>-2.147382</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>26.681251</td>\n",
       "      <td>38.731897</td>\n",
       "      <td>24.476592</td>\n",
       "      <td>33.907359</td>\n",
       "      <td>-4.211188</td>\n",
       "      <td>-4.433408</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>23.058090</td>\n",
       "      <td>35.795455</td>\n",
       "      <td>21.081607</td>\n",
       "      <td>31.647055</td>\n",
       "      <td>-5.217607</td>\n",
       "      <td>-5.494127</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>20.589539</td>\n",
       "      <td>33.952348</td>\n",
       "      <td>19.189593</td>\n",
       "      <td>30.566378</td>\n",
       "      <td>-6.242555</td>\n",
       "      <td>-7.009777</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>19.746246</td>\n",
       "      <td>34.011839</td>\n",
       "      <td>18.407742</td>\n",
       "      <td>29.795881</td>\n",
       "      <td>-6.721739</td>\n",
       "      <td>-7.190647</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>20.327395</td>\n",
       "      <td>34.099928</td>\n",
       "      <td>18.973111</td>\n",
       "      <td>30.173095</td>\n",
       "      <td>-7.630148</td>\n",
       "      <td>-7.541099</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>18.352438</td>\n",
       "      <td>32.461728</td>\n",
       "      <td>17.293672</td>\n",
       "      <td>30.437466</td>\n",
       "      <td>-8.816031</td>\n",
       "      <td>-7.809808</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>307</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-10.197769</td>\n",
       "      <td>-9.387226</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>34.066522</td>\n",
       "      <td>34.150675</td>\n",
       "      <td>31.798569</td>\n",
       "      <td>31.832426</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>101</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>30.708801</td>\n",
       "      <td>30.927903</td>\n",
       "      <td>28.498033</td>\n",
       "      <td>28.679393</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>102</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>27.679915</td>\n",
       "      <td>28.869670</td>\n",
       "      <td>26.011857</td>\n",
       "      <td>27.193362</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>103</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>25.767960</td>\n",
       "      <td>26.080854</td>\n",
       "      <td>24.553055</td>\n",
       "      <td>24.913357</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>23.625035</td>\n",
       "      <td>24.255258</td>\n",
       "      <td>22.762151</td>\n",
       "      <td>23.129930</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>105</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>21.209572</td>\n",
       "      <td>22.007317</td>\n",
       "      <td>20.376887</td>\n",
       "      <td>20.976655</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>106</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>20.700911</td>\n",
       "      <td>21.224513</td>\n",
       "      <td>19.755048</td>\n",
       "      <td>20.173150</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>107</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>19.455265</td>\n",
       "      <td>20.114971</td>\n",
       "      <td>18.802985</td>\n",
       "      <td>19.505641</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>16.089430</td>\n",
       "      <td>16.201411</td>\n",
       "      <td>15.561511</td>\n",
       "      <td>15.613351</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>109</th>\n",
       "      <td>45714</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-inf</td>\n",
       "      <td>-inf</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>280</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>88.102262</td>\n",
       "      <td>91.341925</td>\n",
       "      <td>88.102262</td>\n",
       "      <td>91.341925</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>281</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>88.102262</td>\n",
       "      <td>91.341925</td>\n",
       "      <td>88.102262</td>\n",
       "      <td>91.341925</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>282</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>84.272590</td>\n",
       "      <td>85.459824</td>\n",
       "      <td>84.122199</td>\n",
       "      <td>84.800612</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>283</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>77.977063</td>\n",
       "      <td>75.235087</td>\n",
       "      <td>77.772077</td>\n",
       "      <td>74.780847</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>284</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>70.209072</td>\n",
       "      <td>71.484678</td>\n",
       "      <td>69.940845</td>\n",
       "      <td>71.130427</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>285</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>66.206306</td>\n",
       "      <td>68.059966</td>\n",
       "      <td>65.960996</td>\n",
       "      <td>67.678900</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>286</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>65.136640</td>\n",
       "      <td>67.633845</td>\n",
       "      <td>64.685068</td>\n",
       "      <td>67.200776</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>287</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>58.713239</td>\n",
       "      <td>62.169723</td>\n",
       "      <td>58.342811</td>\n",
       "      <td>61.889949</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>288</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>54.368667</td>\n",
       "      <td>57.406394</td>\n",
       "      <td>54.241193</td>\n",
       "      <td>57.066366</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>289</th>\n",
       "      <td>1504</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-64.884239</td>\n",
       "      <td>-58.812141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>370</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>34.023573</td>\n",
       "      <td>35.218689</td>\n",
       "      <td>29.918092</td>\n",
       "      <td>31.413066</td>\n",
       "      <td>-0.084222</td>\n",
       "      <td>-0.024102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>371</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>25.642332</td>\n",
       "      <td>28.258868</td>\n",
       "      <td>22.987567</td>\n",
       "      <td>25.190574</td>\n",
       "      <td>-1.755977</td>\n",
       "      <td>-2.170367</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>372</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>21.764348</td>\n",
       "      <td>26.024994</td>\n",
       "      <td>19.720106</td>\n",
       "      <td>23.249629</td>\n",
       "      <td>-2.985788</td>\n",
       "      <td>-2.865900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>373</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>19.262302</td>\n",
       "      <td>23.366393</td>\n",
       "      <td>17.568711</td>\n",
       "      <td>21.347137</td>\n",
       "      <td>-4.049029</td>\n",
       "      <td>-4.083070</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>374</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>17.592406</td>\n",
       "      <td>22.960011</td>\n",
       "      <td>16.292853</td>\n",
       "      <td>21.092785</td>\n",
       "      <td>-4.734828</td>\n",
       "      <td>-3.933545</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>375</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>16.419077</td>\n",
       "      <td>20.712400</td>\n",
       "      <td>15.367975</td>\n",
       "      <td>19.212449</td>\n",
       "      <td>-5.289175</td>\n",
       "      <td>-5.212886</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>376</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>15.259165</td>\n",
       "      <td>21.535616</td>\n",
       "      <td>14.468321</td>\n",
       "      <td>19.762098</td>\n",
       "      <td>-6.012546</td>\n",
       "      <td>-5.146475</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>377</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>14.521916</td>\n",
       "      <td>20.445813</td>\n",
       "      <td>13.869079</td>\n",
       "      <td>18.948410</td>\n",
       "      <td>-6.512280</td>\n",
       "      <td>-6.563647</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>378</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>14.032293</td>\n",
       "      <td>19.094639</td>\n",
       "      <td>13.400247</td>\n",
       "      <td>17.949454</td>\n",
       "      <td>-7.533172</td>\n",
       "      <td>-7.415988</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>379</th>\n",
       "      <td>40499</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-10.644291</td>\n",
       "      <td>-10.582392</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>460</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>78.003648</td>\n",
       "      <td>75.343394</td>\n",
       "      <td>67.848473</td>\n",
       "      <td>65.589589</td>\n",
       "      <td>2.269091</td>\n",
       "      <td>2.164218</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>461</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>67.972490</td>\n",
       "      <td>67.139103</td>\n",
       "      <td>59.114814</td>\n",
       "      <td>58.041510</td>\n",
       "      <td>2.193507</td>\n",
       "      <td>2.069505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>462</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>59.236741</td>\n",
       "      <td>59.202505</td>\n",
       "      <td>51.177214</td>\n",
       "      <td>50.783257</td>\n",
       "      <td>2.062789</td>\n",
       "      <td>1.956852</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>463</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>50.334799</td>\n",
       "      <td>53.200259</td>\n",
       "      <td>44.048121</td>\n",
       "      <td>46.428701</td>\n",
       "      <td>1.842754</td>\n",
       "      <td>1.613425</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>464</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>43.852801</td>\n",
       "      <td>47.904801</td>\n",
       "      <td>38.450488</td>\n",
       "      <td>41.360446</td>\n",
       "      <td>1.573624</td>\n",
       "      <td>1.457343</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>465</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>37.226155</td>\n",
       "      <td>41.118180</td>\n",
       "      <td>32.864154</td>\n",
       "      <td>35.993057</td>\n",
       "      <td>1.232399</td>\n",
       "      <td>1.153251</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>466</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>32.044842</td>\n",
       "      <td>37.505708</td>\n",
       "      <td>28.325148</td>\n",
       "      <td>32.673925</td>\n",
       "      <td>0.847830</td>\n",
       "      <td>0.768644</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>467</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>26.089813</td>\n",
       "      <td>32.818492</td>\n",
       "      <td>23.797926</td>\n",
       "      <td>29.427367</td>\n",
       "      <td>0.376336</td>\n",
       "      <td>0.238634</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>468</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>21.168903</td>\n",
       "      <td>30.299461</td>\n",
       "      <td>19.505276</td>\n",
       "      <td>27.419524</td>\n",
       "      <td>-0.246472</td>\n",
       "      <td>-0.100592</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>469</th>\n",
       "      <td>12</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-0.324538</td>\n",
       "      <td>-0.268406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>550</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.1</td>\n",
       "      <td>67.940313</td>\n",
       "      <td>70.413306</td>\n",
       "      <td>65.717093</td>\n",
       "      <td>68.552819</td>\n",
       "      <td>-0.674179</td>\n",
       "      <td>-0.553025</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>551</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.2</td>\n",
       "      <td>55.738798</td>\n",
       "      <td>56.170954</td>\n",
       "      <td>54.142444</td>\n",
       "      <td>53.407348</td>\n",
       "      <td>-2.108835</td>\n",
       "      <td>-2.108793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>552</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.3</td>\n",
       "      <td>47.283592</td>\n",
       "      <td>51.475517</td>\n",
       "      <td>45.889670</td>\n",
       "      <td>49.405987</td>\n",
       "      <td>-3.235013</td>\n",
       "      <td>-2.703139</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>553</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.4</td>\n",
       "      <td>44.230126</td>\n",
       "      <td>47.456639</td>\n",
       "      <td>42.756442</td>\n",
       "      <td>45.767629</td>\n",
       "      <td>-4.120065</td>\n",
       "      <td>-3.827604</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>554</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.5</td>\n",
       "      <td>41.846469</td>\n",
       "      <td>45.488837</td>\n",
       "      <td>40.502659</td>\n",
       "      <td>43.367493</td>\n",
       "      <td>-4.892722</td>\n",
       "      <td>-4.639319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>555</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.6</td>\n",
       "      <td>39.671900</td>\n",
       "      <td>40.946949</td>\n",
       "      <td>38.272779</td>\n",
       "      <td>39.305149</td>\n",
       "      <td>-5.423449</td>\n",
       "      <td>-5.095669</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>556</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.7</td>\n",
       "      <td>36.438213</td>\n",
       "      <td>37.092313</td>\n",
       "      <td>35.455745</td>\n",
       "      <td>35.632924</td>\n",
       "      <td>-5.931158</td>\n",
       "      <td>-5.810665</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>557</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.8</td>\n",
       "      <td>35.624144</td>\n",
       "      <td>40.028741</td>\n",
       "      <td>34.817564</td>\n",
       "      <td>38.455168</td>\n",
       "      <td>-6.497161</td>\n",
       "      <td>-6.247994</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>558</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>0.9</td>\n",
       "      <td>32.656239</td>\n",
       "      <td>37.838321</td>\n",
       "      <td>31.705541</td>\n",
       "      <td>36.408246</td>\n",
       "      <td>-6.966711</td>\n",
       "      <td>-6.586714</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>559</th>\n",
       "      <td>1497</td>\n",
       "      <td>masking</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-7.289103</td>\n",
       "      <td>-6.897482</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id      aug    p  ris10_train  ris10_test  ris25_train  ris25_test  \\\n",
       "10       307  masking  0.1    48.336373   50.845730    42.918112   44.151358   \n",
       "11       307  masking  0.2    37.135394   42.886036    33.314471   38.041467   \n",
       "12       307  masking  0.3    31.271007   41.712744    27.947840   37.039683   \n",
       "13       307  masking  0.4    26.681251   38.731897    24.476592   33.907359   \n",
       "14       307  masking  0.5    23.058090   35.795455    21.081607   31.647055   \n",
       "15       307  masking  0.6    20.589539   33.952348    19.189593   30.566378   \n",
       "16       307  masking  0.7    19.746246   34.011839    18.407742   29.795881   \n",
       "17       307  masking  0.8    20.327395   34.099928    18.973111   30.173095   \n",
       "18       307  masking  0.9    18.352438   32.461728    17.293672   30.437466   \n",
       "19       307  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "100    45714  masking  0.1    34.066522   34.150675    31.798569   31.832426   \n",
       "101    45714  masking  0.2    30.708801   30.927903    28.498033   28.679393   \n",
       "102    45714  masking  0.3    27.679915   28.869670    26.011857   27.193362   \n",
       "103    45714  masking  0.4    25.767960   26.080854    24.553055   24.913357   \n",
       "104    45714  masking  0.5    23.625035   24.255258    22.762151   23.129930   \n",
       "105    45714  masking  0.6    21.209572   22.007317    20.376887   20.976655   \n",
       "106    45714  masking  0.7    20.700911   21.224513    19.755048   20.173150   \n",
       "107    45714  masking  0.8    19.455265   20.114971    18.802985   19.505641   \n",
       "108    45714  masking  0.9    16.089430   16.201411    15.561511   15.613351   \n",
       "109    45714  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "280     1504  masking  0.1    88.102262   91.341925    88.102262   91.341925   \n",
       "281     1504  masking  0.2    88.102262   91.341925    88.102262   91.341925   \n",
       "282     1504  masking  0.3    84.272590   85.459824    84.122199   84.800612   \n",
       "283     1504  masking  0.4    77.977063   75.235087    77.772077   74.780847   \n",
       "284     1504  masking  0.5    70.209072   71.484678    69.940845   71.130427   \n",
       "285     1504  masking  0.6    66.206306   68.059966    65.960996   67.678900   \n",
       "286     1504  masking  0.7    65.136640   67.633845    64.685068   67.200776   \n",
       "287     1504  masking  0.8    58.713239   62.169723    58.342811   61.889949   \n",
       "288     1504  masking  0.9    54.368667   57.406394    54.241193   57.066366   \n",
       "289     1504  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "370    40499  masking  0.1    34.023573   35.218689    29.918092   31.413066   \n",
       "371    40499  masking  0.2    25.642332   28.258868    22.987567   25.190574   \n",
       "372    40499  masking  0.3    21.764348   26.024994    19.720106   23.249629   \n",
       "373    40499  masking  0.4    19.262302   23.366393    17.568711   21.347137   \n",
       "374    40499  masking  0.5    17.592406   22.960011    16.292853   21.092785   \n",
       "375    40499  masking  0.6    16.419077   20.712400    15.367975   19.212449   \n",
       "376    40499  masking  0.7    15.259165   21.535616    14.468321   19.762098   \n",
       "377    40499  masking  0.8    14.521916   20.445813    13.869079   18.948410   \n",
       "378    40499  masking  0.9    14.032293   19.094639    13.400247   17.949454   \n",
       "379    40499  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "460       12  masking  0.1    78.003648   75.343394    67.848473   65.589589   \n",
       "461       12  masking  0.2    67.972490   67.139103    59.114814   58.041510   \n",
       "462       12  masking  0.3    59.236741   59.202505    51.177214   50.783257   \n",
       "463       12  masking  0.4    50.334799   53.200259    44.048121   46.428701   \n",
       "464       12  masking  0.5    43.852801   47.904801    38.450488   41.360446   \n",
       "465       12  masking  0.6    37.226155   41.118180    32.864154   35.993057   \n",
       "466       12  masking  0.7    32.044842   37.505708    28.325148   32.673925   \n",
       "467       12  masking  0.8    26.089813   32.818492    23.797926   29.427367   \n",
       "468       12  masking  0.9    21.168903   30.299461    19.505276   27.419524   \n",
       "469       12  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "550     1497  masking  0.1    67.940313   70.413306    65.717093   68.552819   \n",
       "551     1497  masking  0.2    55.738798   56.170954    54.142444   53.407348   \n",
       "552     1497  masking  0.3    47.283592   51.475517    45.889670   49.405987   \n",
       "553     1497  masking  0.4    44.230126   47.456639    42.756442   45.767629   \n",
       "554     1497  masking  0.5    41.846469   45.488837    40.502659   43.367493   \n",
       "555     1497  masking  0.6    39.671900   40.946949    38.272779   39.305149   \n",
       "556     1497  masking  0.7    36.438213   37.092313    35.455745   35.632924   \n",
       "557     1497  masking  0.8    35.624144   40.028741    34.817564   38.455168   \n",
       "558     1497  masking  0.9    32.656239   37.838321    31.705541   36.408246   \n",
       "559     1497  masking  1.0     0.000000    0.000000     0.000000    0.000000   \n",
       "\n",
       "     uinfo_train  uinfo_test  \n",
       "10      0.538697   -0.038267  \n",
       "11     -1.567900   -1.856173  \n",
       "12     -2.772070   -2.147382  \n",
       "13     -4.211188   -4.433408  \n",
       "14     -5.217607   -5.494127  \n",
       "15     -6.242555   -7.009777  \n",
       "16     -6.721739   -7.190647  \n",
       "17     -7.630148   -7.541099  \n",
       "18     -8.816031   -7.809808  \n",
       "19    -10.197769   -9.387226  \n",
       "100         -inf        -inf  \n",
       "101         -inf        -inf  \n",
       "102         -inf        -inf  \n",
       "103         -inf        -inf  \n",
       "104         -inf        -inf  \n",
       "105         -inf        -inf  \n",
       "106         -inf        -inf  \n",
       "107         -inf        -inf  \n",
       "108         -inf        -inf  \n",
       "109         -inf        -inf  \n",
       "280   -64.884239  -58.812141  \n",
       "281   -64.884239  -58.812141  \n",
       "282   -64.884239  -58.812141  \n",
       "283   -64.884239  -58.812141  \n",
       "284   -64.884239  -58.812141  \n",
       "285   -64.884239  -58.812141  \n",
       "286   -64.884239  -58.812141  \n",
       "287   -64.884239  -58.812141  \n",
       "288   -64.884239  -58.812141  \n",
       "289   -64.884239  -58.812141  \n",
       "370    -0.084222   -0.024102  \n",
       "371    -1.755977   -2.170367  \n",
       "372    -2.985788   -2.865900  \n",
       "373    -4.049029   -4.083070  \n",
       "374    -4.734828   -3.933545  \n",
       "375    -5.289175   -5.212886  \n",
       "376    -6.012546   -5.146475  \n",
       "377    -6.512280   -6.563647  \n",
       "378    -7.533172   -7.415988  \n",
       "379   -10.644291  -10.582392  \n",
       "460     2.269091    2.164218  \n",
       "461     2.193507    2.069505  \n",
       "462     2.062789    1.956852  \n",
       "463     1.842754    1.613425  \n",
       "464     1.573624    1.457343  \n",
       "465     1.232399    1.153251  \n",
       "466     0.847830    0.768644  \n",
       "467     0.376336    0.238634  \n",
       "468    -0.246472   -0.100592  \n",
       "469    -0.324538   -0.268406  \n",
       "550    -0.674179   -0.553025  \n",
       "551    -2.108835   -2.108793  \n",
       "552    -3.235013   -2.703139  \n",
       "553    -4.120065   -3.827604  \n",
       "554    -4.892722   -4.639319  \n",
       "555    -5.423449   -5.095669  \n",
       "556    -5.931158   -5.810665  \n",
       "557    -6.497161   -6.247994  \n",
       "558    -6.966711   -6.586714  \n",
       "559    -7.289103   -6.897482  "
      ]
     },
     "execution_count": 134,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5b94850",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02424ad5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "823154ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6de9296c",
   "metadata": {},
   "outputs": [],
   "source": [
    "keys = [\n",
    "    'Train', 'masking', 'shuffling', 'noisemasking', 'scarf', 'rq', \"cutmix\",\n",
    "    'binshuffling-2', 'binsampling-2', 'binshuffling-3', 'binsampling-3',\n",
    "    'binshuffling-4', 'binsampling-4', 'binshuffling-5', 'binsampling-5',\n",
    "    'binshuffling-6', 'binsampling-6', 'binshuffling-7', 'binsampling-7',\n",
    "    'binshuffling-8', 'binsampling-8', 'binshuffling-9', 'binsampling-9',\n",
    "    'binshuffling-10', 'binsampling-10'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a44a043c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "22 0.95\n"
     ]
    },
    {
     "ename": "KeyError",
     "evalue": "'cutmix'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Input \u001b[0;32mIn [7]\u001b[0m, in \u001b[0;36m<cell line: 6>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     12\u001b[0m         \u001b[38;5;28mprint\u001b[39m(d, data[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124macc\u001b[39m\u001b[38;5;124m\"\u001b[39m])\n\u001b[1;32m     13\u001b[0m         \u001b[38;5;28;01mfor\u001b[39;00m k \u001b[38;5;129;01min\u001b[39;00m keys:\n\u001b[0;32m---> 14\u001b[0m             result[k]\u001b[38;5;241m.\u001b[39mappend(\u001b[43mdata\u001b[49m\u001b[43m[\u001b[49m\u001b[43mk\u001b[49m\u001b[43m]\u001b[49m)\n\u001b[1;32m     15\u001b[0m     done \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m     16\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n",
      "\u001b[0;31mKeyError\u001b[0m: 'cutmix'"
     ]
    }
   ],
   "source": [
    "done = 0\n",
    "result = dict()\n",
    "# keys = [\"Train\", \"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"binshuffling-4\", \"binsampling-4\"]\n",
    "for k in keys:\n",
    "    result[k] = []\n",
    "for d in datalist:\n",
    "    fname = f'/home/SemiTab/motivation/invariance/train=original/{d}.npy'\n",
    "    try: \n",
    "        data = np.load(fname, allow_pickle=True).item()\n",
    "        if \"acc\" in data:\n",
    "            if data[\"acc\"] >= 0.95:\n",
    "                print(d, data[\"acc\"])\n",
    "                for k in keys:\n",
    "                    result[k].append(data[k])\n",
    "            done += 1\n",
    "        else:\n",
    "            print(111, d)\n",
    "    except FileNotFoundError:\n",
    "        print(d)\n",
    "        pass\n",
    "print(f'{done}/{len(datalist)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "4ce63982",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "masking\n",
      "42/42 5\n",
      "61.707 55.610\n",
      "scarf\n",
      "42/42 7\n",
      "60.444 53.017\n",
      "shuffling\n",
      "42/42 6\n",
      "52.104 46.011\n",
      "noisemasking\n",
      "42/42 9\n",
      "57.684 51.169\n",
      "rq\n",
      "42/42 0\n",
      "nan nan\n",
      "cutmix\n",
      "42/42 3\n",
      "73.193 69.511\n",
      "binshuffling\n",
      "42/42 9\n",
      "63.853 57.034\n",
      "binsampling\n",
      "42/42 5\n",
      "73.161 69.167\n"
     ]
    }
   ],
   "source": [
    "keys = [\"masking\", \"scarf\", \"shuffling\", \"noisemasking\", \"rq\", \"cutmix\", \n",
    "        \"binshuffling\", \"binsampling\"]\n",
    "for t in keys:\n",
    "    done = 0\n",
    "    result = dict({\"top10\": [], \"top25\": []})\n",
    "    for d in datalist:\n",
    "        fname = f'/home/SemiTab/motivation/invariance/train={t}/{d}.npy'\n",
    "        try: \n",
    "            data = np.load(fname)\n",
    "            if data[1] >= 0.85:\n",
    "                result[\"top10\"].append(data[1])\n",
    "                result[\"top25\"].append(data[2])\n",
    "            done += 1\n",
    "        except FileNotFoundError:\n",
    "            print(d)\n",
    "            pass\n",
    "    print(t)\n",
    "    print(f'{done}/{len(datalist)}', len(result[\"top10\"]))\n",
    "    print(f'{np.mean(result[\"top10\"]):.3f} {np.mean(result[\"top25\"]):.3f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0b5fec5b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "62.290 56.848\n"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "279dbe0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e4d1615",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b3028870",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train nan\n",
      "masking nan\n",
      "shuffling nan\n",
      "noisemasking nan\n",
      "scarf nan\n",
      "rq nan\n",
      "cutmix nan\n",
      "binshuffling-2 nan\n",
      "binsampling-2 nan\n",
      "binshuffling-3 nan\n",
      "binsampling-3 nan\n",
      "binshuffling-4 nan\n",
      "binsampling-4 nan\n",
      "binshuffling-5 nan\n",
      "binsampling-5 nan\n",
      "binshuffling-6 nan\n",
      "binsampling-6 nan\n",
      "binshuffling-7 nan\n",
      "binsampling-7 nan\n",
      "binshuffling-8 nan\n",
      "binsampling-8 nan\n",
      "binshuffling-9 nan\n",
      "binsampling-9 nan\n",
      "binshuffling-10 nan\n",
      "binsampling-10 nan\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3419: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/opt/conda/lib/python3.8/site-packages/numpy/core/_methods.py:188: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    }
   ],
   "source": [
    "for k in result:\n",
    "    print(k, np.round(np.mean((np.array(result[k])), axis=0), 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "dbf04aed",
   "metadata": {},
   "outputs": [],
   "source": [
    "p1 = [np.mean(np.array(result['shuffling']))]\n",
    "p2 = [np.mean(np.array(result['scarf']))]\n",
    "for nb in range(2, 11):\n",
    "    p1.append(np.mean(np.array(result[f'binshuffling-{nb}'])[:, 0]))\n",
    "    p2.append(np.mean(np.array(result[f'binsampling-{nb}'])[:, 0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "aee2613d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.gca().set_axisbelow(True)\n",
    "plt.grid()\n",
    "plt.plot(range(1, 11), p1, marker=\"o\", label=\"Range-limited shuffling\")\n",
    "plt.plot(range(1, 11), p2, marker=\"o\", label=\"Range-limited sampling\")\n",
    "# plt.hlines(xmin=2, xmax=10, y=np.mean(np.array(result['Train'])[:, 0]), linestyle=\"dashed\", linewidth=1)\n",
    "# plt.hlines(xmin=2, xmax=10, y=np.mean(np.array(result[\"shuffling\"]), axis=0)[1], \n",
    "#            linestyle=\"dashed\", linewidth=1, color=\"tab:red\", label=\"Shuffling\")\n",
    "plt.legend()\n",
    "plt.xlabel(\"Number of Ranges\")\n",
    "plt.ylabel(\"RIS (Top-10)\")\n",
    "plt.savefig(\"figs/numbins_ris.png\", dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "id": "14c2d795",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "42.16240065520343"
      ]
     },
     "execution_count": 135,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbfde533",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8783574",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "1bf7a0f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "masking 42/42\n",
      "shuffling 42/42\n",
      "scarf 42/42\n",
      "noisemasking 42/42\n",
      "rq 42/42\n",
      "binsampling 42/42\n",
      "binshuffling 42/42\n"
     ]
    }
   ],
   "source": [
    "done = 0\n",
    "result = dict()    \n",
    "for t in [\"masking\", \"shuffling\", \"scarf\", \"noisemasking\", \"rq\", \"binsampling\", \"binshuffling\"]:\n",
    "    result[t] = []\n",
    "    done = 0\n",
    "    for d in datalist: #[44131]: #[44131, 44090, 40922, 44161]: #dlist:\n",
    "        fname = f'/home/SemiTab/motivation/invariance/train={t}/{d}.npy'\n",
    "        try: \n",
    "            data = np.load(fname, allow_pickle=True)\n",
    "            if data[1] >= 0.95:\n",
    "                result[t].append(data)\n",
    "            done += 1\n",
    "        except FileNotFoundError:\n",
    "            print(t, d)\n",
    "            pass\n",
    "    print(t, f'{done}/{len(datalist)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "f7d095f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "masking [ 0.953 62.29  56.848]\n",
      "shuffling [ 0.955 63.957 58.136]\n",
      "scarf [ 0.953 64.66  59.597]\n",
      "noisemasking [ 0.952 66.842 60.659]\n",
      "rq nan\n",
      "binsampling [ 0.952 72.39  68.282]\n",
      "binshuffling [ 0.953 61.167 53.966]\n"
     ]
    }
   ],
   "source": [
    "for k in result:\n",
    "    print(k, np.round(np.mean((np.array(result[k])), axis=0), 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "041db364",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d7d6487",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6eacc342",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 279,
   "id": "63398633",
   "metadata": {},
   "outputs": [],
   "source": [
    "dlist = datalist[:20] + datalist[21:38] + datalist[-1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 241,
   "id": "147006e6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[44090, 40922, 44161]"
      ]
     },
     "execution_count": 241,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "datalist[38:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 286,
   "id": "782fd74f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([65.53885684, 59.46232152]),\n",
       " array([77.85970188, 75.70854611]),\n",
       " array([79.01805825, 79.01805825]),\n",
       " array([74.74367065, 74.4833752 ]),\n",
       " array([86.79580456, 78.11032885]),\n",
       " array([61.38948136, 55.57870091]),\n",
       " array([55.65140419, 54.38213542]),\n",
       " array([88.61111111, 88.61111111]),\n",
       " array([34.17232642, 13.66893057]),\n",
       " array([55.13771386, 50.32788391]),\n",
       " array([79.85099208, 79.7488299 ]),\n",
       " array([39.6452492 , 36.12485625]),\n",
       " array([38.39286309, 35.78213487]),\n",
       " array([75.48054994, 73.30833716]),\n",
       " array([58.46795108, 48.53626757]),\n",
       " array([80.54278524, 79.5901453 ]),\n",
       " array([10.38655568,  5.66760999]),\n",
       " array([91.32718151, 87.39045708]),\n",
       " array([75.32755218, 67.17425236]),\n",
       " array([76.00287002, 69.83851872]),\n",
       " array([23.68575777, 21.07027589]),\n",
       " array([75.64508459, 74.99738908]),\n",
       " array([58.05789843, 57.07531074]),\n",
       " array([95.42796023, 95.42796023]),\n",
       " array([58.98203087, 57.04979291]),\n",
       " array([94.8276579 , 94.58484934]),\n",
       " array([81.11609025, 79.75232795]),\n",
       " array([91.96825397, 91.36190476]),\n",
       " array([94.24479167, 93.35416667]),\n",
       " array([88.06483301, 88.06483301]),\n",
       " array([87.65652952, 87.65652952]),\n",
       " array([99.05315328, 99.05315328]),\n",
       " array([71.24410021, 50.5864012 ]),\n",
       " array([93.50275436, 92.93778456]),\n",
       " array([27.90882944, 21.96390268]),\n",
       " array([76.03508622, 74.69803914]),\n",
       " array([71.78952523, 69.33036686]),\n",
       " array([62.7241849, 48.3778331]),\n",
       " array([58.58067971, 41.75518275]),\n",
       " array([52.94397413, 40.07711706]),\n",
       " array([18.1317558 , 15.87886913]),\n",
       " array([0.99411626, 0.3976465 ])]"
      ]
     },
     "execution_count": 286,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result['binshuffling']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 288,
   "id": "b6456e12",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "45714"
      ]
     },
     "execution_count": 288,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "datalist[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7dc980f4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
