{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import project_path\n",
    "from collections.abc import Callable\n",
    "from itertools import accumulate\n",
    "from functools import partial\n",
    "import functools\n",
    "import time\n",
    "import typing\n",
    "\n",
    "import os\n",
    "# change environment variable\n",
    "os.environ['XLA_PYTHON_CLIENT_MEM_FRACTION'] = '0.8'\n",
    "\n",
    "import jax\n",
    "# make sure that jax uses the second GPU only\n",
    "# jax.default_device(jax.devices()[1])\n",
    "jax.config.update(\"jax_default_device\", jax.devices()[1]) \n",
    "from jax import random\n",
    "from jax import grad, vmap, pmap, jacfwd, value_and_grad, jit, vjp\n",
    "import jax.numpy as jnp                # JAX NumPy\n",
    "from jax.nn import log_softmax, logsumexp, softmax\n",
    "from jax.tree_util import tree_map, tree_leaves, tree_flatten, tree_unflatten\n",
    "from jax.lax import pmean, psum, top_k, stop_gradient\n",
    "\n",
    "import flax\n",
    "from flax import linen as nn           # the linen api\n",
    "from flax.training.train_state import TrainState  # useful dataclass to keep train state\n",
    "\n",
    "import numpy as np                     # ordinary numpy\n",
    "import optax                           # optimizers\n",
    "import tensorflow as tf\n",
    "tf.config.experimental.set_visible_devices([], 'gpu')\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "from networks.vgg import VGG\n",
    "from networks.mlp import MLP, ID\n",
    "from models.ssl_base import ssl_agent, supervised_agent\n",
    "\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoYAAAJICAYAAAD8aCW9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAC4jAAAuIwF4pT92AAA9YUlEQVR4nO3deXRUVaL3/V8FMjAYIEAAgURmhAAaGy7oZRCk6evARQRRVEBB1PRS38aHB9QXGhTlguijgrS+0kCatRqhFaSvA7cb6AAPg4pAE9IQDTIbSEgICUkqCaTeP3JyTJGaq5JKUt/PWqy1T2rvXbsCh/Ors88+x2Kz2WwCAABAyAsL9gAAAABQNxAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAEPjYA8AwWW1WnXixAlzu1u3boqKigriiAAAQLAQDEPciRMnlJCQYG4fPXpUffv2DeKIAABAsDCVDAAAAEkEQwAAABgIhgAAAJBEMAQAAICBYAgAAABJBEMAAAAYCIYAAACQRDAEAACAgWAIAAAASQRDAAAAGAiGAAAAkEQwBAAAgIFgCAAAAEkEQwAAABgIhgAAAJBEMAQAAICBYAgAAABJBEMAAAAYCIYAAACQRDAEAACAgWAIAAAASQRDAAAAGAiGAAAAkEQwBAAAgIFgCAAAAEkEQwAAABgIhgAAAJBEMAQAAICBYAgAAABJBEMAAAAYCIYAAACQRDAEAACAgWAIAAAASQRDAAAAGAiGTsyaNUsWi8X8c8stt3jVfvv27ZoyZYp69uypZs2aKSYmRv3799fs2bN1/Pjxmhk0AACAHxoHewB10bfffqv33nvPp7b5+fmaOXOmNmzYYPfzoqIiXb58WampqXrvvfe0cOFCvfzyy4EYLgAAQEAQDG9QVlamGTNmqLy83Ke2Dz74oHbs2GH+LCEhQYmJibJardq9e7cyMzNVVlamV155RWVlZZo/f34ghw8AAOAzppJvsGTJEqWmpkqSJk+e7FXb119/3QyFUVFRWr9+vVJTU5WcnKwNGzbo1KlTmj17tll/wYIF2rlzZ+AGDwAA4AeCYRXHjx/XokWLJEmPPfaYRo8e7XHbrKwsvfPOO+b2u+++q0ceecSuTkREhJYuXapJkyZJkmw2G9PJAACgziAYGmw2m2bMmKGSkhK1atXKLuR5Ijk5WYWFhZKknj17aubMmU7rLl26VGFhFb/6ffv26dChQ74PHAAAIEAIhoY//OEP2rNnjyTprbfeUmxsrFftP//8c7M8bdo0WSwWp3Xj4uI0cuRIc3vz5s3eDRYAAKAGEAwlnT17VnPnzpUkDR06VE899ZRX7a1Wq/bv329ujxgxwm2bu+++2yxXXawCAAAQLARDSUlJSSooKFBERIQ++ugjl2f7HElPTzdXMVssFt1+++1u2yQmJprlY8eOeTdgAACAGhDywfCTTz7RF198IUmaM2eObr31Vq/7SE9PN8uxsbGKiopy2yYuLs4s5+bmKjs72+v3BQAACKSQvo9hTk6OXnjhBUkVC0ZeffVVn/up1K5dO4/atG/f3m47NzdXbdu29en9K2VlZXkdMDMyMvx6TwAA0HCEdDD83e9+ZwapDz/8UJGRkT71c/XqVbPcpEkTj9rcWK9qH75auXKlFi5c6Hc/AAAgNIXsVPLf/vY3rVu3TpI0depUu8Ug3rJarWY5IiLCozY3htDi4mKf3x8AACAQQjIYFhYW6plnnpEktW7dWsuWLfOrv6rXFJaWlnrUpqSkxG7b0zONAAAANSUkp5JfffVVnTp1SpL09ttvq02bNn7117x5c7Ps6Zm/G+tV7cNXSUlJmjhxoldtMjIyNG7cOL/fGwAA1H8hFwwPHjyo5cuXS6q4l+DUqVP97rN169Zm+eLFix61uXDhgt12TEyM3+OIjY31+sbcAAAAlUIuGB45csS85+CZM2c0ePBgp3WrrvDNzMy0qztv3jzdd999kqRevXqZP8/KypLVanV7y5ozZ86Y5ZiYGL9XJAMAAPgr5IJhVSdOnNCJEyc8qltaWqpvvvnG3K4aGnv16qWwsDCVl5fLZrPp8OHDLgOnVHHmspIv904EAAAItJBcfBJoUVFRdkEwJSXFbZudO3ea5arPTQYAAAiWkAuG06ZNk81m8+jPmjVrzHbx8fF2r02bNs2u36oLONauXetyDGfPntX27dsdtgUAAAiWkAuGNWXq1Klq1qyZpIpH5K1atcpp3Tlz5uj69euSpCFDhtg9NxkAACBYCIYBEhsbq1mzZpnbL7zwgjZu3GhXp6ysTHPnztX69evNny1evLjWxggAAOBKSC8+CbR58+Zpz5492rFjh4qLizVp0iQtWrRIiYmJslqt2rVrlzIzM836Cxcu1PDhw4M4YgAAgF8QDAMoPDxcmzZt0syZM82zhampqUpNTa1Wb8GCBXrllVeCMUwAAACHCIYB1qJFC23YsEFPP/20kpOTtW/fPmVmZio8PFydO3fWmDFjNH36dG5RAwAA6hyLzWazBXsQCJ60tDQlJCSY20ePHlXfvn2DOCIAABAsLD4BAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgK8WB46tQpffzxx3r88cc1YMAAtWrVSuHh4YqJiVH//v31zDPPaOfOnT71/d133ykpKUl9+vRRdHS0oqOj1adPHyUlJem7774L8CcBAADwn8Vms9mCPYjadujQIT377LP69ttvPao/YsQIJScnKy4uzm3d0tJSzZ49W8uXL5ezX63FYtGLL76opUuXKjw83KuxB1paWpoSEhLM7aNHj6pv375BHBEAAAiWxsEeQDCkp6dXC4U9e/ZUQkKC2rRpo7y8PO3du1fnzp2TJKWkpGjIkCHavXu3unbt6rLvp59+Wn/605/M7a5du2rw4MGSpP379+unn36SzWbTu+++q/z8fP3xj38M8KcDAADwTUgGw0rdu3fXjBkz9Pjjj6tjx452r5WXl2vt2rV6/vnnVVRUpJ9//lmPPfaY9u7dK4vF4rC/1atXm6EwLCxMb7/9tl544QWFhYWZfb7//vt66aWXVF5ertWrV2v48OGaMmVKzX5QAAAAD4TkVPLOnTt18uRJPfHEE2rUqJHLups3b9b48ePN7a1bt2rMmDHV6pWUlKhHjx46e/asJGnu3LlavHixwz7nzp2rJUuWSJLi4+P1ww8/KCIiwteP4xemkgEAQKWQXHwyfPhwTZs2zW0olKQHH3xQgwYNMre//PJLh/X++te/mqGwRYsWmjdvntM+58+fr+joaEnS6dOnnfYJAABQm0IyGHrrrrvuMsunTp1yWOfzzz83y5MmTVLTpk2d9te0aVM9/PDD5vbmzZv9HiMAAIC/CIYeqHpN4fXr1x3W+cc//mGWR4wY4bbPu+++2yzv2LHD98EBAAAECMHQA6mpqWa5c+fO1V6/cuWKMjMzze3ExES3fVatc/78eeXn5/s5SgAAAP+E9KpkT5w5c8bujN4999xTrU56errdtif3O7yxTnp6ugYOHOjjKCtkZWUpOzvbqzYZGRl+vScAAGg4CIZuzJo1y5w+jouL0wMPPFCtTk5OjlmOjo5WkyZN3PbbtGlT3XTTTSooKJAk5ebm+j3WlStXauHChX73AwAAQhNTyS4kJyfrs88+M7cXL16syMjIavWuXr1qlj0JhY7qVu0DAAAgGAiGThw4cEDPPvusuf3oo49q8uTJDutarVaz7M39CKuGzOLiYh9GCQAAEDhMJTtw8uRJPfDAA2bg69+/vz788EOn9aOiosxyaWmpx+9TUlJilr050+hMUlKSJk6c6FWbjIwMjRs3zu/3BgAA9R/B8AaZmZkaPXq0Lly4IKniWcdbt241b0jtSPPmzc2yN2f+qtat2oevYmNjFRsb63c/AAAgNDGVXEVOTo5Gjx6tEydOSJI6dOigbdu2qUOHDi7btW7d2izn5+fbTS07U1RUZC48kaSYmBgfRw0AABAYBENDfn6+xowZo7S0NElSmzZttG3bNnXp0sVt2169etltnz592m2bM2fOuOwDAACgthEMJRUWFuree+/V999/L6niWcdbt25Vnz59PGrfokULu7OKhw4dctvm4MGDZrljx44up6oBAABqQ8gHQ6vVqrFjx2rPnj2SKu4v+OWXX+qOO+7wqp+qj7hLSUlxW3/nzp1meeTIkV69FwAAQE0I6WBYVlamhx56yHyySWRkpLZs2aK77rrL676qruzdsGGDy0UoxcXF2rhxo8O2AAAAwRKywfD69euaPHmyvvrqK0lS48aNtXHjRoePvPPE2LFj1alTJ0lSXl6e3njjDad1X3/9deXl5UmS4uPjdf/99/v0ngAAAIEUksHQZrNp+vTp+vTTTyVJYWFhWrduncaOHetzn5GRkXaPo1u8eLHef/99lZeXmz8rLy/X+++/ryVLlpg/e+2117y6KTYAAEBNsdhsNluwB1HbVq5cqd/+9rfmdo8ePfTrX//a4/YrVqxw+tqUKVO0bt06c7tbt24aPHiwJGn//v3mrXAk6cknn9Tq1au9GXrApaWlKSEhwdw+evSo+vbtG8QRAQCAYAnJG1xnZWXZbf/444/68ccfPW7vKhiuWrVKLVq00AcffCCbzaYTJ07YhUFJslgsev7557Vs2TLvBg4AAFCDQjIY1qSIiAgtX75cTzzxhFavXq2UlBSdP39eUsVtaUaMGKHp06dr4MCBQR4pAACAvZCcSsYvmEoGAACVQnLxCQAAAKojGAIAAEASwRAAAAAGgiEAAAAkEQwBAABgIBgCAABAEsEQAAAABoIhAAAAJBEMAQAAYCAYAgAAQBLBEAAAAAaCIQAAACQRDAEAAGAgGAIAAEASwRAAAAAGgiEAAAAkEQwBAABgIBgCAABAEsEQAAAABoIhAAAAJBEMAQAAYCAYAgAAQBLBEAAAAAaCIQAAACQRDAEAAGAgGAIAAEASwRAAAAAGgiEAAAAkEQwBAABgIBgCAABAEsEQAAAABoIhAAAAJBEMAQAAYCAYAgAAQBLBEAAAAAaCIQAAACQRDAEAAGAgGAIAAEASwRAAAAAGgiEAAAAkEQwBAABgIBgCAABAEsEQAAAABoIhAAAAJBEMAQAAYCAYAgAAQBLBEAAAAAaCIQAAACQRDAEAAGAgGAIAAEASwRAAAAAGgiEAAAAkEQwBAABgIBgCAABAEsEQAAAABoIhAAAAJEmNgz0AAIBzGVkF+vT788q8UqwOLZpowh0d1T32pmAPC0ADRTAEgDpq08Fz+t+fHtG1cpv5sz/+35+05KH+Gp/YKYgjA9BQEQwBhAR/z7zV9pm7jKyCaqFQksqu2zTnsyPq36mlusc2rzPjrQ/4nQDuEQwB1LpAH6Dd9efvmbdgnLn79Pvz1UJhpbLrNn128Jzm/Ka3x+Ndtfsn3RHfSjmFpZKkO+Jb6emhXex+Tw05OHH2FfCMxWazOf6fByEhLS1NCQkJ5vbRo0fVt2/fII4I9Y23YcLRATq8kcXnA7S7/jKyCvSbd3c7DFnhjSz6+sVhkmz69Pvz+uFivnILyxTTLFw920Vrwh0dJclte1dn7nz14ieHtOXwz05fH9m7rXq2i672e3f1eR35ty6t9MaD/XTk3JVqv8fGYdKwnm0lqdrvpT4FRk/+DdTE3yFQHxEMQxzBEP7wJuRlZBXo410ntfHAWTn6T8fRAdpd6PTkgP/p9+f04c4TTj/Dv3WJ0fenLzvtY2iPttpxPMtp+1vb36Tlk293GpQ8+Qw3vi5J/+svR3T4bJ7T97VIdr/HMIv05F1d9P3pyy7bedqfK/4E+WCY89kRbfjurNPXnxvRzenZVyDUEAxDHMEQvvLmLIyjAOnI7Z1bKq51U3Vo0UQtmjTW23/7wa6NRVK/ji2UV1yqAus1XS+3Kd96zWl/jwzsrAOnLysj66pvH9JDYRYp4eYWOpVTqOKy62oS3kh3dW+jm1s20Zo9J3Xjx46OaqyubZvrjviWSt57utpnlEWqD/8zx8U01ZCurfX0sC6S5NM0tK/T156223TwnF7a+E+Xobd7bHP1vTm6Wj8NeWodcIZgGOIIhvWfszNONXlAy8gqcHtGq/IszLp9pzRvS1rA3ht1j8VSEWirBmCLRbq7V1u9cu+tDv/tZWQVaNbGwzpyLt/u52EW6bbOLTWoS2un/27/kJKhpVvTq4W9Ph1uUr9OLSWbZL12XVGNG+nTg+d03cNp9cr3nz2ml9pFRwX0kgegviAYhjiCYf3m6ExcozCLbDab3UHamwOaLws5HPnP225Ws4hG+vO3zqfw0PBVTnGHNwozr+HMLy7VT5eK3La1WKRBt7TSLW2ay1p2XVHhjXTs53wdOX+lVsbt6J+4r9ckcvYR9QXBMMQRDIMnELdP8WaRQdUDWkZWgT7efVLfn74sSbojrpWeHtZFf//XRb31P+lOQ2VGVoHGvLvbozMwQ7u30e6MSx5/HqC+6BHbXKNubefxPuvttbje/r/gbH8meMIXBMMaUlpaqg0bNmj9+vVKS0vTxYsX1apVK3Xp0kXjx4/XtGnT1KZNm2APs94Gw/r27fvG8Tq6fs7baar/+vq4y0UVjkQ0sqh180hduGL1eKFB5di+fnGY3vzqX9pxPNur9wQaqspp5+dGdHdax99rcd39v7Dp4Dn9r7/8s9rZzUYW6a2JA5j2htcIhjXg+PHjevTRR3X48GGndWJjY7VmzRrde++9tTcwB+pjMAz07U5qmqdTr1L1A8WNgXLgLa303anLyrxSrENn8nQm1/10XKDc2v4mHbtQUGvvB9QX/9YlRm88mFDty6k31+L6ckudjKwCjfk/u3XdyWG8cZi09f8Z7nDau759uUbt4QbXAXbu3DmNGjVKP/9ccf8xi8WiYcOGqVu3bsrOzta2bdtUXFysrKwsjRs3Tlu3btXIkSODPOr6w9+nQdQ2Z+N1puqNix0Fyg931tRI3SMUAo59czJXo9/ZpUFdYnRLm2ayll1XgbVMKcezVe6m7c95xZJ8u6H5m18dcxoKJelauRy242bfcIVgGGCTJ082Q2F8fLy2bNmiAQMGmK9funRJjzzyiLZv366ysjJNnDhRJ06cUMuWLYM04vrFn6dBVOXq2/L2Yxe1fEeGLl0tUZvmkXp+ZHeNurWdR+O7sd/LRaUeh8JK6RfyNefTI07v9weg7rGpIiB+czLXq3aHz+Tpv74+rh8u5rus93Nesd3/L1HhjTy6rCP9Qr7+6+vjdrMO9enLNWofU8kB9NVXX+m+++6TJEVEROjAgQPq169ftXqFhYXq37+/fvrpJ0nSyy+/rDfffLNWx1qpvk0lu3saxH/edrPee+R2l324moo+cCrX4SrayYM6683x/b3u1+LD/eicrYYE0HC5u8H4yN6x2vVDttdfNL19H272jbBgD6Ah+eCDD8zy1KlTHYZCSWrWrJlee+01c/ujjz7StWvOb9KLX3Ro0cTl6ze3dP26q6no2Z8ecXprlT9/e9bl0y+c9evL1y5CIRB6XO32jSzSzgCEQnfvI/0ytY3QRTAMkKtXr2r79u3m9pNPPumy/kMPPaTmzStO1+fm5mrXrl01Or6GYsIdHRXeyOLwtfBGFj3k5voYV1PR7m7B8tb/HPepX0+FOf5YAEJcp1ZNvLpJtz9u/HK9/dhFjftgj/59yQ6N+2CPth+7WCvjQPAQDANk7969KikpkVRxRnDgwIEu60dFRWnIkCHm9o4dO2p0fA1F99ibtOSh/tXCYeVUsLtrYzKv+P5t+FhmgTYdPOdTv5YbQl+YpeIpDbd3bqmRvdvquRHdNPCWGJ/HBqDhul5Lswg3frl+ZdMRTU8+oMNn83TucrEOn83T9OQDemXTkdoZEIKCxScBcuzYMbPcr18/NW7s/lebmJiov//979Xaw7XxiZ3Uv1NLfXbwnH7OK9bNLZvoocROHl0w7W4q2h1nF2e763fSrzqrVbMIffNTjg6fzVO5TfpXZsUq3zCLNPCWGGUXlPg1NgAN09WSmr/U6MYv19uPXXR5ac09fdprZO/YGh8Xah/BMEDS09PNcnx8vEdt4uLizPLx486nKVFd99jmPl0gPeGOjvrj//1JZQ6+gjcKs7idrnG28tlVv5IU37qZRveJ1ce7fqp2DWG5TVqyNd1hOwDIKyoLeJ/39muv+NbNnH65Xr4jw2X75Tt+JBg2UATDAMnJyTHL7dp5dmuT9u3bm+XcXO9uceBIVlaWsrO9eypFRobrnb+hqZyKnvPZEbsQ525VclWOLs7uHnuTZo3u6TTgvfP3dJ3KKQzIxeMA4I9GYRbNGt3L5SzLpauuZzCY4Wi4CIYBcvXqVbPcpIln05VV61Vt76uVK1dq4cKFfvfT0Lmaih6f2EmXi8r09dELTttXXpxd7Z6FhaVO25Rdt+mg8RxTAAiWMIv01gT312O3aR6pc5edXzvd9qbIQA8NdQTBMECsVqtZjoiI8KhNZOQvO1ZxMbcIqE2upqJf+nVPbTt20eG0cOXF2c7uWegK5woBBFuYRerfqaXbes+P7K7pyQdcvN4jgKNCXcKq5ACJiooyy6Wlzs8cVVW5ilny/Cwjap6zlc+Nw6ShPdroza/+pZc2/tPrexb+Kr5VoIcKAF6pfEyeO6NubafJgzo7fG3yoM5cX9iAccYwQCrvSSh5fvavar2q7X2VlJSkiRMnetUmIyND48aN8/u9G5obp5sLrNe084dsjx5B5Uh4I4sSOkZL3wV4oADgpfQLrh+/V+nN8f11T5/2Wr7jR2UXlKjtTZF6fmQPQmEDRzAMkNatW5vlixc9uwHohQu/XMcWE+P/PexiY2MVG8sOGyiV080ZWQX6zbu7Pb7B7I2Pwatc2PKnfadraKQA4LmU9GxtOnhO4908EECqeBQfQTC0EAwDpFevXmb59GnPAsCZM2fMcu/ePJuyrvL2qSaV9yz8Oa9YTcIbyaaKx1llZPm/wAgA/FVuc35PVoBgGCC33nqrWU5NTdW1a9fc3uT64MGDDtujbvHmaSnhjSyaMbSrusc2d7hABQDqAmf3ZAVYfBIgd955p7nKuLCwUAcOOF/NJVUsPNm/f7+5PXLkyBodH3zn6dNSqj45ICOrIGChMD6mqXiMMgBHWjUNV2JcS5+ete7onqwAwTBAmjdvrlGjRpnba9eudVl/06ZNKiioeCRaTEyMhg0bVpPDgx8m3NGx2grlSmEWmc86/vrFYeY1O95OP7tyb/8OuptrfAA4MKZve21Kukt/+91wPTeimxLjWnrctvKerEBVBMMASkpKMstr165VWlqaw3pFRUWaP3++uT1z5kyPnq2M4HB2+5rwRhYtmzhAq6cN0pzf9La7Vseb6WdXKu+beFMU/z4A2GtkkWYM7Srpl8Vym5Lu0h+n/srtGcTGYRX/twA3IhgG0H333aehQ4dKqpgqvv/++3XkyBG7Ojk5ORo3bpz5KLqYmBjNmTOn1scK74xP7KSvXxym50Z003/ednO1M4Q38nT62ZWqU9OB6A9Aw9E4THpr4gCHi0dG3dpOyyYOcDrTIUk2m01HzuXV4AhRX1lsNne35YU3zp07p0GDBikzM1OSZLFYNHz4cHXr1k3Z2dnatm2bioqKJEmNGzfW1q1b7aaga1taWpoSEhLM7aNHj6pv375BG09DkZFVoP94b7fDp6fceDubG3Vq1UQPDLjZ7qH2rvpzpn/HFko9f8XuiSuNLBUrEtnpgfrlkYG/3O2g6mM8XcnIuqpVu3/Shu/OOtznwxtZ9PWLw1iZDDvMTwVYp06dtGPHDj366KM6fPiwbDabUlJSlJKSYlevbdu2WrNmTVBDIWpO5fTznM+O2IW58EYWDe3RxuWNsh8YcHO1lYLO+nOkcZi0dMIAjU/spIysq9WeCX3kXF61fiyS4lo3lbXsui7mlzjvHEDAhVmkgbfE6LtTuXJ0aXLVux14o3tsc7VsGuH0iyArk+EIwbAG9O7dW998840++eQTrV+/Xmlpabp48aJatmyprl27avz48XryySfVpk2bYA8VNejGp6dUBjPJpt0/XnL5LGZP+msS3kiSlFVQostFpWrVNFy92kfbnUlw9Ezo7rHNHY6re2xz/dfXx/XhzhOB/UUA9ZBFvp9ZnzG0i8Ibhdntp8Vl11VgvaZdP2TbLUyrvGRkvPEMdkdfJisvKfGFu+udWZmMGzGVHOKYSg4OVwcAT55GUFO8nbIOs0hP3dVF4Y0rDoKl18r19dEL7hsCQdSySbjyistc1hnZu616tY82w92+Ezk6nVvksk2YRZo9ppeeG9HdaR1HZ/Grhj53r3vL3Ze950Z044wh7BAMQxzBMHgCfQAIFEehNcwi3da5pXq2u0lSxdkPZ2N+ZdMR/fnbs9X6jY5qrLAwi/KKXB+Qa1rTiEa6Vl6u0msN87++AR1b6MzlIl0O8u/ZW73aNdftca2UVWBVZp5Vxy4UeNSuXXSkYppFqKjkmiSLGoVJxWXlyrxidVi/8rq6j41r75y5MTC5C1i3x7XUWxMcLwYJJldf9rjGEI4QDEMcwRCO+BtadxzP0vIdPyq7oERtb4rU8yN7aGTvWJ8W0VQKb2TRzS2b6HSO67M2FkkxzSKUU1harX3VM7KVnzH9Qr7+cTy73i/IsUj637+pOFtV+Xzv+vLUnRn/fov+3/vt/9/x9MlBzs54uTsr721gqs8Bq67OUKBuIhiGOIIhapujg5QjjcMsmnBHJ7uzk59+f87lWZswi7RsovOFN84O3BUh5J+6Vl71/aWHf9VZGw+ctfu5vxLjWurIuSs+hbbGYRb9f1N+pe9O5Sr9Qr4uF5WpVdMI9Wp/U7XPt+ngOc3+9Iiue/A+t7RuqivFZSosuaZSN38vjcIqltV7k+17xDZX55im1a6vq5h67a3nRnRz2M5cVXvgrMOV/O4Cmbt/A94GpvocsOrqDAXqHoJhiCMYIhiqHqQuXLHq25O5dmfsnB1sXZ21CbNIq6YO1EgfnxLj7MCZkXVVb351TP9Iz7ILJ5UrSb85mevV+zw3opseSuxUbRFRZQCOjmqsZf+TXi14NQqz6K0J3gWQymD1/enLyreWKSu/xO73fOM1ce5uszTpV53NGypXHf+V4jJtTbvgNrz5Gk5qMpB5OyYCFho6gmGIIxiiLvD27F4wzto4GqNk82pq3NMpx6qBTpLuiG/l0+1KPPkMN/bp6++3pv9eCGRA7SAYhjiCIeqjuhQSHAUiR9Ot9WXKUfL991uX/l4A+IZgGOIIhoD/HJ9NFCEJQL1DMAxxBEMAAFApLNgDAAAAQN1AMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgKQQDoanTp3Sxx9/rMcff1wDBgxQq1atFB4erpiYGPXv31/PPPOMdu7c6XP/3333nZKSktSnTx9FR0crOjpaffr0UVJSkr777rsAfhIAAIDAsNhsNluwB1GbDh06pGeffVbffvutR/VHjBih5ORkxcXFeVS/tLRUs2fP1vLly+XsV2uxWPTiiy9q6dKlCg8P93jsNSEtLU0JCQnm9tGjR9W3b98gjggAAARL42APoLalp6dXC4U9e/ZUQkKC2rRpo7y8PO3du1fnzp2TJKWkpGjIkCHavXu3unbt6rb/p59+Wn/605/M7a5du2rw4MGSpP379+unn36SzWbTu+++q/z8fP3xj38M4KcDAADwXcgFw0rdu3fXjBkz9Pjjj6tjx452r5WXl2vt2rV6/vnnVVRUpJ9//lmPPfaY9u7dK4vF4rTP1atXm6EwLCxMb7/9tl544QWFhYWZ/b7//vt66aWXVF5ertWrV2v48OGaMmVKzX1QAAAAD4XcVPLOnTt18uRJPfHEE2rUqJHLups3b9b48ePN7a1bt2rMmDEO65aUlKhHjx46e/asJGnu3LlavHixw7pz587VkiVLJEnx8fH64YcfFBER4cvH8RtTyQAAoFLILT4ZPny4pk2b5jYUStKDDz6oQYMGmdtffvml07p//etfzVDYokULzZs3z2nd+fPnKzo6WpJ0+vRpl/0CAADUlpALht666667zPKpU6ec1vv888/N8qRJk9S0aVOndZs2baqHH37Y3N68ebNfYwQAAAgEgqEbVa8pvH79utN6//jHP8zyiBEj3PZ79913m+UdO3b4NjgAAIAAIhi6kZqaapY7d+7ssM6VK1eUmZlpbicmJrrtt2qd8+fPKz8/349RAgAA+I9g6MKZM2fszubdc889Duulp6fbbXtyz8Mb69zYBwAAQG0L2dvVeGLWrFnm9HFcXJweeOABh/VycnLMcnR0tJo0aeK276ZNm+qmm25SQUGBJCk3N9fv8WZlZSk7O9urNhkZGX6/LwAAaBgIhk4kJyfrs88+M7cXL16syMhIh3WvXr1qlj0JhVXrVgbDqn34auXKlVq4cKHf/QAAgNDEVLIDBw4c0LPPPmtuP/roo5o8ebLT+lar1Sx7cz/CqkGzuLjYy1ECAAAEVp05Y7hixQqtWLEioH0uWrRIEyZM8KrNyZMn9cADD5hhr3///vrwww9dtomKijLLpaWlHr9XSUmJWfbmTCMAAEBNqDPB8NKlSwFfgJGXl+dV/czMTI0ePVoXLlyQVPGc461bt5o3o3amefPmZtmbM39V61btw1dJSUmaOHGiV20yMjI0btw4v98bAADUf3UmGAZbTk6ORo8erRMnTkiSOnTooG3btqlDhw5u27Zu3dos5+fny2q12p1FdKSoqMi8vlCSYmJifBz5L2JjYxUbG+t3PwAAIDTVmWsMFyxYIJvNFtA/M2bM8Oi98/PzNWbMGKWlpUmS2rRpo23btqlLly4ete/Vq5fd9unTp922OXPmjMs+AAAAaludCYbBUlhYqHvvvVfff/+9pIrnHG/dulV9+vTxuI8WLVrYnVk8dOiQ2zYHDx40yx07dnQ7XQ0AAFDTQjoYWq1WjR07Vnv27JFUcW/BL7/8UnfccYfXfVV9xF1KSorb+jt37jTLI0eO9Pr9AAAAAi1kg2FZWZkeeugh88kmkZGR2rJli+666y6f+qu6gGPDhg0uF6EUFxdr48aNDtsCAAAES0gGw+vXr2vy5Mn66quvJEmNGzfWxo0bnT7yzhNjx45Vp06dJFWshn7jjTec1n399dfNFdPx8fG6//77fX5fAACAQAm5YGiz2TR9+nR9+umnkqSwsDCtW7dOY8eO9avfyMhIu6eOLF68WO+//77Ky8vNn5WXl+v999/XkiVLzJ+99tprXt0UGwAAoKZYbDabLdiDqE0rV67Ub3/7W3O7R48e+vWvf+1xe3c34Z4yZYrWrVtnbnfr1k2DBw+WJO3fv9+8HY4kPfnkk1q9erXH710T0tLSlJCQYG4fPXpUffv2DeKIAABAsITcfQyzsrLstn/88Uf9+OOPHrd3FwxXrVqlFi1a6IMPPpDNZtOJEyfswqAkWSwWPf/881q2bJnnAwcAAKhhIRcMa1pERISWL1+uJ554QqtXr1ZKSorOnz8vqeK2NCNGjND06dM1cODAII8UAADAXshNJcMeU8kAAKBSyC0+AQAAgGMEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDAEAACAJIIhAAAADARDAAAASCIYAgAAwEAwBAAAgCSCIQAAAAwEQwAAAEgiGAIAAMBAMAQAAIAkgiEAAAAMBEMAAABIIhgCAADAQDB0YNasWbJYLOafW265xes+tm/frilTpqhnz55q1qyZYmJi1L9/f82ePVvHjx8P/KABAAD81DjYA6hrvv32W7333ns+t8/Pz9fMmTO1YcMGu58XFRXp8uXLSk1N1XvvvaeFCxfq5Zdf9ne4AAAAAUMwrKKsrEwzZsxQeXm5z+0ffPBB7dixw/xZQkKCEhMTZbVatXv3bmVmZqqsrEyvvPKKysrKNH/+/EANHwAAwC9MJVexZMkSpaamSpImT57sdfvXX3/dDIVRUVFav369UlNTlZycrA0bNujUqVOaPXu2WX/BggXauXNnYAYPAADgJ4Kh4fjx41q0aJEk6bHHHtPo0aO9ap+VlaV33nnH3H733Xf1yCOP2NWJiIjQ0qVLNWnSJEmSzWZjOhkAANQZBENVBLQZM2aopKRErVq1sgt4nkpOTlZhYaEkqWfPnpo5c6bTukuXLlVYWMWvft++fTp06JBvAwcAAAgggqGkP/zhD9qzZ48k6a233lJsbKzXfXz++edmedq0abJYLE7rxsXFaeTIkeb25s2bvX4/AACAQAv5YHj27FnNnTtXkjR06FA99dRTXvdhtVq1f/9+c3vEiBFu29x9991muepiFQAAgGAJ+WCYlJSkgoICRURE6KOPPnJ5ps+Z9PR0cyWzxWLR7bff7rZNYmKiWT527JjX7wkAABBoIR0MP/nkE33xxReSpDlz5ujWW2/1qZ/09HSzHBsbq6ioKLdt4uLizHJubq6ys7N9em8AAIBACdn7GObk5OiFF16QVLFY5NVXX/Wrr0rt2rXzqE379u3ttnNzc9W2bVufxyBVrIz2NmBmZGT49Z4AAKDhCNlg+Lvf/c4MUR9++KEiIyN97uvq1atmuUmTJh61ubFe1T58tXLlSi1cuNDvfgAAQGgKyankv/3tb1q3bp0kaerUqXYLQXxhtVrNckREhEdtbgyixcXFfo0BAADAX3XmjOGKFSu0YsWKgPa5aNEiTZgwwe5nhYWFeuaZZyRJrVu31rJly/x+n6rXFJaWlnrUpqSkxG7b0zONAAAANaXOBMNLly7ZLeIIhLy8vGo/e/XVV3Xq1ClJ0ttvv602bdr4/T7Nmzc3y56e+buxXtU+fJWUlKSJEyd61SYjI0Pjxo3z+70BAED9V2eCYW04ePCgli9fLqniPoJTp04NSL+tW7c2yxcvXvSozYULF+y2Y2Ji/B5HbGysTzfnBgAAkOpQMFywYIEWLFhQo+9x5MgR836DZ86c0eDBg53Wrbq6NzMz067uvHnzdN9995nbvXr1MstZWVmyWq1ub1lz5swZsxwTE+P3imQAAAB/1ZlgWNtOnDihEydOeFS3tLRU33zzjbl94y1hevXqpbCwMJWXl8tms+nw4cMuQ6dUcfaykq/3TwQAAAikkFyVHGhRUVF2QTAlJcVtm507d5rlqs9NBgAACJaQCobTpk2TzWbz6M+aNWvMdvHx8XavTZs2rVrfVRdwrF271uU4zp49q+3btztsCwAAECwhFQxr0tSpU9WsWTNJFY/IW7VqldO6c+bM0fXr1yVJQ4YMsXtuMgAAQLAQDAMkNjZWs2bNMrdfeOEFbdy40a5OWVmZ5s6dq/Xr15s/W7x4ca2NEQAAwJWQXXxSE+bNm6c9e/Zox44dKi4u1qRJk7Ro0SIlJibKarVq165dyszMNOsvXLhQw4cPD+KIAQAAfkEwDKDw8HBt2rRJM2fONM8WpqamKjU1tVq9BQsW6JVXXgnGMAEAABwiGAZYixYttGHDBj399NNKTk7Wvn37lJmZqfDwcHXu3FljxozR9OnTuUUNAACocyw2m80W7EEgeNLS0pSQkGBuHz16VH379g3iiAAAQLCw+AQAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMDQO9gAQXCUlJXbbGRkZQRoJAAD1W7du3RQVFRXsYfiFYBjizp49a7c9bty44AwEAIB67ujRo+rbt2+wh+EXppJDXF5eXrCHAABAg5CTkxPsIfiNYBji8vPzgz0EAAAahMuXLwd7CH5jKjnE/epXv7Lb3rhxo/r06ROk0QCoKiMjw+7yjs8//1zdu3cP3oAA2LlxH+3cuXPwBhMgBMMQFx0dbbfdp0+fen99BNBQde/enf0TqMMiIyODPQS/MZUMAAAASQRDAAAAGAiGAAAAkEQwBAAAgIFgCAAAAEkEQwAAABgIhgAAAJBEMAQAAICBYAgAAABJBEMAAAAYCIYAAACQxLOSQ17btm31+9//3m4bQN3A/gnUbQ1xH7XYbDZbsAcBAACA4GMqGQAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhiFp7dq1slgsXv2ZMWOGV++xfft2TZkyRT179lSzZs0UExOj/v37a/bs2Tp+/HgNfTKgYSgtLdW6det07733Kj4+XlFRUerQoYPuvPNOLVu2TJcuXQr2EIEGoaaPh/XyWGhDyFmzZo1Nkld/pk+f7lHfV65csU2aNMllX+Hh4bY333yzhj8lUD8dO3bMdtttt7nch2JjY21ffvllsIcK1Hs1dTysz8fCxjWSNlFv9O7dW6NGjXJb784773Rbp6ysTA8++KB27Nhh/iwhIUGJiYmyWq3avXu3MjMzVVZWpldeeUVlZWWaP3++X+MHGpJz585p1KhR+vnnnyVJFotFw4YNU7du3ZSdna1t27apuLhYWVlZGjdunLZu3aqRI0cGedRAwxCo42G9PxYGO5mi9lX9hjR16tSA9Ttv3jyz36ioKNv69evtXi8pKbHNnj3brGOxWGwpKSkBe3+gvhs6dKi5f8THx9sOHz5s93p2drZt1KhRZp2YmBjb5cuXgzNYoAGoieNhfT8Wco0hAiIrK0vvvPOOuf3uu+/qkUcesasTERGhpUuXatKkSZIkm82ml19+uVbHCdRVX331lXbv3i2pYl/57//+bw0YMMCuTps2bbRlyxZ17dpVkpSbm6ulS5fW+lgBONYQjoUEQwREcnKyCgsLJUk9e/bUzJkzndZdunSpwsIq/unt27dPhw4dqpUxAnXZBx98YJanTp2qfv36OazXrFkzvfbaa+b2Rx99pGvXrtX4+AC41xCOhQRDBMTnn39ulqdNmyaLxeK0blxcnN11UZs3b67JoQF13tWrV7V9+3Zz+8knn3RZ/6GHHlLz5s0lVZw13LVrV42OD4BnGsKxkGAIv1mtVu3fv9/cHjFihNs2d999t1mueoEuEIr27t2rkpISSRVnBAcOHOiyflRUlIYMGWJusw8BwddQjoWsSg5xeXl5+stf/qK0tDRduXJF0dHRuvnmmzVkyBD169fP5bedSunp6SovL5dUsYry9ttvd9smMTHRLB87dsz3DwA0AFX3gX79+qlxY/f/NScmJurvf/97tfYAfOPv8bChHAsJhiFuy5Yt2rJli8PXevTooTlz5uipp55yuUOkp6eb5djYWEVFRbl937i4OLOcm5ur7OxstW3b1ouRAw1H1X0oPj7eozZV96E6e6NcoB7x93jYUI6FTCXDqR9//FEzZszQ2LFjzYtpHcnJyTHL7dq186jv9u3b223n5ub6NkigAfB3H2L/AWqWJ8fDhnIsJBiGqLi4OL300kv66quvdPbsWVmtVhUWFio9PV0rV65U7969zbpffPGFJk+ebJ4iv9HVq1fNcpMmTTx6/xvrVe0DCDX+7kPsP4DvAnU8bCjHQoJhCBo3bpxOnjypZcuW6T/+4z/UqVMnRUZGqmnTpurZs6eee+45/fOf/7RbGfnXv/5Vf/7znx32Z7VazXJERIRHY4iMjLTbLi4u9uGTAA2Dv/sQ+w/gm0AeDxvKsZBrDOuIFStWaMWKFQHtc9GiRZowYUK1n7ds2dJt24iICK1atUoZGRnmTXeXLFmixx9/vFrdqtdRlJaWejS2yhWYlTz9dgU0RP7uQ+w/gG8CeTxsKMdCgmEdcenSJbsLVwMhLy/Pr/ZhYWH6/e9/r3vuuUeSdPToUZ07d06dOnWyq1d5PzXJ8287N9ar2gcQavzdh9h/gJrlyfGwoRwLmUqGS8OGDVN4eLi57Wg5fevWrc3yxYsXPer3woULdtsxMTE+jhCo//zdh9h/gJrn7njYUI6FBMM6YsGCBbLZbAH9M2PGDL/HFR4erjZt2pjbly5dqlanV69eZjkrK8vuOgtnzpw5Y5ZjYmKCvjwfCKaq+9Dp06c9alN1H6p6cTyAmuHueNhQjoUEQ7hVdWl+s2bNqr3eq1cv83mPNptNhw8fdtvnwYMHzfKtt97q/yCBeqzqPpCamurRs4/Zh4Da5+p42FCOhQRDuPTTTz8pPz/f3L755pur1YmKitLgwYPN7ZSUFLf97ty50yxXfVYkEIruvPNOc3ViYWGhDhw44LJ+SUmJ3aO32IeAmufueNhQjoUEQ7i0evVqs9yiRQvddtttDuuNGzfOLK9du9Zln2fPntX27dsdtgVCUfPmzTVq1Chz290+tGnTJhUUFEiqmH4aNmxYTQ4PgDw7HjaEYyHBMMR4c/PMvXv36u233za3H3nkEafPcJ06dap5Wj09PV2rVq1y2u+cOXN0/fp1SdKQIUPsnhUJhKqkpCSzvHbtWqWlpTmsV1RUpPnz55vbM2fO9OjZygDs1cTxsEEcC20IKWvWrLENHDjQlpycbMvLy3NYp7i42Pbee+/ZmjRpYpNkk2Rr2bKl7eeff3bZ97x588z6TZo0sW3YsMHu9dLSUtucOXPMOpJsKSkpAftsQH03dOhQc9+45ZZbbP/85z/tXr906ZJt9OjRZp2YmBjb5cuXgzNYoJ6rqeNhfT8WWmw2m622wyiCZ+3ateYd3Bs3bqzevXurd+/eatWqla5fv67z589r3759dtdRNGnSRFu3bnU7XVVWVqbf/OY32rFjh/mzfv36KTExUVarVbt27VJmZqb52sKFC+3OfACh7ty5cxo0aJC5n1gsFg0fPlzdunVTdna2tm3bpqKiIkkV++/WrVvtpqABeK6mjof1/lgY7GSK2rVmzRq7bynu/gwaNMj2r3/9y+P+8/LybA8//LDLPsPDw21vvPFGDX5KoP46duyY7bbbbnO5D7Vt29b2xRdfBHuoQL1Wk8fD+nws5IxhiCkpKdH333+vvXv3av/+/Tpx4oQuXbqknJwclZeXq0WLFurSpYsGDx6sCRMm6N///d99ep9t27YpOTlZ+/btU2ZmpsLDw9W5c2eNGTNG06dPrzPL8oG6qLS0VJ988onWr1+vtLQ0Xbx4US1btlTXrl01fvx4Pfnkk3b3UwPgvdo4HtbHYyHBEAAAAJJYlQwAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACCJYAgAAAADwRAAAACSCIYAAAAwEAwBAAAgiWAIAAAAA8EQAAAAkgiGAAAAMBAMAQAAIIlgCAAAAAPBEAAAAJIIhgAAADAQDAEAACBJ+v8BsSRKz3N2HYMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2, 2), dpi=300)\n",
    "x = np.random.normal(0, 10, (10000))\n",
    "y = np.random.normal(0, 1, (10000))\n",
    "X = np.stack([x, y], axis=1)\n",
    "plt.scatter(x, y, s=1)\n",
    "plt.xlim(-50, 50)\n",
    "plt.ylim(-50, 50)\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "sns.despine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2, 2), dpi=300)\n",
    "Xn = X / np.linalg.norm(X, axis=1, keepdims=True)\n",
    "plt.scatter(Xn[:, 0], Xn[:, 1], s=1)\n",
    "plt.xlim(-1.5, 1.5)\n",
    "plt.ylim(-1.5, 1.5)\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "sns.despine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAl8AAAJICAYAAABfbIE+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAC4jAAAuIwF4pT92AABaO0lEQVR4nO3debxU1Znv/2+dmUE4zEMQEFSOUZTYEYUENKA3CSa5ROX+xKQ15Jp0S+d380u/7r0mt29ia7rTGUzfG2PstjsR1ASNSVSi0iQCIZowKCGMAspwQAQOZ2A6Y03790dByZG9NjXsvWpX1ef9ep0Xdc7eVXuZ1PDUs571rIjjOI4AAABgRUWhBwAAAFBOCL4AAAAsIvgCAACwiOALAADAIoIvAAAAiwi+AAAALCL4AgAAsIjgCwAAwCKCLwAAAIsIvgAAACwi+AIAALCI4AsAAMAigi8AAACLCL4AAAAsIvgCAACwiOALAADAIoIvAAAAiwi+AAAALCL4AgAAsIjgCwAAwCKCLwAAAIsIvgAAACwi+AIAALCI4AsAAMAigi8AAACLCL4AAAAsIvgCAACwqKrQA0Buuru7tWfPnvTvEydOVF1dXQFHBAAAMkHwVaT27NmjK664Iv37tm3bdPnllxdwRAAAIBNMOwIAAFhE8AUAAGARwRcAAIBFBF8AAAAWEXwBAABYRPAFAABgEcEXAACARQRfAAAAFhF8AQAAWETwBQAAYBHBFwAAgEUEXwAAABYRfAEAAFhE8AUAAGARwRcAAIBFBF8AAAAWEXwBAABYRPAFAABgUVWhBwCf7HhRGhqRRry/0CMBACC89q+Rju2XqvtIl88tyBAIvkrFqm9Ko/oQfAEA4GXjk9LmJanbl58oyBCYdiwlsa5CjwAAgHCLdRZ6BARfJSUETygAAEItBIkKgq9SEu8u9AgAAAi3OMEX/ETmCwAAb2S+4KsYmS8AADyF4LOS4KuUkPkCAMBbCD4rCb5KSQhSqQAAhFoIPisJvkoJBfcAAHij4B6+CkEqFQCAUCPzBV+FoIgQAIDQSiZDMUtE8FVKyHwBAGAWgsBLIvgqLSFIpQIAEFoEX/BdSJ5UAACEUkhmiAi+SklInlQAAIRSSGaICL5KSTIuJWKFHgUAAOFE8HWuRCKhLVu26Cc/+YnuueceffCDH1RNTY0ikYgikYhuuOGGQK67ePHi9DUy/bn77rsDGUveQvLEAgAgdELyGVlV6AGc8fzzz+szn/mMOjuZOstLrEuqG1DoUQAAED4haLAqhSj4On78eCgCr4aGBs2ePfu8502fPt3CaHIQkicWAAChQ+bL3YgRI3TNNdekf37zm9/oBz/4gbXrX3vttXr44YetXc93IXliAQAQOiFZmBaa4OtjH/uY9u/fr7Fjx/b6+/r16ws0oiJF8AUAgLuQ7AQTmuBr5MiRhR5CaSD4AgDAXUgyX6Fa7QgfEHwBAOAuJM3ICb5KDQX3AAC4C0mCIjTTjmFx/Phx/eIXv9D27dt14sQJDRgwQKNHj9a0adM0efJkRSKRQg/RW0ieWAAAhE5Iph0Jvt5j6dKlWrp0qeuxSy65RPfee68+//nPhzcII/gCAMAdBffF56233tLdd9+t559/Xk8//bT69evny+MePXpUzc3NWd1n9+7d7gcIvgAAcEfmK1zGjh2refPmafbs2Zo8ebKGDRumRCKhgwcPauXKlXrooYe0c+dOSdKLL76oO+64Q88995wqKvIvm3vkkUd0//335/04kkLzxAIAIHQouA+PuXPnat++fXrwwQf18Y9/XGPGjFFtba369u2rSy+9VPfcc482b96sBQsWpO/z61//WkuWLCngqA1C8sQCACB0QpKgIPiSVF9ff94MVk1NjX784x9rxowZ6b995zvfCXpo2QvJEwsAgNAJSWkO045ZqKio0H333acbb7xRkrRt2zYdPHhQY8aMyetxFy5cqHnz5mV1n927d2vu3LnnHghJMSEAAKETks9Igq8szZw5U9XV1YrFYpKkHTt25B18DR8+XMOHD/djeKGJ6gEACJ2QzA4x7Zil6upqDR06NP17S0tLAUfjIiRPLAAAQickddEEXzno6OhI3/ar3YRvQvLEAgAgdEKSoCD4ytLevXt18uTJ9O+jR48u4GhchOSJBQBA6ISkNIfgK0uPPfZY+vbAgQM1ZcqUwg3GTUiKCQEACJ2QfEaWffDV3t6e8blr1qzR97///fTvt99+u6qqQrZmgcwXAADuQvIZWbLBV2NjoyKRSPpn8eLFruf98pe/1NSpU/XEE0/oxIkTrud0d3froYce0o033qju7lTUXF9fr/vuuy+o4ecuJClVAABCJRGXkrFCj0JSyFpNzJkzR4cOHer1tyNHjqRvb9iwwXWab9my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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2, 2), dpi=300)\n",
    "theta = np.arctan2(Xn[:, 1], Xn[:, 0])\n",
    "plt.hist(theta, bins=100, density=True)\n",
    "plt.xlim(-np.pi, np.pi)\n",
    "thetas = np.linspace(-np.pi, np.pi, 100)\n",
    "plt.plot(thetas, 10/(2 * np.pi * (100 - 99*np.cos(thetas)**2)))\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "sns.despine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Figure for normalized Gaussian distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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qLe3t/S62kPh62nr9/vV19fXUNtUKlVxytvn86m/v7+htul0uup6z9u35XraWj1GGIah+fmFUp1LUs9mLbia2UbOnTtnSqr653Wve71535f/vvSnu7u7YttXv+Y1ZW0HB4cqtj116nRZ27GxsYptp6amytpOTU1VbDs2NlbW9tSp0xXbjo6Oms+ff7H0541velPFtv39/WX/drfeemvVf7ft3v3ud1dtm0wmS20//OEPV20bCARKbe+8886qbaenp0ttP/7xj1dte+7cuVLbe+65p2rbp556qtT2i1/8YtW2jz32WKntX/7lX1Zt++CDD5bafuUrX6na9v777y+1vf/++6u2/e//43Ol/8Zf+tL/rNr2/R/4YKl2Pv6JT1Zt++733F5q+6ef/kzVtv/xHe8stf3sf/vvVdv++q+/vdT281/4UtW2N9/8H0pt/9f/vrdq29tu+0/m8+dfNGdm58xEIlH97/bud5fVcLW2t956a1nb/v7+im1vuummsrbj4+MV215//fVlbU+ePFmx7ZkzZ8ranjlzpmLbkydPlrW9/vrrK7YdHx8va3vTTTdVbOuUMcLt2vpI1uuMIk8vcbto3DvnripJpdMqBlikAu3JZ5rtcwnfc889p9e+9rWl13/66Xs0NTVV1sZt08Vbrr32jAaHBsumjTKZjAzD0NHJSY2MDO/6HaaLNzh1ujiVSml+YVE7/2tvTRfn83k9+eRTVe+PdcIUcDOmi7ds1bm0MV28tc2ZpqlDQ4MaHRmp2Aemizc4bbo4EoloemZ2V51L0ujwsK688nTFz3GDtj6S7e7uLguovez3c6e13R7k28XicU0emSx7b2ugSCSTGhkZLtsIdto+qOynnrY9PT01//3qadvd3V3x36JVbbefG21m287OThUNQ5FoTH3bBs+dAoGA/D5/zf9mfn97tfX5fLva7lXnW22TyXWNjoxqYKDyv9mWattCq9r2V/lve5C224O8mW2tGCOyuZzWgqGKdd5fx79nu2rrq4u9JBgMlpaf28mUtLC0rIyLb/Nwk0KhoIWFRRWrPazcND13FaZUS50vUedtoqY69wBCtk2YRvVB1zAMzS8suHOJSRcpFouaX1jc90b8cDji6ntjK6HO3aHWOvcCQraNLK+syKyyV1goFjVf5XYP2MswDC0sLCqzzzl6SVpaWmpBj5xppeY6ZwB3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5oufvvvd75a9vvnmm7nwCY5T7573hQsXlEgkam4PWGl2dlZve9vbyq6XOX36tL73ve9pYmLiQJ/txm3DcSF7ww03aHx8vPT60qVLevzxx2v63S9/+ctlr9/5znc2s2tAU9R79aTTzznBO5aXl/Vrv/ZrZas5HT9+XGfPnt21bnwj3LhtOC5k/X7/rkWkP/vZz+57NHv27NmyxyoNDQ3p9ttvt6KLwIHUu7d+7ty5ste/8Au/0OQeAfsLh8O65ZZbdPHixdJ7ExMT+t73vqfTp0835TvcuG04LmQl6ZOf/GTZNO+//du/6Qtf+ELF9ouLi/rt3/7tsvc+9rGPlR0RA06xfSAZGRnRqVOnqrbfvvqNpH3bA82WSCT09re/vWzRh5GREX33u9/VNddc07TvceO24ahH3W0ZHx/Xpz71KX3qU58qvfcnf/Inmpub06c//WlNTU1J2liI+jvf+Y4+9rGPld26MzU1pT/6oz9qeb+B/UQikbJarWXPe2Vlpez19nNQQCu84x3v0I9+9KOy9+6++24Fg0E98sgjdX3Wddddp9HR0V3vu3XbcGTIShtHs0888YQefPDB0nt//dd/rb/927/VyZMnNTw8rOnpaUWj0bLf6+vr0/3337/vZd+AHRq53WD7ajaS9Id/+If66Ec/qs7OTr33ve9lwRVYbq/rYj7zmc809FmPPfaY3vrWt+56363bhiOni6WNc7Pf/OY39b73va/s/WKxqEuXLunpp5/eFbBjY2N6+OGH9eY3v7mFPQVq18hAcvLkybLXL7/8su6++27dfffdXD0P13DrtuHYkJU2nqDzjW98Q9/61req/oMPDAzozjvv1PPPP7/nHhLgFPVePSlJd911154391977bWOWggdOAi3bhs+s94V+G104cIFPfnkk1pcXFQul9PIyIiuueYavfnNb+aRdnC15eVlPfzww1pZWVF/f79Onz6tt7zlLVzcB89z+rbRViELAEA7cfR0MQAA7YyQBQDAIoQsAAAWIWQBALAIIQsAgEUIWQAALELIAgBgEUIWAACLELIAAFiEkAUAwCKELAAAFiFkAQCwCCELAIBFCFkAACxCyAIAYBFCFgAAixCyAABYhJAFAMAihCwAABYhZAEAsAghCwCARQhZAAAsQsgCAGARQhYAAIsQsgAAWISQBQDAIoQsAAAWIWQBALAIIQsAgEUIWQAALELIAgBgEUIWAACLELIAAFiEkAUAwCKELAAAFiFkAQCwyP8Hy2YVR4b9ZIMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 480x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sigma_y1 = 2\n",
    "sigma_y2 = 4\n",
    "\n",
    "plt.figure(figsize=(1.6, 1.), dpi=300)\n",
    "plt.xlim(0, 2*np.pi)\n",
    "thetas = np.linspace(0, 2*np.pi, 500)\n",
    "# plt plot with fill between\n",
    "# plt.plot(thetas, sigma_y2/(2 * np.pi * (sigma_y2**2 - (sigma_y2**2 - 1)*np.cos(thetas-(np.pi/6))**2)), color='#555555')\n",
    "plt.fill_between(thetas, sigma_y2/(2 * np.pi * (sigma_y2**2 - (sigma_y2**2 - 1)*np.cos(thetas-(np.pi/6))**2)), color='#6D6E71')\n",
    "# plt.plot(thetas, sigma_y1/(2 * np.pi * (sigma_y1**2 - (sigma_y1**2 - 1)*np.cos(thetas-(np.pi/6))**2)), color='#DDDDDD', alpha=0.5)\n",
    "plt.fill_between(thetas, sigma_y1/(2 * np.pi * (sigma_y1**2 - (sigma_y1**2 - 1)*np.cos(thetas-(np.pi/6))**2)), color='#BCBEC0', alpha=0.6, edgecolor=\"none\")\n",
    "# plt.plot(thetas, sigma_y1/(2 * np.pi * (sigma_y1**2 - (sigma_y1**2 - 1)*np.cos(thetas-(np.pi/6))**2)), \n",
    "#          color='#BCBEC0', alpha=0.6)\n",
    "# plt.plot(thetas, sigma_y**2/(2 * np.pi * (sigma_y**4 - (sigma_y**4-1)*np.cos(thetas)**2)))\n",
    "plt.xticks([0, np.pi, 2*np.pi], ['$0$', '$\\pi$', '$2\\pi$'], fontsize=10)\n",
    "# hline at 1/2pi\n",
    "plt.hlines(1/(2*np.pi), 0, 2*np.pi, color='black', linestyle='--', linewidth=0.5)\n",
    "plt.yticks([])\n",
    "# plt.yticks(fontsize=8)\n",
    "sns.despine()\n",
    "# save pdf\n",
    "plt.savefig('normalized_gaussian_distr.pdf', bbox_inches='tight', backend='pgf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jaxdeck",
   "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.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
