{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "import sys\n",
    "sys.path.append('..')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "BASE_DIR = None # redacted\n",
    "RESULT_DIRS = [x for x in os.listdir(BASE_DIR) if os.path.exists(os.path.join(BASE_DIR, x, 'results.pickle'))]\n",
    "lmbdas = [float(result_dir.split('=')[-1]) for result_dir in RESULT_DIRS]\n",
    "indices = np.argsort(lmbdas)\n",
    "RESULT_DIRS = [RESULT_DIRS[idx] for idx in indices]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKAAAADaCAYAAACRrzoIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA/EklEQVR4nO3df3Db+X3f+RdIrenddUWQcmKvw/VKX4nJNdN4RJB0z+sktUXQ6vTif1aglF7vatcSwZXdjHPpilz2hz2ZuqHA3dTNTXO7gCSPfZdMIgLWXZM0yYrQ6mZ6sXMhASm+ZKYNBUgbMWs33QUg2rsb2RK/9weMXwRIAiSA7+dLPB8zGAHfX3h/iLe++H7f+Hw/X49t27YAAAAAAACAFulyOgAAAAAAAADsbRSgAAAAAAAA0FIUoAAAAAAAANBSFKAAAAAAAADQUhSgAAAAAAAA0FIUoAAAAAAAANBSFKAAAAAAAADQUhSgHDY1NaWZmRmnwwAaQt7CFOQiTEAewhTkIkxAHqJVyC3389i2bTsdRKfzeDxKJBLy+Xxte8/5+Xl5vV5JUi6X0/T09K7X2e38XC6nhYUFRaNRLS4uNt4otJVb8pa82vvckovz8/OSpFQqJUkKh8Mtiw/t54Y8LOwPpXweptNpXbhwobgN7A1uyMWNxsfH+Y7eY9yQh/F4XOFwWOPj47IsS4uLixodHVUgEGhDtNgpJ3Jru/OJVp8n17Lb/a5T6AFlgEAg0NYTkcJJUDAYVDAYlM/n09TU1K7W2e38ZDKphYUF5XI5ZTKZ5jQULeWGvCWvOoMbcnFmZkbT09Oanp4uxjo+Pt7yWNE+bslDv9+vYDCoUCik/v5+TUxMtCNctJEbcrFcLBZTPB5vVXhwiBvyMJfLKR6Pa2pqSlNTUzp8+DDFJxdod25tdz7R6vPkWna733WUDcctLi7aXq+3be/n9XrtbDZbMW27VNhund3OL4hGo7bP59syFpjBDXlbQF7tbabnYjabtf1+f8U6iUTClmSnUqkWRYl2Mz0Pbdu2/X6/HQqFiq9DoVBbY0Z7uCEXC7LZrB0Oh+teHu7hhjyMRqNV68B87c6tgs3OJ9p1ntzIe5qMHlAG8Pv9kvLV1VZLp9PK5XI1u9tv9uvTduvsdj7cyfS8RedwQy4uLy8rnU4XX1uWJSn/6yv2Bjfk4eLiYkUX/aWlpWLc2DvckIsFCwsLOnnyZAsig9PclIdwl3bm1nacOE92e75TgDLEyZMn29KVsPwEqJzX6930RGi7dXY7H+5lct6is5ici16vV9lstmKsgsIBQqEQhb3B5DzcKBaLKZfL6cKFC02MDKZwQy7G43EKoHucG/JwYWFBsVhMkUiEwa1dpF25tR0nzpPdfl60z+kAkOf1ehWJRLb9j1TvtZ3Dw8MKBoN1v39/f3/DY+QU1tls8NJ658O93Ji32Jvclotzc3MKh8MM/rzHuCEPCwOp5nI5TUxMkIN7lFty0bIsV5wwYWdMz8PCD0OFH4MikYgmJiYUjUbrfg84w+nc2o4T58luOS+iAGWASCSi8fFxRSKRbX8NalWldyfJut06u50Ps7k1b7H3uC0XZ2ZmdOrUqaYe6MB5bslDr9dbzL1IJKK+vj7dvn2bQtQe4oZcjEQi7AP3ODfk4cZeyCdPntTU1NSmlzfBDCbk1nacOE92y3kRl+A5rNAF3u/36+TJky2vuG92uUfhV6idrLPb+XAfN+QtOoPbcjEWi+nw4cOuuVUu6uOGPMzlcpqZmanobeL3+4t3gcLe4IZcTCaTGhkZaWVYcJgb8lDKx1muUHTa7BInOK/dubUdJ86T3X5e5LFt23Y6iE4Vi8V0+fLl4n+cZDKpsbExZbPZTddpRjfCvr4+JRKJigT1eDzaKhW2W2e38wtisZjm5uaUSCTqaifaz015Wx4zebX3uC0X4/G4crlc8RbPhdv5uuFgAZtzSx4mk0kNDw8rlUoV1ylMW1xcZCyePcAtuRiPxysGD06lUopEIgqFQrIsq7iPhDu5JQ9zuZz6+voq9omFadlslh5QBnIqt8rfv9b5RLvOkxt5T6M5cOc92PnbR252G8fFxcWWvncoFLLD4XDxdTQatYPBYPF1KpWquE1zPevsdn5BOByu+XeBGdyWtwXk1d7jtlxMJBJ2KBSyU6lU8REKhbj9s8u5LQ+np6erXrNv3BvclovlEomEa24fjq25LQ837hNDoZAdCARaGid2xsncKtjsfKLV58k7OTc3GT2gHDI8PKxr165VVdfn5+e1tLTU8u6E8/PzxYrp0tKSQqFQcV7hV6hUKlX3Orudn06ni1XtZDKp6elpjY6O8iuYYdyWt+TV3uWmXMzlcjp06FDNgXb5CnY3N+WhlM/FSCRSfJ1KpRQKhfilfw9wWy4WFL6jY7GYpqenNT4+Tm88F3NbHm7cJ7755ptV5y8wg5O5Vc/5RCvPk3d6bm4qClAAAAAAAABoKQYhBwAAAAAAQEtRgAIAAAAAAEBLUYACAAAAAABAS+1z4k0LA3lZlqV0Oq1gMLjpAJjJZFLxeFxSfnCtCxcuFJdtZDsAAAAAAABwhiMFqImJCSUSCUn5ItLk5OSmI9fH43FNT09Lyo/0PjY2Vly3ke0AAAAAAADAGW2/BC+dTle8tiyr2MNpo2Qyqbm5ueLrQCCgZDKpdDrd0HYAAAAAAADgnLYXoOLxuPr7+yum9ff3K5lMVi3r8/l04cKF4utcLldcvpHtAAAAAAAAwDltvwSvUETaKJPJ1JweCASKzy9fviy/3y+v19vQdu7fv6/79+8XX6+vryuTyejAgQPyeDz1B4+OYtu2vvvd7+oDH/iAurqaU6slF9Eo8hCmIBdhAvIQpiAXYQLyEKaoNxcdGQOqls0KSuXzY7FYccynRrYzNzenX/7lX95FdOhkd+/e1cDAQFO2RS5ip8hDmIJchAnIQ5iCXIQJyEOYYrtc9Ni2bbcxHkUiEYXD4YpCUl9fn6LRqPx+/6brTU1NaWZmRpZlNbydjVXce/fu6YMf/KDu3r2r/fv3bx3wg7ekKx/IP3/mdWnf4/U2FS63tramJ598UrlcTr29vU3Z5o5zkTzsWEbloUQudjCjcpE87FhG5aFELnYwo3KRPOxYRuWhRC52sHpzse09oPx+v8LhcNX0kZGRTdeZn58vFp8KPZwa2U5PT496enqqpu/fv7+O/0Td0mPFFfhP1IGa2dV0x7lIHnY8I/JQIhdhRi6Shx3PiDyUyEWYkYvkYcczIg8lchHb5mLbByEv9GAqSKfTGhkZkdfrlaTiXe4KYrGYfD5fsfi0sLAgr9e77XYAAAAAAABghqb0gLpz544OHjwoSbp27ZrGxsa2XD4ajWpmZkajo6NaWlpSNBotzpubm9Po6Kimp6eVTqc1MTFRsa7X61UwGNx2OwAAAAAAADDDrgpQzz77rDwej7xer6ampnTw4EGNjY3pypUreuaZZzZdz7IshUIhSZV3uZNUUUSyLEtbDVG11XYAAAAAAABghl1dgvfyyy8rGAwqlUppenpaIyMjOn78uBYXF5sVHwAAAAAAAFyurh5QW/VoGhoaUigU0qFDh5oaGAAAAAAAAPaGunpAXb58ecv5FJ8AAAAAAACwmboKUIuLi7p48eKWy2w3HwAAAAAAAJ2prgJU4c52tYpMa2treuGFFzQzM9P04AAAAAAAAOB+dRWghoaGdOjQIU1MTOjFF1+UJL366qs6deqU+vr6FA6H1d/f39JAAQAAAAAA4E51FaBu3rwpSfJ4PLp165a6u7s1Pj6uvr4+LS8v69atW1pYWGhlnAAAAAAAAHCpuu6CNzk5qf7+fsXjcfl8Pr388svK5XKamprS/v37JeV7SQEAAAAAAAAb1VWASqVSGh4e1vLyckWh6cKFCxodHdXRo0dbFR8AAAAAAABcrq4C1OzsrM6dO1c1fXJyUl//+teVyWQkSceOHWtudAAAAAAAAHC9usaAqlV8Kjhx4oQymYzGx8ebFhQAAAAAAAD2jroKUNsJBAI6ceJEMzYFAAAAAACAPaYpBSgpf5keAAAAAAAAsFHTClDcBQ8AAAAAAAC1NK0ABQAAAAAAANRSVwFqbW2t1XEAAAAAAABgj6qrADU8PKybN29KohgFAAAAAACAxtRVgJqentbRo0clSZFIpOYyhQIVAAAAAAAAUG5fvQuePXtWXq9X8XhcqVSqan48HtfKykpTgwMAAAAAAID71dUDanJyUn6/X7Ztb/kAAAAAAAAANqq7B9SJEyd04sQJff3rX9eJEyeq5t+4caOpgQEAAAAAAGBvqLsAVVAoPl25ckXpdFrDw8P6+Mc/rqGhoaYHBwAAAAAAAPdruAB1+/ZtDQ8PS5Isy9Jv//Zv6969e0okEtq/f3/TAwQAAAAAAIC71TUGVLmZmRlFo1FlMhktLy9reXlZS0tLm94dDwAAAAAAAJ2t4QLU+Pi4xsbGKqZ5vV55vd66t5FOpzU/P69YLKb5+Xnlcrktl08mk8VeVxunJ5PJ4jYLzwEAAAAAAGCOhgtQtYpFN2/e1OLiYt3bmJiY0PT0tAKBgAKBgCYnJzddNhaLSVLN4lI4HNbw8LA8Ho+mpqZkWVbdMQAAAAAAAKA9Gh4Dyu/3q7+/X6Ojo5LyPY/S6bQSiURd66fT6YrXlmUpHo9vunwgENh03vDwsLLZrCQ11AMLAAAAAAAA7dNwD6ihoSGl02n5/X4dOnRIwWBQmUxGR48erWv9eDyu/v7+imn9/f07vnyu0cv/AAAAAAAA0F4N94CS8kWfc+fO7egNNxvvKZPJ7GhbhUv0lpaWNr0M7/79+7p//37x9draWsPvBTQDuQgTkIcwBbkIE5CHMAW5CBOQh2ilhntAtcp2A5HXEgwGi+NInTp1SuPj4zWXm5ubU29vb/Hx5JNP7jJaYGfIRZiAPIQpyEWYgDyEKchFmIA8RCu1vQDl9XqrejtlMpkdXUZXPp6UZVnF8ag2mp2d1b1794qPu3fvNvxeQDOQizABeQhTkIswAXkIU5CLMAF5iFba0SV4V65ckWVZOnr0qG7cuKFsNqtjx47Vta7f71c4HK6aPjIy0lAMyWRSY2NjxUHICzaOLyVJPT096unpaWj7QCuQizABeQhTkIswAXkIU+wmF1ff/DGtfGdQg6seDRxsblzoLOwT0UoN94B69tlndebMmeKd64aGhpTNZnXx4sW61t84RlM6ndbIyEixB1QymazZi0mqvEzPsiyFQqHi63g8rkAgwIDkAAAAADrGpa/s01Off03HfuW6njr8qC5dcjoiAKit4QJUOp1WJpORbdvFaSdOnNDMzEzd24hGo5qZmVEsFlM4HFY0Gi3Om5ubKw4sLuULS4Vtl8/zer0aGRnR/Py8IpGIlpaWKrYDAAAAAHvZ6qoUPPsurdvdkqT1dY+mpvLTAcA0DV+CVxjo2+PxFKfV2/upoLz3UiAQqJi3sYjk9/vl9/srejsV+Hw++Xy+ht4bAAAAAPaClZV80ancw4fSrVvSwIBDQQHAJhouQPl8Pj3//PO6ffu2Ll68qIWFBcXjcc3Pz7ciPgAAAABADYODUleXXVGE6u6WjhxxMCgA2ETDl+CNjY1pampKIyMjWl5els/nUyKR0HPPPdeK+AAAhll988d0/c8/ptVVz/YLAwCAlhkYkCIvfb9siq1wmN5PcA7HidjKju6Cd/v2bZ07d65q+s2bN2VZlvbv37/rwAAA5rn0lX0Kfv41rdvd6jpvKxKRTp92OioAADrX6c880Jmp/F3Lfvqj6zp9utvhiNCpLn1lnyY//5ey7S6OE1FTwz2gJCkUCml2dlYvvvhicdrs7KyWl5cVj8d1586dZsUHADAEA50CAGC2Rx91OgJ0qsJxom3nSwwcJ6KWhgtQJ0+e1NLSklKplN544w2dPXtWkrS4uKiRkRE988wzCofDTQ8UAOCsrQY6BYBOxeUmMElXl739QkALcJyIeuzoErxMJlN8XrgDXi6Xk9frlSQlk8ndRwYAMMrgoOTx2LJtBjoFAInLkmGerh1d3wLsHseJqEfDuyjLsnT9+nXduXNHV65cUTgc1tramjKZjA4cOCBJSqfTTQ8UAOCsgQEpcOJB8XV3NwOdAuhcXJYME3noiAeHDAxIExwnYhsN94CanZ3V5OSkYrGY+vr6FI/HFQ6HZVmWwuGw3nzzTR06dKgVsQIAHPZ3P7yuaCz//M6tdzRw8DFnAwIAh2x1uQknXHAKPaDgpJERWwscJ2ILDRegent7tbCwUDFtaGhI586d07179zQ3N8cYUADQAQYGGGcCQOfichOYiB5QcNLDh6XnHCeilh3XyNfW1ioep06dUm9vr86fP08PKADYo2yOJQBAUr6X08kAl5vALPSAgpPKC1BALQ3vol544QV1dXWpr69PfX198nq96uvrY9wnAAAAdJS/++H14vM7t95hAHI4jgIUnPTgwfbLoLM1fAleKpVSNpvV0tKSbt++rcnJSaXTad28ebMF4QEATFJ+qQkAdLryXqFcbgITUICCk+gBhe00vIsaHx9Xb2+v/H6/4vG4pPyd8ebm5poeHAAAAGCqdWpOMAxjQMFJ9IDCdhruAZVOp3XgwAElEgnNzMzoyJEj8ng8shkYBAD2PHb1AFBCr1CYhgIUnEQPKGyn4R5Q586d0/Lysg4ePCifz6erV69qenpaiUSiFfEBAABUWX3zx3T9zz+m1VXOtuAcivIwDZfgwUkPHpS+k/l+Ri0N76Lu3LlTcZc7y7I0OTmpa9euNTUwAIB5ONmCCS59ZZ+e+vxrOvYr1/XU4Ud16ZLTEaFTra9vvwzQThSg4KQ//Vap6MT3M2ppeBcVCoWqpl27dk0TExNNCQgAAGAzq6tS8Oy7tG53S5LW1z2amspPB9qNojxM00WnEzhkdVV69Xp38TXfz6il4QJUKpXSlStXiq+ff/55jY+Pa2xsrKmBAQDMw8kWnLaykj+oLffwoXTrlkMBoaPRAwqmYQwoOGVlpXpcPL6fsVHDBairV6+qt7dXL774ogYHB3Xt2jWlUilFo9FWxAcAAFA0OCh1dVVWQru7pSNHHAoIHY2iPEzj8ZCUcMbgYHX+8f2MjeoqQL366qsVD4/Ho1u3bsmyLIVCId2+fVvPP/98q2MFAAAdbmBAirz0/bIptsLh/HSg3ShAwTSMAQWnDAxIH/t7pdvgdXfz/Yxq++pZyO/3q6+vT319fVXzgsGgMpmM7t27p5deeqnpAQIAzMHJFkxw+jMPdGaqR5L00x9d1+nT3dusAbQGl+DBNFyCByf95N+2df3/zj+/c+sdDRx8zNF4YJ66ClDRaFQnTpzYchnuggcAANrt0UedjgCdjKI8TEMPKJhiYIAdJKrVtYuqVXxaW1vT2tqavvvd72ptbU2RSKTpwQEAzMLJFgCUsE+Ead55x+kIAGBzDdfIX3jhBXV1dRUvyevt7VVfX5/S6XQr4gMAANgUA+7CSVyCBxNc+krpopbfXtinS5ccDAYdrbwoT4EetdR1CV65VCqlbDarpaUl3b59W5OTk0qn07p582bd20in04rFYrIsS+l0WsFgUF6vd9Plk8mkJicnlUgkdrUdAMDucDAB0zDeCZxEAQpOW12VgmffVXxt2x5NTUnHjzP4M5xl2xJf0dio4QLU+Pi4ent75ff7derUKU1OTsqyLJ06dUrPPPNMXduYmJgoFpPS6bQmJycVjUZrLlsoMCWTyV1tB3C71Td/TCvfGdTgqkcDB52OBgDMQAEKTqIoD6etrEjr65U7wocPpVu3KECh/cq/k9k/opaGC1DpdFoHDhxQIpHQzMyMjhw5Ik8DR38bL9WzLEvxeHzT5QOBQFO2A7jZpa/sU/Dzr2nd7lbXeVuRiHT6tNNRoRNxMAEAJfSAgtMGB6WuLruiCNXdLR054mBQ6Fjlx4nr6xL3qMVGDRegzp07p0AgoIMHD+rgwYNaXFxUPB7XyZMn61o/Ho+rv7+/Ylp/f7+SyaR8Pl/dcTSynfv37+v+/fvF12tra3W/D9BMO8nFQtfqdTt/YLG+Ttdq7A77RJiiGblIDyjs1m7ykKI8mmknuTgwIEVe+r7OTPVIyo+LFw57OEbEjjXrOJH9I2rZ0Y06b9y4URzzKZfL6fDhw+rt7a1r3VwuV3N6JpNpKIZGtjM3N6fe3t7i48knn2zovYBm2UkubtW1GtiJ3ewTOZhAMzXj+5kCFHZrN3lIDyg0005z8fRnHhSf/0//4wN6yWNXmnXuzP4RtTRcgHr22Wd15syZ4uVuQ0NDymazunjx4q4C2ayg1IztzM7O6t69e8XH3bt3m/JeQKN2kouFrtXl6FqN3WCfCFOQizDBbvLQtqmAonmasU98z3taEBg6SrO+m/nRErXsaAyoTCajF154oTjtxIkTOnDggM6cObPt+l6vt6qXUiaTafjudY1sp6enRz09PQ1tH2iFneTixq7VEl2rsTvsE2GKZuQiPaCwW7vJQ06w0Ex8P8MEzdon0gMKtTTcA2p8fFySKgYeb6T3k9/vrzl9ZGSkoTiatR3ADcq7Vj/9kXW6VsMxnGwBQEn5CdbqKtVQACjgmBG1NFyA8vl8ev7557W0tKSLFy/qE5/4hILBoGZnZ+ta37KsitfpdFojIyPFnkvJZLLqDncF5ZfXbbcdYK/ihzEAKKEHFJz0//1ZKQGfOvyoLl1yMBhA7BNhDnpAoZaGL8EbGxuTZVmKxWJaXl6Wz+dTKBTS0NBQ3duIRqOamZnR6OiolpaWFI1Gi/Pm5uY0Ojqq6elpSfm73S0uLlbMCwQC224H2KvYmcNJ/JoF03CyBaesrkqvXi/dZJy71AJACceMqKXhApQkHTp0SOfOnauYdufOHR08eLCu9S3LUigUkqRiMalgYxHJ7/fL7/cXl693O8BeRQEKAEooQMEpKyvVg5AX7lJLAQpAp+OcBbXUVYC6ceOGFhYWtlwmHo9raWmpKUEB2Bw7cziJX7MAIG9wUPJ47IoiFHepBYA8jhlRS10FKK/Xq2g0Kp/Pt+kyqVSqaUEB2Bw7cwAAnDcwIH38Yw/16vX84XR3N3ephTPKjw3pFQoncRc8bKeuAtShQ4cUjUa3HOfpxo0bTQsKwObYmcNJFEBhGk624KSf/Nu2Xr2ef37n1jsaOPiYswGhI1GAgok4ZkQtdd8Fb7tBxhsZhBzAzlGAAoASTrbgpPITrIEBzrbgDE70YQp6QGE7dRegAJiBnTmcVH5gwQEvTEABCkCn4/sYpig/T9l4kwZAogAFuA4HGTAFuQgTUIAC0On4PoYpygtQ/GiOWihAAS7DQQZMQS4C6HTsB2EC8hCmoKc8ttO0AtSrr77arE0B2AK/JsBJHFjANO+843QEQB77RDiF3IMp6AGF7dR1F7yRkRHdu3dv0/mZTEYjIyM6duxY0wIDUBs7c5iCA1445dJXSocvf/CH3bp0STp92sGAAOX3iVwRCidwFzyYovw85fXXPXrykHOxwEx1FaD8fr9GR0fl9XoVDoc1Ojoqn89XnJ9IJHT79u2WBQmgZH2dIws4hx5QcNrqqhQ8+66yKR5NTUnHj0sDA46FBbBPhGPIPZjiL1ZK5ylP/+y7FYnwAxEq1VWAOn/+fPH5jRs39Nxzz1XMHxsb06lTp5obGYCaOMaAKTjghRNWVqoL8Q8fSrduUYCCs9gnwinkHkywuir98f/bXXy9vs4PRKjW8BhQb7zxRtW0mzdvKplMNiUgAFvjEjw4iR5QcNrgoNTVVZl83d3SkSMOBYSOxj4RJiD3YIKVFWnjhciFH4iAgrp6QJU7deqURkZGNDo6KklKp9OKx+MKhUJNDw5ANQpQMAUHvHDCwIAUeen7OjPVI0nyeGyFwx5+XYXj2CfCKeQeTDA4KOWv1SgVofiBCBs13ANqaGhIy8vL8vl8sm1bQ0NDunr1atVleQBagwIUnMSv/TDB6c88KD7/uf/hIeNLwAjsE+EUBiGHCQYGpJGR0olKV5etcJjL71Cp4QKUJF25ckWjo6N6+eWXderUKXnY0wFt89Zb+WusAadxsgUTPP640xEAeewT4RRyD6Y4+FQpGf/gd/+GH4jabHVVun7d7HPFhgtQzz77rM6cOaN4PC4p3yMqm83q4sWLTQ8OQLXXX+/SU09Jly45HQk6ET2gAKCEfSJMQO7BFOW5eOCAc3F0ol//demDH5SOHZPR54oNF6DS6bQymYzssuw6ceKEZmZmmhoYgJLV1cpehuvr0tSU2dVt7H0c8AJACftEOIXcgynKhwp5+NC5OJzgZO+j1VXpF36htC8w+Vyx4QLU+Pi4JFVcdkfvJ6C1Vm5VX+bKXSXgtI2FUcAJjAIAU1AEgFPIPZjirbdKzx882Hy5epl4SVmtmC5dyvc6akXvo8L7LS1t/rf4xjeq9wOmnis2XIDy+Xx6/vnntbS0pIsXL+oTn/iEgsGgZmdnWxEfAEmDR6qPLLirBJxw809LXxt/5+ijxnbvReeg/gQnceIPEzAIOUxw6ZJ0dbG7+Pp//fV9DRWONhZ2tivq1FucWlqS/u2/zf+7W7ViWl2VgsFS76+NvY9WV6WFhfyj0UJa+ft9+MO1/xaXLkk///PV6zbzXHFpSfrCF6SXXtp9MXBfoyuMjY3JsizFYrHi3fBCoZCGhoZ2FwmATQ0MVB7hdneLu0qg7VZXpVeulg4s1tc9mpqSjh8nF+EcTrbgJMaAggnIPTitUIQp/1no8sIjWohKoZB07tzW61+6VCridHVJ589Lzz9fWdQJBqXvf1/KZqVvflP6/d/PT/d4Su+xuiqtrEiDg/lj009/Wvra10rv8w/+gfSpT+WfP/10/t9vfKP0utbxbGGb73lPdaEpGJR+67eq71L+8GE+xmvX8uds5ebnq2OtFcfSUuX7FRQKXMeP518Hg9X7gFrnihv/NhunSZXzC/NeekmKRkvb+dznpAsXtOMB5hsuQN28eVNHjx7VuQ1Z9Oqrr+rYsWM7iwJA3fr71/Wnf9rFCT/abmVFsu3Ks/1C917yEU6hAAVTUASAU8g9OGV1NV84+bM/qy6USPncnJ6W7t2Txsbyl+j9yZ9ITzwhffKTpULL5GTl+EXT09XbWl+XPvvZzd9jaUmKxfKvPZ58oaS8+CTli1a///ubt2djcSiRyG+7sM2N/9fW16Xf+Z3a2zp5svb0Qqxf/3rtv5mUL5RtFefDh/mi0LvfXXsbZ87kC1TXr+cLZ5cuSZFIPv5Cge+v/zrfM6xQxJNK7fz4x/Pr1tq32Hb+89rpD9B1F6DW1tYkSZcvX9bhw4eLg5BnMhnlcjnNzMxoqRn92gBs6ZFHONmHMwYHJY/HrihCcSkoAORRBIBTyD044dKlysLRVv7Nv8k/yn32s1IgkC8aNUN5Lx3blv79v298G9PT0m/8Ru2C2mbt/M3fbPx9ymOtZaviU8Ev/dLm88LhUsFpo1oFvo29eV99dev3tm3p135NeuGF7ePcqO4xoFKpVPFyu97eXnm9Xnm9XlmWpeHhYQ0PDzf+7gAatr7Oz/1wxsCA9Inx0i1NurttLgWFIyrHO+HMC2agCACnkHtot9XVfC+b3eZes4pPzfStb23eM8lNWr1f+PKXdzYeVN09oIaGhpRIJBSPx3XixInG36lMOp1WLBaTZVlKp9MKBoPyer0NL5tMJiXlB0ZPp9PK5XLy+Xy7ig0w3V7YIcK9PvRT63rlav558k/e0Yd8jzkbEDoS+0GYgjGgYALyEO22suJ0BHDaTofhaGgMqN7e3mLxqXBJnsfjkW3bmpyc1OXLl+vazsTEhBKJhKR8gWlyclLRTfqhbbVsOBxWJBKRJPn9/k23AewlHFjASeX598QTJCOcwR2fYCK+n+GU8kvjyUO0Q2HQanS2nQzDUfcleAUvvPCCurq61NfXp76+PvX29qqvr0/pdLqu9TcuZ1mW4vH4jpYdHh5WNptVNpvV4uLipr2ogL2EX/5hCg5y4ZTy/SAFKJiCfSKcQg8oAE749rcbX6fhAlQqlVI2m9Urr7yil19+Wevr61pZWdHs7Gxd68fjcfX391dM6+/vL15O1+iyhbGogE5BAQpO4ldWmID9IEzEPhFOoQCFdvvGN5yOACb4j/+x8XUaugRPksbHx9Xb2yu/369Tp05pcnJSlmXp1KlTeuaZZ7ZdP5fL1ZyeyWQaXjaXyyn2w5HLlpaWNDU1Jcuyqpa/f/++7t+/X3xduHwQaLdm5CInXtit3eRhef6VF6OAndhpLtIDCs20m30iJ/5opp3mInmIZuLcGfV6//sbX6fhHlDpdFoHDhzQnTt3NDMzoyNHjmhwcFDZbLbxdy+zWbFpq2WDwaACgYACgYBOnTql8fHxmsvPzc2pt7e3+HjyySd3FSuwU83IRQpQ2K3d5CEHuWimneYiY0ChmZp1nMg+EbvVjH0isFv15OHTTzsQGIzzcz/X+DoNF6DOnTun5eVlHTx4UD6fT1evXtX09HRxoPDteL3eqt5OmUym5mV02y1bPkZU4S55tcaimp2d1b1794qPu3fv1hUr0GzNyEUOMrBbu8lDClBopp3mIj2g0EzsE2GKneYieYhm4twZ9XjuucbvgCft4BI8STp06FDxuWVZsixLN2/e1NGjR7dd1+/3KxwOV00fGRlpaNlkMqmxsbGqnlcbx4ySpJ6eHvX09GwbG9BqzchFekBht3aTh5WX4DUpIHSsneYi+0E00272iZz4o5l2movkIZqpnjxcWWlTMDCSxyN9/vM7W7fhHlA3b97U2bNndfz48eJjdHRUY2Njda2/cYymdDqtkZGRYq+mZDJZ7MW01bKWZSkUChXnxeNxBQIBBiTHnseBBZxUnn+vv07XEziDAhRMUXnizz4RzqAAhXYbHNyqB/LWSfjpT9fXe3m7ZT75SekXfkHq2lDR6O426xLBQnxdXc3vtd2K7f3zfy5dvy7dvSv9i39Re7n5+Z31fpJ20APq2LFjxbGXykWj0bq3EY1GNTMzo9HRUS0tLVWsOzc3p9HRUU1PT2+5rNfr1cjIiObn5+X1epVKpRqKAXArTrzgpD/789I33X//0+9WJCKdPu1gQOhIXIIHU3DiDxOQh2i3gQEpFJJ+eMpe1NVl6z/84s/pnR88Jj39f+jg4Xfrrbekxx+X3npLOnIkv+5P/mT1ugXd3VLhIqipKenhw3zx5pd+STp5snI7Un47t25Vv8fSkvRHfyR99KPSE09Iv/d70ne+Ix08KH3mM7X/r3R3S3Nz0oMH+ULMRh5Pfr1CjB/6UP5OcO9/f348pH/5L6Wvfa20/Kc+JX3pS/n4jhyRXnml1KaNCm183/uk558vtdu2q2P95Celf/Wv8u0qtP3OHennf776GOkLX8i3OZeT3nhDOn++tO3z56V/+A+lb34zv/xHPlJZWPrSlySvV5qZyW+3sM5zz9X+7Orhse3GdlMnT57UwsJC1fR79+6pt7d355G00dramnp7e3Xv3j3t379/64UfvCUtvCf//OT3pH2Ptz5AGKGhPGn1ezx4S55H8rnX1WXr4UPOuDqFSXm4uip98IN2xa/83d35L7yd/goC9zApF9/4zlv6kSfy+8Qzn/mBLlx6pCXxwDwm5aEkfep//oH+99/I59/rf/m2nnjysZbEBPOYlIu3V96W9eP53Aue+YHCF9gndgqn8/DFF0vFie5uKfy/3dfp97w7P3Obc+eN687NSaOjlcWl1dVS8aZZx5rXr0vHjlVP//KXpUCg9D6f/nRlMSkQyC+zXTzlha/R0er5hTYVCmYbC2fly2wsWhUKQOfO1X7vS5dKyxaKZBt/KN7J37SederNxYZ7QE1NTVWN97S2tqYLFy7oud2UwgDUhV+24JSVlepLTB4+zH8hUYBCO9ETFKag5wlMQB7CKc89l+91UyxOvP+BVN1Xpb51axxLDgw0/xhzcDBfyCk/lujuriw+SdJXvyp97nPVxaTt4hkdrV14KqinTeXLnD4tHT9eX9GonmV38jdt5ufQcAEqnU5rfHxcnrI+77Zty+PxUIAC2oAxJuCU/PX+1T2gjhxxMCh0pPX1Ug7+1esera5SBIUzyveHnPjDKRSg4KSK4sSDXazbJgMDUiRS3VOoVhzbFZPapZG/kxN/00Y0PAh5KBTS4uKiMplMxeP8+fOtiA9ADaurTkeATjQwIP30R0sXrXd12Zt+YQOtVP6r5R/84T499VS+2znQbpz4wwTkIdCY06fzQ0hcv57/l/FM26fhAlQgENDY2Jh6e3uLD6/Xq6mpqVbEB6AGTrbglB8fLB3ZXnvlb/jChiP+6q8qe4Kur+d/yaQ4j3Zb586gMAAFKKBxAwPSxz7GD6nt1vAleIcPH9bs7KxGN/RFu3z5si5fvty0wACUrK7WPtk6fpydJtqrvOfJj/wIR7lwRvp29Yk+45HBCbdSpVz8yM9wZ1A4g6ITALdouAAVDoeVy+W0uLhYnJbL5XT79u2mBgagZOUWJ1swQ/lBbq1byALt8NQHq8+2GI8M7ba6Ki0tlS4mWF/38OMQHEEPKABu0XABKhQKaWxsrGr6tWvXmhIQgGqDRzjZghkqC1BcbgJnvO99lfvErQYQBVplZUWSuDMonFfeO/n1b3NjBgDmangMqFrFJ0lVl+QBaJ6BAU62YIbyg1x6QMEp5Xn4sz/7kAFE4YjBQUmq/n7mxyG0W/mPQ69c5cYMAMxVVw+oK1euyO/3a//+/bp48aJyuVzVMouLi3rllVeaHR+AGu7cofgEZ5TfcpwCFJxSXoA60G+zP4QjBgYkn29dyWS3pMKdQT3kI9ru299hrFAA7lBXAerll1+W1+vVsWPHdPXqVaXTaVmWVZyfy+WUSCRaFiSAShxMwCn0gIIJGIsMpjj4lK1kMv988Q//RsfGH3U2IHSk115jrFAA7lBXAerq1avF57OzsxoaGqpa5saNG82LCgBgpPKLTR6ub7oY0FIUQmGK8mLoew8w+jOc8eSTjBUKwB0aHgPK46k96Gw2m911MAAAs3HiDxOU5+GDB87FAVTuE7kxA5zxvh9lrFAA7lD3XfDW1tYkSZcvX9bhw4dl//Ann0wmo1wup5mZGS0tLbUmSgCAEbj0CSbgpB+mKN8nUgyFU8rHZ/zpjz7Ub/12N8UnAEaquwCVSqU0MTGhdDqtUChUNX9qaqqpgQEAzFN+4r/OJXhwCIVQmIJchAnK87CvjxszADBX3QWooaEhJRIJxeNxnThxopUxAQAMVXmyRc8TOGN9nbsxwgxvv116Tg8oOIVCKAC3aGgMqN7eXvX19enKlSuS8pflnT17VsePH9fNmzdbER8AwCCMAQUTMAYUTHDpknTt1e7i69/5ve4tlgZah0tBAbhFw4OQh0Ih+f1+SdLY2JiWl5c1PT2ty5cvNz04AIBZ+JUVJigvQL39jnNxoHOtrkrBoCSVeuP96pcf0eqqYyGhg5V/N3/ve/ROBmCuhgtQgUBA+/fv14ULF5RIJBSNRjU2NqbR0dFWxAcAMAgFKJjg//wPpZ4mN2926dIlB4NBR1pZqR4Hb33do1u3nIkHne3/KtsnfuOb7BMBmKvhAlQqldLJkyc1NTWlSCSigwcP6saNGwqHw62ID0ANtr39MkArcAkenLa6Ks2FHimb4tHUlOh5grYaHJS6NhxFd3XZOnLEmXjQuVZXpV9hnwjAJRouQJ0/f16zs7PKZrM6c+aMXnvtNWWzWc3MzLQiPgCSLn2l8n4BFy86FAg6Xnnx86//2rk40LnyPU8qLzF5+FD0PEFbDQxIkYgklXaKn332AXcfQ9uxTwTgJnUVoGZnZ/Xiiy8WXw8NDam3t1eStL6+rvPnz2t+fr41EQIdbnVVCp59V8W0s2f5ZQvOWLlVOsj9p5/voZs/2m5wUOryVHYD7e4WPU/QdqdPSz/1d0rdQo99nG6haL98bzz2iQDcoa4C1OLiop577jlJ0oULF3T8+HGdPXtWd+7c0aFDh3T16lXdoswOtAS/bMEUL7wg/Zf/UvrasG26+aP9Bgakz322/DZPtubmRM8TOKT0/czdx+CEgQHpn27YJ4bD7BMBmKmuAlThrneSNDk5qd7eXoVCIR08eLA4PRAIND04APyyBTOsrkr5K60phsJ5f+9ny3uaePT886I3Hhzx/R+UnnNZMpxSvk/8737C1unTDgYDAFuoqwDl8VSecPT392v//v1bLgOgOQYGpC//6vcrpv27f8cvW2ivlZXag993dVEMRfu9/u3K1+vrojceHPHmm6Xnv/CLXJYMZ9y/X3ruaXiEXwBon33bL1Ktr69vV2+aTqcVi8VkWZbS6bSCwaC8Xm/DyzayHcDNAs881Of/l9Lrf/SPnIsFnalwx6fK247bCoU8FEPRdnfvVp9hFXrjOZWPq6v5Qu3gYP0x7GSdZsVVPl3aepn3vEf63vdaG6fbrK5K3/iG9MYbpR9gbdujyUnpQx+SRkdLyxSKVAcOSE8/nX9e+Ht/+9vSf/pP0s/8TH6dwrY3fh5LS5XLlW+7sN3ybUnS7/6u9MQT0ic/mX9dvvxjj0l/8RfV25NK8378x6XHH6/OkY3b2timgYHq/Npq+cL8W7ekv/mbfLxPPFGK59Ah6fbtytjK4/7d3823/cMflr71Lek//2fp6FEpl5Pe/W6p/LTlzp38sidP5pepld/lf4unnzYz5zfm1jf+n9I+8fXXpX/8j6Vjx/LPEwlpeDg/TSqtl83m/95er/RHfyS96135v9Xt2/lpH/yg9MYb0t/6W/nnN2/m13/rLel978sv/6M/mv8R6tAhaXk5/ygsv7go3b0rPfKI9JGPSD/1U6X4s1kplco/P3y48jPKZqU//uP8uj/xE9Lf//v5vM7lpI9+tPS5HjlSmat37+bf/7/9N+kHP8jnyPh4KS5Jeu97822SpJER6dFH8/nz4EH++eOP5+ORSvGVr9PTU/n3ee016b/+V+n97y/97d71rvw6731vvjDY05N/eL35v+ETT0i9vfkekz09+W2/9Vb+M1lby7e5v79yXiGuI0fMzUmgXh7b3v6G7v39/Tpc+N+ofOHHsqyKZZLJpB7WeU/u4eFhJRKJ4rZmZmYUjUYbXraR7ZRbW1tTb2+v7t27V9WTq8qDt6SF9+Sfn/yetO/xepqIPaChPGnyeywtSb/6q1IyKb3zjvTgwQN95zulevHwcP6LivEm9o53vzv/uf6zf1Y6CZGczUNJ+upXpV/7tdJBUDZrq3AZ3mOPPVR/f3dLYoJzDhyQfvEXpU9/unK6SfvEtXsPtfbd6tx74on8Jcrtlv+/UXrt9eZPapu9TrPi2ji93HbLtCLOWkzeJ37hC/mT3a08+mg+Vxvx6KP5dm/8zL7/fentt0vTHnkkf4LdLM3e3k7avhPNjluqHfvAgPSv/7U5+8RLl6TJydq9ktEZLl5U8TJLp/eJVTh37lj15kndPaAOHTpU83lBqlAm3kY6na54bVmW4vF4w8s2sp1GlJ9s5fVI3/vhe8307Hr7MM9mJ1tO+fSnpa99bePUyv+qP6y7Yo+5dUu6fFn61Kfy+yKnHTlS+gWwpPRr/9tvd1ecFGFvWF2V/sk/kb70JTPG96q9T6xdZfr2t2tObrtcLv9o9TqNquc9tlumHXEWmLZPfOop6S//sr5ld1KAeeed6vVq/a2bXXRp9vbaUXySmh+3VDt2k/aJq6vSmTPOxgDnTU5Kx4/TEwruVFcBKhqNamxsbMtlrl27VtcbxuNx9ff3V0zr7+9XMpmUz+ere9nl5eW6t1Mvyyp18S3ZJ+mHBbfcjjYLw5l0YLG0VOtEC53ma1+TPve5yl/92+2rX61VfEInSaXyeeBkcZ59IiRz9on1Fp+wN5mwTyxcGojOZtvSN78pTUw4HQnQuLoKUNsVn+pdRpJym/xslslkGlq2ke3cv39f98tG57t3756kfDexgt/8zVrFJ3SSVEp66aXS+EqF/KjjKtW6bZeLi4tNeyu43LVr+XEAnMhDSVpYaNrbwcViMemZZ/LP2SfCSewTYQKn94n0OkbB22/nx4xyap+4qQdvSYU8XVuT9tU3RA/cr+5ctNssFArZfr+/YpplWXY0Gm1o2Ua288UvftGWxIPHjh53795tQuaTizx29yAPeZjyIBd5mPAgD3mY8iAXeZjwIA95mPLYLhfrGoS8mSKRiMLhcHHwcCl/V71oNCq/31/3sul0uu7tbKzirq+vK5PJ6MCBA/J4PBXLrq2t6cknn9Tdu3dbNpBbO9CO3bNtW9/97nf1gQ98QF1dzbmnbb25yOdnlk7NQ4nP0DSdmot8fmbp1DyU+AxN06m5yOdnlk7NQ4nP0DRuyMW6ByFvFr/fr3A4XDV9ZGSkoWUty6p7Oz09PerpqRxA3Ov1bhnn/v37XZ18BbRjd3p7e5u6vUZzkc/PLJ2ahxKfoWk6NRf5/MzSqXko8RmaplNzkc/PLJ2ahxKfoWlMzsW2F6Asy6p4nU6nNTIyUkzqZDIpr9cry7K2XHbjf4KN2wEAAAAAAIAZ2l6AkvJ31ZuZmdHo6KiWlpYUjUaL8+bm5jQ6Oqrp6eltl91qHgAAAAAAAMzgSAHKsiyFQiFJUiAQqJi3sYi01bJbzdupnp4effGLX6zqdug2tMPd9kq7aYf77ZW20w532yvtph3ut1faTjvcba+0m3a4315pO+1on7YPQg4AAAAAAIDO0pyh8gEAAAAAAIBNUIACAAAAAABAS1GAAgAAAAAAQEs5Mgi5idLptGKxmCzLUjqdVjAYlNfrdTqsmpLJpOLxuCRpaWlJFy5cKMa6VTtMbuPMzIxmZ2dd345mcFP7yEVz27FbbmobeWhuO5rBTe0jF81tx265qW3kobntaAY3tY9cNLcdu+WmtpGHhrXDhm3btu3z+YrPU6mUHQgEHIxma6FQqOJ5eexbtcPUNiYSCVuSnc1mi9Pc2I5mcVP7yEUz29EMbmobeWhmO5rFTe0jF81sRzO4qW3koZntaBY3tY9cNLMdzeCmtpGHZrWDApSd/yDKPxjbtm2v1+tQNFtLJBIVsaVSKVuSnUqltmyHyW2MRqO2ZVnF/0RubUczuKl95KK57dgtN7WNPDS3Hc3gpvaRi+a2Y7fc1Dby0Nx2NIOb2kcumtuO3XJT28hD89rBGFCS4vG4+vv7K6b19/crmUw6FNHmfD6fLly4UHydy+Uk5ePdqh2mtjEWiykQCFRMc2M7msVN7SMXzWxHM7ipbeShme1oFje1j1w0sx3N4Ka2kYdmtqNZ3NQ+ctHMdjSDm9pGHprXDgpQKiXiRplMpr2B1Kk86S5fviy/3y+v17tlO0xsYy6Xq3n9qdva0Uxuax+5WHue27mtbeRh7Xl7gdvaRy7Wnud2bmsbeVh73l7gtvaRi7XnuZ3b2kYe1p7nFApQW9jsAzNFLpdTLBZTNBrddrmdzGu1hYUF+f3+upc3tR3tYHr7yMX65rmd6W0jD+ubtxeY3j5ysb55bmd628jD+ubtBaa3j1ysb57bmd428rC+ea1GAUqS1+utqgJmMhljRrnfzMzMjBYXF4txbtUO09oYj8d18uTJmvPc1I5mc2v7yMXKeW7n1raRh5Xz9gK3to9crJzndm5tG3lYOW8vcGv7yMXKeW7n1raRh5XznEIBStq0kjgyMtLmSOo3Pz+vmZkZWZalXC6nXC63ZTtMbOPCwoIikYgikYjS6bTm5uaUTCZd145mcmP7yMXqeW7nxraRh9Xz9gI3to9crJ7ndm5sG3lYPW8vcGP7yMXqeW7nxraRh9XznLLPsXc2iGVZFa/T6bRGRkaMreLGYjH5fL7if6CFhQUFg8GqeMvbsdU8J2z8zzA1NaWpqamqz0Iyux3NRi62H7lYjTxsP/KwNnKx/cjFauRh+5GHtZGL7UcuViMP229P5aGj9+AzSCqVsqenp+1oNGpPT08Xb2tomsKtI8sf3g23ltysHSa2MZvN2qFQyJZkB4NBO5FI2LbtvnY0k1vaRy6a2Y5mcUvbyEMz29FMbmkfuWhmO5rFLW0jD81sRzO5pX3kopntaBa3tI08NK8dHtu27RbXuAAAAAAAANDBGAMKAAAAAAAALUUBCgAAAAAAAC1FAQoAAAAAAAAtRQEKAAAAAAAALUUBCgAAAAAAAC1FAQoAAAAAAAAtRQEKAAAAAAAALUUBykDj4+M6fPiwpqamNDw8LI/Ho6mpKU1MTMjj8SiXy2l8fFyxWMzpULHHkYswAXkIU5CLMAF5CFOQizABeegyNowTDAaLz0OhkO31eitep1Ipe3Fx0c5msy2PJZFINP19otGoHQ6Hm7pNtAa5CBOQhzAFuQgTkIcwBbkIE5CH7kIPKANNTU1tOi8YDKq/v19+v19er7elceRyOU1MTDR9u5cvX5ZlWU3fLpqPXIQJyEOYglyECchDmIJchAnIQ3ehAGUgn8+36Tyv16t0Oq2JiQlFIhFJUjwe1/DwsCKRiGZmZnT48GFFIhHF43FNTEyor69PyWSyuI14PK75+XmNj49X/IedmZlRJBLR+Pi44vG44vG40um05ubmiuvXWjcSiRTff3x8XH19fcXYakkmkxoZGdnV3wjtQS7CBOQhTEEuwgTkIUxBLsIE5KHLON0FC1vb2I2wwOfz2aFQqPjasix7enratm3bXlxctCXZiUTCtm3bnp6eLnZNTKVSxeVs27a9Xq8djUbtRCJhBwIB27ZtO5vN2tFo1LZt25ZU7Ea42brBYNCWVIwnGo3akuxUKlURcyKRsKenp23LsuxwOFyMD+5ALsIE5CFMQS7CBOQhTEEuwgTkofn2tafMhWbb2A3P6/VqdHRUkooV0kI1+PDhw4pGo5KkWCymdDqt+fl5SdLs7Kwsy5JlWYrFYopEIgoGgwoEAlXvudm64XBYkUikuE4gEJBlWYrH4woGg8X1fT6f0um0crlcxXS4G7kIE5CHMAW5CBOQhzAFuQgTkIfmoADVYVKplMbHx2smcTgc1tTUlMLhsK5du1Z1nexW62602XWqly9f3vI6XXQOchEmIA9hCnIRJiAPYQpyESYgD5uPMaA6jNfrLVZ0C5LJZLGymkqlJOWvaS3IZDJbrltLJpOp+R9pz13Dih0jF2EC8hCmIBdhAvIQpiAXYQLysPkoQBnuzTffrDk9l8tt+XrjtMJ/hFOnTikejxcHOovFYspkMlpeXlYymZRlWQqFQkqn01Xb2WzdgsI6uVxOuVxOfr+/Zjxer1fxeLxmzDAXuQgTkIcwBbkIE5CHMAW5CBOQhy7g9CBU2FwikbAty7Il2eFwuGK61+u1/X6/nc1miwOnBQIBO5vN2qFQqDiwWTabtf1+v+31eosDlxUGZ/N6vcXtLi4u2n6/345Go/b09HRx2WAwaPt8PntxcXHTdW3bLr5/KBSyg8Fg1SBqBcFgsDhwG9yDXIQJyEOYglyECchDmIJchAnIQ3fw2LZtt6fUhb3M4/EolUptev0q0C7kIkxAHsIU5CJMQB7CFOQiTNDJecgleGiaPdMtEK5HLsIE5CFMQS7CBOQhTEEuwgSdmocUoLBrhetaw+Fwx/5HghnIRZiAPIQpyEWYgDyEKchFmKDT85BL8AAAAAAAANBS9IACAAAAAABAS1GAAgAAAAAAQEtRgAIAAAAAAEBLUYACAAAAAABAS1GAAgAAAAAAQEtRgAIAAAAAAEBLUYACAAAAAABAS1GAAgAAAAAAQEv9//CLQpNgCLOGAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x228.571 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, len(RESULT_DIRS), figsize=(12, 16/len(RESULT_DIRS)), sharex=True, sharey=True)\n",
    "for result_dir, ax in zip(RESULT_DIRS, axes):\n",
    "    lbda = float(result_dir.split('=')[-1])\n",
    "    with open(os.path.join(BASE_DIR, result_dir, 'results.pickle'), 'rb') as f:\n",
    "        results = pickle.load(f)\n",
    "    erasure_probs = results['erasure_probs']\n",
    "    ax.axvline(results['train_dataset'].leaking_subbytes_cycles[0], color='orange')\n",
    "    ax.plot(lbda * erasure_probs.squeeze(), color='blue', marker='.')\n",
    "    ax.set_title(f'$\\lambda={lbda}$')\n",
    "    ax.set_xlabel('Timestep $t$')\n",
    "axes[0].set_ylabel('Estimated leakage of $X_t$')\n",
    "axes[0].set_ylim(0, 0.2)\n",
    "fig.tight_layout()\n",
    "fig.savefig(os.path.join(BASE_DIR, 'sweep.pdf'))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
