{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sb\n",
    "sb.set_theme()\n",
    "\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "char_mi = [np.log(x) for x in [55, 52, 48, 47, 46, 43, 42, 41, 41]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[15.679925516431847, 34.43458078030649]\n"
     ]
    }
   ],
   "source": [
    "mi_gt = [np.sum(char_mi[:4]), np.sum(char_mi)]\n",
    "print(mi_gt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "x = [4, 9, 4, 9, 4, 9, 4, 9]\n",
    "y = mi_gt + [14.6, 32.02] + [15.34, 34.46] + [7.68, 6.23]\n",
    "models = ['Ground Truth'] * 2 + ['TRE'] * 2 + ['CoB'] * 2 + ['Single Ratio'] * 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(list(zip(x, y, models)),\n",
    "               columns =['num_char', 'mi', 'models'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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>num_char</th>\n",
       "      <th>mi</th>\n",
       "      <th>models</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4</td>\n",
       "      <td>15.679926</td>\n",
       "      <td>Ground Truth</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>9</td>\n",
       "      <td>34.434581</td>\n",
       "      <td>Ground Truth</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4</td>\n",
       "      <td>14.600000</td>\n",
       "      <td>TRE</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>9</td>\n",
       "      <td>32.020000</td>\n",
       "      <td>TRE</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>15.340000</td>\n",
       "      <td>CoB</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>9</td>\n",
       "      <td>34.460000</td>\n",
       "      <td>CoB</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>4</td>\n",
       "      <td>7.680000</td>\n",
       "      <td>Single Ratio</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>9</td>\n",
       "      <td>6.230000</td>\n",
       "      <td>Single Ratio</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   num_char         mi        models\n",
       "0         4  15.679926  Ground Truth\n",
       "1         9  34.434581  Ground Truth\n",
       "2         4  14.600000           TRE\n",
       "3         9  32.020000           TRE\n",
       "4         4  15.340000           CoB\n",
       "5         9  34.460000           CoB\n",
       "6         4   7.680000  Single Ratio\n",
       "7         9   6.230000  Single Ratio"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0GE5VNu2bcnKymL37t107dqVX375BbB2m/b19a31/q/ddFqNHTt28NdffzF+/PiGDqVezZ07l59//pkFCxagqiozZsxo6JAcymw2c/LkSTp37szChQuZOnUqkydPpqioqKFDqxcLFixoFlWC2Wzmk08+4cMPP2TNmjV89NFH/OMf/6C4uLihQ3MYDw8P3nnnHV5//XVuvfVWsrOz8fT0RK+vm+/4zS4pbNmyhSNHjjBkyBAGDx5Meno6f/vb31i3bl1Dh+ZQza09ecuWLdHr9YwePRqAbt264ePjw9GjRxs4MsfLyMhgy5Yt3HTTTQ0disPt27ePzMxMYmNjAYiNjcXFxYXDhw83cGSO1bdvX3744QcWLlzIhAkTKCsrq7MzH80uKfz9739n3bp1rF69mtWrVxMcHMycOXPo379/Q4fmMM2xPbmvry+9evVi/fr1ABw9epTs7Gxat27dwJE53qJFi0hISMDHx6ehQ3G44OBg0tPTOXLkCACHDx8mKyuLVq1aNXBkjnX27FkAFEVh9uzZ3HXXXbi6utbJvpvlnEJz01zbk7/88ss899xzzJo1C71ezxtvvHFNz6NUWLRoEc8//3xDh1EvAgICeOmllyotKHj99dfx9vZu2MAc7N1332X79u2YTCb69evH1KlT62zf0jpbCCGETbM7fSSEEKJ6khSEEELYSFIQQghhI0lBCCGEjSQFIYQQNpIUxDVh2rRpvPPOOw1ybFVV+fe//01cXBy33XbbVb138ODBbNiwwUGRCXH1JCkIhxg8eDB9+/alpKTEtu2nn37i3nvvbcCoHGPbtm2sX7+epKQk5s+f39Dh1Mi9997LTz/91NBhiEZAkoJwGIvFwjfffNPQYVy1q203ffr0aUJDQ+vsitKaqLiXQEO51lt0NyeSFITD/O1vf+OLL76goKDgkudOnTpFx44dMZvNtm0XfltduHAhd911FzNnzqRHjx4MGTKE7du3s3DhQhISEujTpw+LFi2qtM/c3FweeOABoqOjmTBhAqdPn7Y9d/jwYR544AF69uzJiBEjWL58ue25adOmMX36dB5++GG6d+/Opk2bLok3IyODRx99lJ49ezJs2DDmzZsHWKufF154gZ07dxIdHc37779f5Wcxb948Ro4cSXR0NKNGjWLPnj225/bt28dNN91EbGwsTz31FOXl5YC1b/4jjzxC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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "df.groupby(\"models\").plot(x=\"num_char\", y=\"mi\", marker=\"o\", ax=ax)\n",
    "ax.legend([\"sDRE\",\"Ground Truth\", \"Single Ratio\", \"TRE\"])\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mutual information')\n",
    "plt.draw()\n",
    "plt.savefig('omniglot_mi.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot([4, 9], y[:2], label='Ground Truth', marker='o', c='orange')\n",
    "ax.plot([4, 9], y[6:8], label='Single Ratio', marker='o', c='green')\n",
    "ax.plot([4, 9], y[2:4], label='TRE', marker='o', c='red')\n",
    "ax.plot([4, 9], y[4:6], label='sDRE', marker='o', c='blue')\n",
    "plt.legend()\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mutual information')\n",
    "plt.savefig('omniglot_mi.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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USCcnJyYOXNmuocl5s2bh4ODQ+EGls++/PJLTp06hU6nw8PDAy8vrzx9f1mRUAghRK7ILSwhhBC5IglECCFErkgCEUIIkSuSQIQQQuSKJBAhhBC5IglElDiTJk1i8eLFhXJuRVGYPHkyrVq14tVXX83RsZ6enhw+fDifIhMi5ySBiELn6elJ+/btSUpKStu2ceNG3nrrrUKMKn+cPHmSkJAQDh48yKZNmwo7nFx566232LhxY2GHIYoASSCiSDAYDKxdu7aww8ixnLZBDw8Px9XVNU9nA+fU4/UwCktxbx1fkkgCEUXC+++/z5o1a3j06FGG1+7cuUP9+vXR6/Vp2578FLxlyxYGDx7M3LlzadmyJV27duXUqVNs2bKFzp07065dO7Zu3ZruPWNjY3n33Xdp1qwZQ4cOJTw8PO21a9eu8e6779K6dWt69uzJrl270l6bNGkSM2bMYMSIETRt2pRjx45liDcqKooPP/yQ1q1b0717d3799VfAdFU1depUTp8+TbNmzViyZEmmP4tff/2V3r1706xZM1566SUuXLiQ9lpoaCh9+/alRYsWfPLJJ2i1WsC09sMHH3xA27ZtadWqFR988AF3795N9/NavHgxgwcPpkmTJty+fZvNmzennadr1678/PPP6eIICgqiX79+NG/enG7duvHnn3+yePFiTpw4ga+vL82aNUtrtpnTn9nBgwd56aWXaNasGR07dszTNSpEAVKEKGQvvviiEhISoowePVpZtGiRoiiK8uuvvypDhw5VFEVRbt++rdSrV0/R6XRpxwwdOlT59ddfFUVRlM2bNyvu7u7Kpk2bFL1eryxatEjp3LmzMnPmTEWr1SqHDh1SmjZtqiQkJCiKoigTJ05UmjZtqvz111+KVqtVZs+erQwePFhRFEVJTExUOnXqpGzatEnR6XTK+fPnldatWyuXL19OO7Z58+bKiRMnFIPBoKSkpGQYz5tvvqnMmDFDSUlJUS5evKi0adNGOXz4cFqsj8+VmV27dikdOnRQzpw5oxiNRuXmzZvKnTt30n5OAwcOVO7evavExsYqvXr1Un766SdFURTlwYMHyu7du5WkpCQlPj5eGTNmjDJq1Kh0P6/OnTsrly9fVnQ6nZKamqr88ccfyq1btxSj0agcO3ZMady4sXL+/HlFURTlzJkzSvPmzZXg4GDFYDAod+/eVa5evZrhZ5/bn5mHh4dy/PhxRVEUJS4uLu284tkiVyCiyBg7dizr1q3L1YI3bm5uDBw4ECsrK1566SUiIyMZPXo0Go2GDh06oNFoCAsLS9u/S5cutGrVCo1Gw6effsrp06eJjIzkwIEDuLq6MnDgQKytrWnYsCE9e/Zkz549acd27dqVFi1aoFar05b+fSwyMpKTJ0/i5eWFra0t7u7uDBo0KN0KgOZs2rSJ4cOH07hxY1QqFTVq1MDV1TXt9bfeegtnZ2ccHBx48cUXCQ0NBaBChQr07NmTUqVKUbZsWUaNGsXx48fTvfeAAQOoW7cu1tbW2NjY0KVLF6pXr45KpaJ169Z4eHhw4sSJtDgGDhyIh4cHarUaZ2dnateunWnMufmZWVtbc/XqVRISErC3ty/265EUV9JMURQZ9erVo0uXLqxcuTLLP1ZZqVixYtrXdnZ2QPqVBW1tbdOt/VClSpW0r8uUKYO9vT337t0jPDycs2fPpltQymAw8PLLL6d9/7jlfWbu3buHvb09ZcuWTdtWtWpVzp8/b9E4IiMjzXaIdXJySvu6VKlS3Lt3D4Dk5GTmzZvHoUOHePjwIWBabdFgMGBlZZVp3AcPHmT58uXcvHkTo9FISkpK2lLGkZGRdO7c2aKYc/MzW7JkCStWrOCLL76gfv36fPbZZzRr1syi84miQxKIKFLGjh3LgAEDeO+999K2PS44p6SkpP1hftymOreerA8kJiby8OFDKleujIuLC61ateK7777L1ftWrlyZhw8fkpCQkBZrZGQkzs7OFh3v4uKS7krJUmvWrOHGjRv8+uuvODk5ERoaSv/+/VGe6JX65LLMqampjB07Fn9/f7p27YqNjQ0fffRR2v45iSM3P7PGjRuzYsUKdDod69ev55NPPuHgwYMWHy+KBrmFJYqUGjVq8NJLL/Hjjz+mbXN0dMTZ2ZnAwEAMBgObNm3i9u3bT3WegwcPcuLECVJTU/nqq69o0qQJLi4udOnShZs3b7Jt2zZ0Oh06nY6zZ89avPCQi4sLzZo1Y9GiRWi1Wi5dusSmTZssXrTp1VdfZc2aNZw/fx5FUbh161a6An9WEhMTsbW1pXz58sTFxbFs2TKz+6emppKamoqjoyPW1tYcPHgwbU2Ux3Fs2bKFI0eOYDQaiYqKSvsZVKpUKd3PP6c/s9TUVH777Tfi4+OxsbGhTJkyaVdJ4tkiCUQUOaNHj043JwRg9uzZrF69mjZt2nD16tWnvt3Rp08fli9fTps2bbhw4QILFiwAoGzZsqxevZpdu3bRsWNHOnTowMKFC0lNTbX4vRctWkR4eDgdO3bk448/ZsyYMXh4eFh0bO/evfnwww/57LPPaN68OaNHj067JWXO22+/jVarpW3btrz++ut07NjR7P5ly5Zl6tSpfPLJJ7Rq1YodO3bg6emZ9nrjxo2ZN28ec+fOpUWLFgwdOpSIiAgAhg0bxp49e2jVqhVz5szJ1c8sMDAQT09Pmjdvzs8//8z8+fMt+vmIokXWAxFCCJErcgUihBAiVySBCCGEyBVJIEIIIXJFEogQQohckQQihBAiVySBCCGEyBVJIEIIIXJFEogQQohckQQihBAiV/4fGFHeyZRxJGQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot([4, 9], y[4:6], label='sDRE', marker='o', c='blue')\n",
    "ax.plot([4, 9], [16.08, 35.39], label='sDRE with same enc', marker='o', c='purple')\n",
    "plt.legend()\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mutual information')\n",
    "plt.savefig('omniglot_mi_sameenc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "x = [4, 9, 4, 9]\n",
    "y = [91.04, 84.97] + [100.00, 99.98] + [53.54 ,24.15]\n",
    "models = ['TRE'] * 2 + ['CoB'] * 2 + ['Single Ratio']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(list(zip(x, y, models)),\n",
    "               columns =['num_char', 'accuracy', 'models'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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>num_char</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>models</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4</td>\n",
       "      <td>91.04</td>\n",
       "      <td>TRE</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>9</td>\n",
       "      <td>84.97</td>\n",
       "      <td>TRE</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4</td>\n",
       "      <td>100.00</td>\n",
       "      <td>CoB</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>9</td>\n",
       "      <td>99.98</td>\n",
       "      <td>CoB</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   num_char  accuracy models\n",
       "0         4     91.04    TRE\n",
       "1         9     84.97    TRE\n",
       "2         4    100.00    CoB\n",
       "3         9     99.98    CoB"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'accuracy'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/indexes/base.py\u001b[0m in \u001b[0;36mget_loc\u001b[0;34m(self, key, method, tolerance)\u001b[0m\n\u001b[1;32m   3079\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3080\u001b[0;31m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_engine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcasted_key\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   3081\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mKeyError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0merr\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32mpandas/_libs/index.pyx\u001b[0m in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mpandas/_libs/index.pyx\u001b[0m in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mpandas/_libs/hashtable_class_helper.pxi\u001b[0m in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mpandas/_libs/hashtable_class_helper.pxi\u001b[0m in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: 'accuracy'",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-28-e36e08fcf6f8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mfig\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0max\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msubplots\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mdf\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgroupby\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"models\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"num_char\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"accuracy\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmarker\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"o\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0max\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0max\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlegend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"sDRE\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"TRE\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mxlabel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Number of characters'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mylabel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Mean label accuracy (test)'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/groupby/groupby.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    464\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    465\u001b[0m         \u001b[0mf\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"plot\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 466\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_groupby\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mapply\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    467\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    468\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__getattr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mstr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/groupby/groupby.py\u001b[0m in \u001b[0;36mapply\u001b[0;34m(self, func, *args, **kwargs)\u001b[0m\n\u001b[1;32m    892\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0moption_context\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"mode.chained_assignment\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    893\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 894\u001b[0;31m                 \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_python_apply_general\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_selected_obj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    895\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mTypeError\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    896\u001b[0m                 \u001b[0;31m# gh-20949\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/groupby/groupby.py\u001b[0m in \u001b[0;36m_python_apply_general\u001b[0;34m(self, f, data)\u001b[0m\n\u001b[1;32m    926\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0mafter\u001b[0m \u001b[0mapplying\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    927\u001b[0m         \"\"\"\n\u001b[0;32m--> 928\u001b[0;31m         \u001b[0mkeys\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalues\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmutated\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgrouper\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mapply\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    929\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    930\u001b[0m         return self._wrap_applied_output(\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/groupby/ops.py\u001b[0m in \u001b[0;36mapply\u001b[0;34m(self, f, data, axis)\u001b[0m\n\u001b[1;32m    236\u001b[0m             \u001b[0;31m# group might be modified\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    237\u001b[0m             \u001b[0mgroup_axes\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgroup\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0maxes\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 238\u001b[0;31m             \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mgroup\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    239\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0m_is_indexed_like\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mres\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgroup_axes\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    240\u001b[0m                 \u001b[0mmutated\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/groupby/groupby.py\u001b[0m in \u001b[0;36mf\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    461\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    462\u001b[0m         \u001b[0;32mdef\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 463\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    464\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    465\u001b[0m         \u001b[0mf\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"plot\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/plotting/_core.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    939\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    940\u001b[0m                 \u001b[0;31m# don't overwrite\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 941\u001b[0;31m                 \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcopy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    942\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    943\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mABCSeries\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/frame.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m   3022\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolumns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnlevels\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3023\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_getitem_multilevel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3024\u001b[0;31m             \u001b[0mindexer\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolumns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   3025\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mis_integer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindexer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3026\u001b[0m                 \u001b[0mindexer\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mindexer\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/pandas/core/indexes/base.py\u001b[0m in \u001b[0;36mget_loc\u001b[0;34m(self, key, method, tolerance)\u001b[0m\n\u001b[1;32m   3080\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_engine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcasted_key\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3081\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mKeyError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0merr\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3082\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mKeyError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0merr\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   3083\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3084\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mtolerance\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: 'accuracy'"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "df.groupby(\"models\").plot(x=\"num_char\", y=\"accuracy\", marker=\"o\", ax=ax)\n",
    "ax.legend([\"sDRE\", \"TRE\"])\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mean label accuracy (test)')\n",
    "plt.draw()\n",
    "plt.savefig('omniglot_acc.png')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot([4, 9], y[4:6], label='Single Ratio', marker='o', c='green')\n",
    "ax.plot([4, 9], y[0:2], label='TRE', marker='o', c='red')\n",
    "ax.plot([4, 9], y[2:4], label='sDRE', marker='o', c='blue')\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mean label accuracy (test)')\n",
    "plt.legend()\n",
    "plt.savefig('omniglot_acc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot([4, 9], y[4:6], label='Single Ratio', marker='o', c='green')\n",
    "ax.plot([4, 9], y[0:2], label='TRE', marker='o', c='red')\n",
    "ax.plot([4, 9], y[2:4], label='sDRE', marker='o', c='blue')\n",
    "plt.xlabel('Number of characters')\n",
    "plt.ylabel('Mean label accuracy (test)')\n",
    "plt.legend()\n",
    "plt.savefig('omniglot_acc_sameenc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "x = [1, 3]\n",
    "y = [10.66, 15.34]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Mutual information')"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAEMCAYAAAArnKpYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAApAklEQVR4nO3de3gU9d3+8fdusgcCSAAjBlAQFESxiFCVp0Rr8FGq4g+NFotUBIUqVWgCJmrCKSRCOIWDYFRAERWLgChCBRUtivXBqqggBSoKcpQgFEh2N4ed3x9TVxAIm8PubDb367pysTt7mA/LkHu/M/P9jM0wDAMRERHAbnUBIiISORQKIiISoFAQEZEAhYKIiAQoFEREJEChICIiAQoFEREJiLW6gJpw6FARfn/lp1s0bdqAgwePhaCi6lFdlaO6Kkd1VU401mW322jcuP4pH4uKUPD7jSqFwk+vjUSqq3JUV+WorsqpS3Vp95GIiAQoFEREJEChICIiAQoFEREJUCiIiNQiS5bEcsUV9bHb4Yor6rNkSc2eLxQVZx+JiNQFS5bEkpbmxuOxAbBrl520NDfgJSWlrEbWoZGCiEgtkZvrCgTCTzweG7m5rhpbh0JBRKQWMAzYtct2ysd27z718qpQKIiIRLg9e2z88Y/1gFP/8m/RouYmsSkUREQilN8PL7zgICmpPh98EENKSgn16p0YAPXqGWRm+mpsnQoFEZEItH27jZSUeowY4ebyy8v5+9+LeOopH1OnemnZ0o/NBi1b+pk6teYOMoPOPhIRiShlZfD00w7y8lw4HDB1qpe77y7F9t89RykpZaSklJGQ0JADB4pqfP0KBRGRCPH113ZSU918/nkMPXuWkpfnIzExvM34FAoiIhbz+WDaNCfTpzuJjzd45hkP/+//lQVGB+GkUBARsdCnn5qjg3/9K4Y77ihl3DgfTZta16pboSAiYoGiIpgwwcUzzzhITDR4+eVirr++3OqyFAoiIuG2dm0MaWludu60c++9JYwc6aNhQ6urMoUlFPLy8li1ahW7d+9m+fLltGvXDoDk5GScTiculzlFe8SIESQlJYWjJBGRsPvPf2DsWBcvvuikTRs/r79eTLdu1o8OjheWUOjRowf33HMPd99990mPzZgxIxASIiLR6m9/iyU93cWBAzYeesjHI4+UUK+e1VWdLCyh0LVr13CsRkQk4hw4YCMz08WyZQ4uuaScBQs8XH653+qyTsvyYwojRozAMAy6dOlCWloaZ511ltUliYhUm2HA4sWxZGW5KSqCxx7z8dBDJTgcVldWMZthGGE79yk5OZmCgoLA7qK9e/eSmJhISUkJubm5FBUVMXny5HCVIyISEt9/Dw88ACtXQrduMHcudOhgdVXBsXSkkJiYCIDT6aRv3748+OCDVXqfgweP4fdXPtvMaeJHq7TOUFJdlaO6Kkd1VU5l6vL7Yf58B9nZLgwDcnN9DBxYSkwMHDhgXV2/ZLfbaNq0wSkfsywUiouLKS8vp2HDhhiGwcqVK+lQW6JUROQXvvnGRmqqm48/juWaa8qYMsVLq1bWTUKrqrCEQk5ODqtXr6awsJABAwYQHx9PQUEBDz/8MOXl5fj9ftq2bcvo0aPDUY6ISI0pK4OnnnIyaZITlwumT/dw113WtKioCWEJhaysLLKysk5avmzZsnCsXkQkJDZutPOXv7j58ssYbrrJbGDXrFntGx0cz/Kzj0REahufD/LzncyYYTawmzvXwy231N7RwfEUCiIilbB+vZ20NDdbt8bQp08p2dleGje2uqqao1AQEQnCsWMwfryLOXMctGhh8MorxSQnR1aLipqgUBAROYP3349hxAizgd1995WQmemjwanP6Kz1FAoiIqdx+DBkZMBzz8Vx4YXlvPFGMVdfHX2jg+MpFERETmHFilgyMlwcPAjDhvkYPrwEt9vqqkJPoSAicpz9+208/riL5csddOxYzltvQcuWJVaXFTZ2qwsQEYkEhgGvvBJLUlJ9Vq+OJTPTx6pVxXTubHVl4aWRgojUed9/b2PECDfvvRfLlVeWkZ/v46KLIre9dSgpFESkzvL74bnnHIwbZ179cfx4LwMGlGKvw/tQFAoiUif9+982/vIXN+vXx3LddWVMnuzlvPNqd4uKmqBQEJE6pbQUZs92Mnmyk3r1YMYMD336REeLipqgUBCROuOrr8wGdl99FUOvXqU88UTtb2BX0xQKIhL1vF6YMsXJk086adrUYN48s4GdnEyhICJR7eOPY0hNdfPNN3b+8IdSxo71Eh9vdVWRS6EgIlHp2DHIyXExb56T88/3s2hRMb/9bXS3qKgJCgURiTpr1pgN7HbvtjFoUAmPPRa9DexqmkJBRKLGoUMwcqSbRYscXHRROcuXe7jyyro5Ca2qFAoiUusZBrz5ptnA7vBhG2lpPv7yl7rRwK6mKRREpFbbv99GRoaLlSsddOpUzqJFHjp21OigqhQKIlIr/dTAbtQoNz4fjBzp48EHS4jVb7Vq0ccnIrXOjh02hg93s3ZtLFdfXUZ+vpe2bTUJrSYoFESk1igvh3nzHOTmurDZIC/PS//+dbuBXU1TKIhIrbB1q9mi4p//jKFHjzImTfLSsqVGBzUt6FBYvRo2bDAnhBwvO7uGKxIROU5pKcyc6WTqVCcNGhjMmuXhjjvUwC5UggqFhx6CRYvguusgLu7n5fpHEZFQ+uILO8OGufn66xh69y4lN9dHQoJGB6EUVCgsXGiOEs47L8TViIgAHg9MmuRk9mwnCQkG8+d7+N3v1MAuHIIKhaZNUQMpEQmLf/zDbGC3fbudfv1KGD3aR6NGVldVdwQVCsOHw913w2OPQbNmJz7Wpk0oyhKRuubIEUhPd/H882YDu8WLi7nmGjWwC7egQuHBB80/33zzxOU2m3mKmIhIdbzzTgwZGbBrl4M//amERx/1Ub++1VXVTUGFgl8zxkUkBA4etDFypIvFix1ccgmsWFFM1676hWOlSk352LkT/vEP+P77UJUjInWBYcCyZbEkJcWxbFksI0b4+OwzFAgRIKhQ2LsXrr0WLrwQbr8d2raFa66BPXtCXZ6IRJt9+2z07+9m8OB6tGxp8M47xaSnl+ByWV2ZQJCh8OCD0KmT2at8717zz86d4YEHQl2eiEQLw4AXX3TQvXt93n8/ljFjvKxcWcwll2h0EEmCCoUPP4QpUwgc+KlfHyZOhI8+Cm4leXl5JCcn0759e7Zu3XrS408++eRpHxOR2u+772zccUc90tLcdOxYzvvvFzFkSKk6mkagoEKhcWP4+usTl23ZEvzchR49evDSSy/RokWLkx7btGkTGzZsoHnz5sG9mYjUGuXlUFDg4Npr6/P55zFMnuxl6VIPbdpoVnKkCiqn09Ph+uvhvvugVSvYsQOeew7GjQtuJV27dj3l8pKSErKzs5k8eTL9+/cPumgRiXybN9tJS3Pz6acx3HBDGRMnemneXGEQ6YIKhUGDzIPLL78MX34JzZubrS+Sk6u38unTp3PrrbdyXjX7ZzRtWvUrcickNKzWukNFdVWO6qqcUNZVUgLjx0NuLjRqZP7euOuuWGy2M/8/rYufV3WEoq6g9+glJ1c/BI73+eef89VXXzFixIhqv9fBg8fw+yv/DSQhoSEHDhyt9vprmuqqHNVVOaGs6/PPzfbWmzfHcPvtpeTk+Dj7bIPCQmvrqo5orMtut532y/RpQyE3FzIzzdujRp3+zavaOvuTTz5h+/bt9OjRA4B9+/Zx3333MX78eLp37161NxURSxQXQ16ei6efdtCsmcGCBcXceKPaHdRGpw2FXbt+vh2KyWqDBw9m8ODBgfvJyckUFBTQrl27ml+ZiITMunVmA7vvvrNzzz0ljBrl46yzrK5Kquq0ofDUUz/ffu656q0kJyeH1atXU1hYyIABA4iPj2fFihXVe1MRsdSRIzB2rIsFC5y0bu1n6dJiunfX6KC2C+qYQpMm8OOPJy8/5xz44Yczvz4rK4usrKwKn7NmzZpgShGRCLBqVQzp6W7277cxZEgJ6em+Ey7AJbVXUKFQWnrqZeqQKlK3FBbayMpysXSpgw4dynn+eQ+dO2tGcjSpMBSSksz22F6v2evoeLt2wf/8TyhLE5FIYRiwdGksmZkujh61kZ7uY+jQEpxOqyuTmlZhKNx/v7kxfPKJOXHtJzabebGdmjxFVUQi0549NtLT3axeHUuXLuXk53u4+GKNDqJVhaHw0yTjq6+Giy8ORzkiEin8fliwwMHYsS7KyyE728ugQaXExFhdmYRSUMcULr4Y9u+H9euhsNAcPfxk4MBQlSYiVtm+3cbw4W7WrYslKamMKVO8tG6tFhV1QVChsGwZ9OsHF10EmzbBpZfCxo3QvbtCQSSalJXB0087yMtz4XDA1Kle7r67FJvN6sokXIIKhawsc67CnXeaHVM//9y8v2lTqMsTkXDZtMlOaqqbDRti6NmzlLw8H4mJGh3UNUG1zt650wyE4/XvDy+8EIqSRCScfD7Iy3Pyv/8bx65dNp591sP8+V4FQh0V1EjhnHPMYwrNmkHr1uZ1ms8+W/MURGq7f/7THB1s2RLDHXeUkpPjpUkTq6sSKwU1Uhg0yLz6GkBqKlx3nXl5ziFDQlmaiIRKURGMHOni5pvjOHrUxssvFzN7tgJBghwpZGT8fPuee+C3vzU3qg4dQlSViITMu+/CwIH12bnTzr33ljBypI+GkXm5ALFAla6Qev75NV2GiITaf/5jNrB78UVo0wZef72Ybt20D1hOFNTuoy++MGcvN2kCTqf543CgKe4itcTf/hZL9+71WbjQQUYGvPdekQJBTimokcIf/gApKTBjBtSrF+qSRKSm/PCDjcxMF6+/7uDSS8t58UUP119fnwMHrK5MIlVQobBvn3mFNU1gEakdDAMWL44lK8tNURE89piPhx4qweGwujKJdEHtPurf37z4tohEvl27bPTtW48//7kebdv6WbOmmNRUBYIEJ6iRwqOPQrdu8MQT5lyF4+naOCKRwe+H5593MG6cC8OA3FwvAweqgZ1UTlChcMcdcMEFcNttOqYgEom++cZGaqqbjz+O5ZprzAZ2rVppRrJUXlChsGEDHDyos41EIk1ZGcye7WTSJCduN0yf7uGuu8p0/E+qLKhjCklJ8PXXoS5FRCpj40Y7PXvGkZPjokePMj78sIg//EGBINUT1EjhggvghhvM3Ue/PKaQnR2KskTkdLxeyM93MnOmk8aNDebO9dCrV5nVZUmUCCoUiovh5puhpAS+//7n5fpGIhJe69ebDey2bYuhT59SsrO9NG5sdVUSTc4YCuXlcN55kJkJLlc4ShKRXzp2DMaPdzFnjoMWLQxeeaWY5GTNSJaad8ZjCjExMHs2OsdZxCLvvRfDtdfW59lnnQwcWMratUUKBAmZoA4033MPFBSEuhQROd7hwzB0qJs+feJwuQzeeKOY8eN9NGhgdWUSzYI6prB+PcycCRMnmruSjj+WsHZtqEoTqbvefDOWRx91cfCgjWHDfAwfXoLbbXVVUhcEFQqDBpk/IhJa+/fbeOwxF2++6aBjx3IWLvRw2WV+q8uSOiSoUOjfP9RliNRthgF//Wsso0a58XggM9PHkCHqVyThF9QxBYDnnjOvqdC+vfnnc8+FsiyRumPnTht9+tRj6NB6tGtXzpo1xQwbpkAQawQ1UsjNhRdegOHDoVUr2LHDPL6wZ495qqqIVJ7fD/PmOcjJMc/1Hj/ey4ABpdiD/qomUvOCCoU5c+D9981A+MmNN8I11ygURKpi2zY7qaku1q+P5brrypg82ct556mBnVgvqFAoKoKEhBOXNW0KHk8oShKJXqWlMGuWk8mTncTFwcyZHn7/e/UrksgR1EC1Z0+4+27YssUMgn/9yzz4fOONoS5PJHp89ZWdG2+M44knXNx4o9nArk8fBYJElqBC4cknoWFD6NQJGjSAyy+H+vXNuQvByMvLIzk5mfbt27N169bA8iFDhnDrrbfSu3dv+vbty+bNm6vydxCJaF4v5OQ4ueGGOH74wca8eR7mzvVyzjnaXSSR57Sh8OSTP9/+4QfzQHNxMezda/75wgsQHx/cSnr06MFLL71EixYtTliel5fHG2+8wbJlyxg4cCCPP/54Vf4OIhHr449juO66+syY4eL3vzdHB7fcoo6mErlOGwrHH0C+4or/PtkO55xDpc+O6Nq1K4mJiSctb9iwYeD2sWPHsGkcLVHi2DF46CG49dY4Skth0aJipk/3Bv1FSsQqpz3Q3LateQrqpZeaB8fmzTv18wYOrF4BmZmZrFu3DsMwmDNnTvXeTCQCrFkTw4gRbnbvhsGDS3j0UfUrktrDZhjGKXdsbt1qzkXYsQPee8+8+tpJL7bBmjXBryw5OZmCggLatWt30mPLli1jxYoVPPvss8G/oUgEOXgQ0tLMXasdOsDcudCtm9VViVTOaUcK7dqZ8xMAevSAd98NbSG9e/dm1KhRHDp0iMaVvGrIwYPH8Psrf9AuIaEhBw4crfTrQk11VY7VdRmG2cAuI8PF4cM20tJKSE0toWVLfV6Voboqpzp12e02mjY99fA1qHkKxweC/xe9uao6+7KoqIgjR44EjjWsWbOGRo0aEa+drlKL7N9vIyPDxcqVDjp1KmfRIg8dO6qBndReQYXCZ5/Bn/8MX35pnl4H5rcjm828MtuZ5OTksHr1agoLCxkwYADx8fHMnz+fYcOG4fF4sNvtNGrUiIKCAh1sllrBMGDhwlhGj3bj88HIkT4efLCE2KD+R4lErqC7pPbqZR5sjour/EqysrLIyso6afmiRYsq/2YiFtuxw8bw4W7Wro3l6qvLyM/30rat5hxIdAgqFHbsMJvi6Uu81GXl5TB3roMnnnBht0Nenpf+/dXATqJLUJvzbbfB6tWhLkUkcm3ZYqdXrziystx061bOBx8UqaOpRKWgRgperxkM3bvDueee+NgLL4SiLJHIUFoKM2c6mTrVSYMGBrNne0hJUb8iiV5BhcIll5g/InXJF1/YGTbMzddfx9C7dym5uT4SEnTsQKJbUKEwenSoyxCJHB4PTJrkZPZsJwkJBvPne/jd79SvSOqG04bC2rXmRXSg4lnLyck1XZKIdT76KIbUVDfffmunX78SRo/20aiR1VWJhM9pQ2HIENi40bx9332nfo7NBtu3h6IskfA6ehSys13Mn++kVSs/ixcXc801QUzCEYkypw2FnwIB4Ntvw1GKiDXeecdsYLdvn40HHighI8NH/fpWVyViDc2/lDrr4EEbWVkulixx0L59OXPneujSRS0qpG5TKEidYxjw+uuxPP642cBuxAgfw4aV4HJZXZmI9RQKUqfs3Ws2sHvrLQeXX17O4sUeLrlEowORnygUpE4wDHjxRQdjxrgoLYUxY7wMHlyqBnYiv3Da/xK/bJF9OprmL5Hu22/NBnYffhjLb35TxpQpXtq00SQ0kVM5bSjExlbcAK8yrbNFrFBeDs8842DCBBexsTB5spd+/dSvSKQipw0FnYYqtdnmzXZSU9189lkMN9xQxsSJXpo31+hA5ExOGwqtWoWzDJGaUVIC06c7mTbNyVlnGRQUeLjtNjWwEwlW0IfZ3ngD/v53KCw0dx39RF1SJVJ89pk5Oti8OYbbby8lJ8fH2WdrdCBSGUHtXR07Fv70J/Pg86uvQtOmsGoV6HLKEgmKi2H0aBc33RTH4cM2FiwopqDAq0AQqYKgQmHePHj7bcjPB6fT/HP5cvjuuxBXJ3IGH34Yw2WXwVNPOenXr5QPPijixht19oNIVQW1++jwYejY0bztdJoXHrnySnN3kogVjhyBsWNdLFjgpG1beO21Yn7zG4WBSHUFFQpt28KmTXDppWY4PPUUNG5s/oiE26pVMTzyiJsffrAxZEgJkyY5KSpSIIjUhKBCIScHDh40b48fD3ffDceOwezZoSxN5ESFhWYDu6VLHXToUM78+R46d/YTF+ekqMjq6kSiQ1ChcNNNP9++6ir4979DVY7IyQwDli6NJTPTxdGjNtLTfQwdWoLTaXVlItEnqFCo6EI6bdrUVCkiJ9u920Z6upu3346lS5dy8vM9XHyxGtiJhEpQoXDhhWZLi+PnJ/w0GUhtLiQU/H5YsMDB2LEu/H4YN87L/feXEhNjdWUi0S2oUPhlc7x9+8y5C0lJoShJ6rrt222kpbn56KNYkpLMBnatW2vOgUg4VKlx8LnnwrRp0K4d9O1bwxVJnVVWBk8/7SAvz/Xf+TBe+vYtVYsKkTCqcjf5LVvMmaQiNWHTJrNFxYYNMfTsWcrEiT7OPVejA5FwCyoUkpJObKNdXGzOWxg1KlRlSV3h80F+vpMZM5zExxs8+6yHW29VAzsRqwQVCvfff+L9+vWhUye46KJQlCR1xT//aY4OtmyJ4Y47SsnJ8dKkidVVidRtQYVCXBzceefJyxcvhjvuqOmSJNoVFcGECS6eecZB8+YGL79czPXX6zQ2kUgQVEO8++479fLBg2uyFKkL1q6N4dpr6/P0007uvbeUtWuLFAgiEaTCkcJPk9b8fvNKbMfPU9i+HdzuUJYm0eQ//4ExY1y89JKTNm38vP56Md26KQxEIk2FoXD8pLW2bU987NxzYcyY4FaSl5fHqlWr2L17N8uXL6ddu3YcOnSI9PR0du7cidPppFWrVmRnZ9NEO5WjzsqVsWRkuCgstPHwwz5GjCihXj2rqxKRU6lw95Hfb85YTkoybx//s2dP8LuPevTowUsvvUSLFi0Cy2w2G/fffz+rVq1i+fLlnHfeeUyePLlafxmJLD/8YOP++93ce289zj7b4K23ihk5UoEgEsmCOqZQ3esmdO3alcTExBOWxcfHc9VVVwXuX3755ezZs6d6K5KIYBiwaFEsSUn1eeutWB57zMfq1cV06qSeRSKRrkrzFI63dm31i/D7/SxcuJDk5OTqv5lYatcuG4884ubdd2Pp2rWcadO8tGunMBCpLao0T2HfPpg7F/r1q5kixo0bR1xcHP2q+IZNmzao8roTEhpW+bWhVNvq8vuhoAAyMsyRwowZMGRIDDEx9S2ty2qqq3JUV+WEoq6gQqF//5OXpaTAgAHVn9Wcl5fHjh07KCgowG4Pam/WSQ4ePIbfX/mWCAkJDTlw4GiV1hlKta2ub76xkZrq5uOPY7n2WrOB3fnnG/z4o7V1WU11VY7qqpzq1GW32077ZbrKvY9atIAvv6zqq035+fls3LiRZ555BqeumFLrlJXB7NlOJk1y4nbDjBke+vRRiwqR2iyoUJg378T7xcWwdClcfXVwK8nJyWH16tUUFhYyYMAA4uPjmTZtGgUFBbRu3Zq77roLgJYtWzJr1qxK/QXEGl99Zbao+PLLGG66qZS8PB/NmqmBnUhtF1QoLFhw4v369eF//gdSU4NbSVZWFllZWSct37JlS3BvIBHD64WpU53MnOmkSRODuXM99OpVZnVZIlJDggqF994LdRlSG3z0Edx7bxzbtsXQp08p2dleGje2uioRqUkVhsLOnWd+g/PPr6lSJFIdOwZPPOFi7lxo0cLGK68Uk5ysFhUi0ajCUGjd+uf5CcYpdhfbbLpGc7R7770YRoxws2uXjT//GdLSimhQ9TOARSTCVXgO6K9+ZV4zIScHduyA0tITf0pKwlWmhNuhQzB0qJs+feJwuQxef93DzJkoEESiXIWhsGGDec2EH3+E7t3hppvglVfMMIiJMX8k+ixfHkv37vV59dVYhg3zsWZNMVdfrSGhSF1wxtliHTvCpElm6+y0NHjzTUhMhM8+C0d5Ek7799sYONDNfffVo1kzg9Wri8nMLFGLdJE6JOjJa9u2mY3x/vEP6NwZnXUSRQwD/vrXWEaNcuPxQFaWjwcfLMHhsLoyEQm3CkPhxx9h4UKYPx+OHoU//tFsgKczjqLHzp02Roxw8/77sVx1VRn5+V4uvFCT0ETqqgpDoXlzuOACMwx+mr3873+bPz9RY9Paye+HefMc5OS4sNlg/HgvAwaUUsX2UyISJSoMhXPPNWewPvus+fNLNtvPl+yU2mPbNjupqS7Wr4/luuvKmDzZy3nnaXQgImcIhe++C1MVEhalpTBrlpPJk53ExcHMmR5+/3s1sBORn1W5S6rULl9+aecvf3GzcWMMvXqVMn68j3PO0ehARE6kUIhyHg9MmeJk1iwnTZsaPPech5tvVgM7ETk1hUIU+/jjGFJT3XzzjZ2+fUsYM8ZHfLzVVYlIJFMoRKFjxyAnx8W8eU7OP9/Pq68Wc+21mpEsImemUIgy775rNrDbs8fG4MElPPqoT/2KRCRoCoUo8eOPMHKkm1dfddCuXTlvvunh17/2W12WiNQyCoVazjDMBnaPPuri8GEbaWk+UlNLcLmsrkxEaiOFQi22f7+N9HQXf/ubg06dylm0yEPHjhodiEjVKRRqIcOAhQvNBnYlJTBqlJcHHiglVv+aIlJN+jVSy3z3ndnAbu3aWLp1K2PqVC9t22oSmojUDIVCLVFeDnPmOBg/3oXdDhMnernnHjWwE5GapVCoBbZsMVtUfPppDD16mA3sWrTQ6EBEap5CIYKVlMDMmU7y8500aGAwe7aHlBQ1sBOR0FEoRKgNG8zRwddfx3DbbaXk5PhISNDoQERCS6EQYTweSE+HKVPiOOccgxdeKKZnT7WoEJHwUChEkI8+MhvYffst/PGPpYwa5aNRI6urEpG6RKEQAY4ehexsF/PnO2nVys+778Jll/msLktE6iCd0Gixt9+OISmpPgsWOHjggRLef79I170WEctopGCRgwdtZGW5WLLEQfv25cyd66FLF7WoEBFrKRTCzDBg2bJYHn/cxZEjNkaM8DFsmBrYiUhkUCiE0d69NjIyXLz1loPOncvJz/dwySUaHYhI5FAohIFhwIsvOhgzxkVZGYwZ4+VPfyolJsbqykREThSWA815eXkkJyfTvn17tm7desbl0eTbb22kpNRj+HA3v/pVOe+9V8SQIQoEEYlMYQmFHj168NJLL9GiRYuglkeD8nJ46ikHv/1tfb74IobJk70sWeKhTRvNShaRyBWW3Uddu3at1PLabvNmO6mpbj77LIYbbihj4kQvzZsrDEQk8umYQg0qKYHp051Mm+bkrLMMnn7aQ+/eamAnIrVHVIRC06YNqvzahISGNVLD+vVw332wcSP07QvTp9s4++x6ltdV01RX5aiuylFdlROKuqIiFA4ePIbfX/ndMwkJDTlw4Gi11l1cDBMmuHjmGQfNmhm8+KKXG24oxzDgwIGqvWdN1BUKqqtyVFflqK7KqU5ddrvttF+moyIUrPLhh2YDux077NxzTwmjRvk46yyrqxIRqbqwnH2Uk5PDNddcw759+xgwYAA333xzhcsj3ZEjMHy4i9tvj8Nmg9deK2byZAWCiNR+NsMwav1pMeHcfbRqVQyPPOLmhx9sPPBAKenpPuLiKr3qGq8rHFRX5aiuylFdlaPdRxYrLLSRmenitdccdOhQzvz5Hjp3VosKEYkuCoUzMAxYujSWzEwXR4/ayMjw8fDDJTidVlcmIlLzFAoV2L3bRnq6m7ffjqVLF7OB3cUXa3QgItFLoXAKfj+88IKD7GwXfj+MG+fl/vvVr0hEop9C4Re2b7eRlubmo49iSUoqY8oUL61b1/pj8SIiQVEo/FdZGRQUOJg40YXTCfn5Xvr2LVWLChGpU+pkKCxZEkturovdu6FFi/r071/CihUONmyIoWfPUiZO9HHuuRodiEjdU+dCYcmSWNLS3Hg85hBg1y47ubkuGjQwmDPHQ69eamAnInVXnQuF3FxXIBB+ZuOsswxuvbXMkppERCJFWNpcRJLdu089DNi7V8MDEZE6FwotWpz6WMHplouI1CV1LhQyM33Uq3diANSrZ5CZ6bOoIhGRyFHnQiElpYypU720bOnHZoOWLf1MneolJUXHE0RE6tyBZjCDISWl7L9dBousLkdEJGLUuZGCiIicnkJBREQCFAoiIhKgUBARkYCoONBst1d94ll1XhtKqqtyVFflqK7Kiba6KnpdVFyjWUREaoZ2H4mISIBCQUREAhQKIiISoFAQEZEAhYKIiAQoFEREJEChICIiAQoFEREJUCiIiEhAVLS5OF5eXh6rVq1i9+7dLF++nHbt2p30nPLycnJycvjggw+w2WwMHjyYO++884yPhbquWbNmsXLlSmJiYoiNjSU1NZWkpCQAZs6cycsvv8w555wDwBVXXMHo0aPDUldF67by80pPT2fLli2B+1u2bGHWrFn06NEjZJ/XoUOHSE9PZ+fOnTidTlq1akV2djZNmjQ54Xnh3saCrSvc21iwdYV7Gwu2Liu2sSFDhrBr1y7sdjtxcXGMHDmSDh06nPCckG5fRpT55JNPjD179hjXXXedsWXLllM+57XXXjMGDhxolJeXGwcPHjSSkpKM77///oyPhbqutWvXGsXFxYZhGMbmzZuNLl26GB6PxzAMw5gxY4YxYcKEatdRlboqWreVn9fxNm/ebFx55ZWGz+c7Y83VcejQIePjjz8O3J8wYYLx2GOPnfS8cG9jwdYV7m0s2LrCvY0FW9fxwrWNHTlyJHD77bffNnr37n3Sc0K5fUXd7qOuXbuSmJhY4XNWrlzJnXfeid1up0mTJlx//fW89dZbZ3ws1HUlJSVRr149ANq3b49hGBw+fLja665uXRWx8vM63uLFi+nVqxdOp7Pa665IfHw8V111VeD+5Zdfzp49e056Xri3sWDrCvc2FmxdFbHy8zpeuLaxhg0bBm4fO3YMm+3k5nWh3L6ibvdRMPbu3Uvz5s0D9xMTE9m3b98ZHwunZcuWcf7553PuuecGlq1YsYIPP/yQhIQEHn74YTp37hy2ek637kj4vEpKSli+fDnPP//8CctD/Xn5/X4WLlxIcnLySY9ZuY1VVNfxwr2Nnakuq7axYD6vcG9jmZmZrFu3DsMwmDNnzkmPh3L7qpOhEOnWr1/P9OnTmTdvXmDZXXfdxQMPPIDD4WDdunUMGTKElStX0rhx45DXY+W6g/HOO+/QvHnzE/a7hqPmcePGERcXR79+/WrsPWtCMHVZsY1VVJeV21gwn1e4t7Hc3FzADO6JEyfy7LPPVvs9gxV1u4+CkZiYeMJQce/evYFvSxU9Fg6ff/45jzzyCLNmzaJNmzaB5QkJCTgcDgB+85vfkJiYyLZt28JSU0XrtvrzAliyZAkpKSknLAv155WXl8eOHTuYNm0advvJ/42s2sbOVBdYs42dqS6rtrFgPi+wZhsD6N27N//3f//HoUOHTlgeyu2rToZCz549efXVV/H7/fz444+888473HjjjWd8LNS+/PJLUlNTmTFjBpdeeukJj+3fvz9we/PmzezevZsLLrggLHVVtG4rPy+Affv28emnn3LLLbcEXXN15efns3HjRmbNmnXa/ctWbGPB1GXFNhZMXVZsY8HUBeHdxoqKiti7d2/g/po1a2jUqBHx8fEnPC+U21fUXWQnJyeH1atXU1hYSOPGjYmPj2fFihUMGjSIoUOHctlll1FeXk52djbr1q0DYNCgQfTp0wegwsdCXVdKSgq7d++mWbNmgddNnDiR9u3bk5GRwaZNm7Db7TgcDoYOHcq1114blroqWreVnxfAU089xdatW8nPzz/h9aH6vLZt28Ytt9xC69atcbvdALRs2ZJZs2ZZuo0FW1e4t7Fg6wr3NhZsXRDebaywsJAhQ4bg8Xiw2+00atSIjIwMLr300rBtX1EXCiIiUnV1cveRiIicmkJBREQCFAoiIhKgUBARkQCFgoiIBCgUREQkQKEgUoOSk5P56KOPAvdXrFjBr3/9a9avX29hVSLBU+8jkRB57bXXmDBhAk8//TRXXHGF1eWIBEWhIBICf/3rX5k6dSpz5swJzIwVqQ0UCiI1bOHChXz66afMnz+fiy++2OpyRCpFxxREati6devo1KnTKS8hKhLpFAoiNWzs2LF89913ZGZmotZiUtsoFERqWNOmTXn++ef59NNPGTNmjNXliFSKQkEkBJo1a8b8+fP54IMPeOKJJ6wuRyRoCgWREElMTGT+/PmsWrWKKVOmWF2OSFB0PQUREQnQSEFERAIUCiIiEqBQEBGRAIWCiIgEKBRERCRAoSAiIgEKBRERCVAoiIhIgEJBREQC/j/tq5XuWdUsUgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# create figure and axis objects with subplots()\n",
    "fig,ax = plt.subplots()\n",
    "# make a plot\n",
    "ax.plot(x, y, color=\"blue\", marker=\"o\")\n",
    "# set x-axis label\n",
    "ax.set_xlabel(\"K\")\n",
    "# set y-axis label\n",
    "ax.set_ylabel(\"Mutual information\",color=\"blue\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "y2 = [86.7, 100.0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "# twin object for two different y-axis on the sample plot\n",
    "ax2=ax.twinx()\n",
    "# make a plot with different y-axis using second axis object\n",
    "ax2.plot(x, y2,color=\"orange\",marker=\"o\")\n",
    "ax2.set_ylabel(\"Mean label accuracy (test)\",color=\"green\")\n",
    "plt.show()\n",
    "# save the plot as a file\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig.savefig('omniglot_k.jpg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch1.8",
   "language": "python",
   "name": "torch1.8"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
