{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 186,
   "metadata": {
    "id": "TUhafu59sh2x"
   },
   "outputs": [],
   "source": [
    "import torch.distributions as D\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "random_seed = 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "metadata": {
    "id": "PCgPd-DCtBe-"
   },
   "outputs": [],
   "source": [
    "gt_mean = 0\n",
    "gt_sigma = 4\n",
    "target_dist = D.Normal(gt_mean, gt_sigma)\n",
    "x = target_dist.sample((10000, 1))\n",
    "omegas = torch.linspace(0.0, 1.0, 101)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.manual_seed(random_seed)\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "n_means = 40\n",
    "n_sigmas = 40\n",
    "means = torch.linspace(-2, 2, n_means)\n",
    "sigmas = torch.linspace(3.0, 7.0, n_sigmas)\n",
    "sigmas_grid, means_grid = (\n",
    "    torch.stack(torch.meshgrid(sigmas, means), dim=-1).reshape(-1, 2).T\n",
    ")\n",
    "\n",
    "# compute NegLogLike\n",
    "test_dist = D.Normal(means_grid, sigmas_grid)\n",
    "nll = -test_dist.log_prob(x).mean(0)\n",
    "\n",
    "# # compute ECE with cdf\n",
    "x_cdf_vals = test_dist.cdf(x)\n",
    "x_cdf_vals = np.abs(x_cdf_vals - 0.5) * 2\n",
    "freq = (x_cdf_vals.unsqueeze(0) <= omegas[:, None, None]).cpu().data.numpy().mean(1)\n",
    "ece = np.abs(freq - omegas.cpu().data.numpy()[:, None]).mean(0)\n",
    "\n",
    "# compute ECE with estimated error cdf\n",
    "n_samples = 1000\n",
    "samples = test_dist.sample((n_samples,))\n",
    "median = samples.median(dim=0, keepdim=True)[0]\n",
    "error = np.power(median - samples, 2)\n",
    "true_error = np.power(median - x, 2)\n",
    "q_vals = torch.quantile(\n",
    "    error, omegas, dim=0\n",
    ")  # get the error values correspondig to the quantiles\n",
    "freq = (true_error.unsqueeze(0) <= q_vals.unsqueeze(1)).cpu().data.numpy().mean(1)\n",
    "ece_from_error = np.abs(freq - omegas.cpu().data.numpy()[:, None]).mean(0)\n",
    "\n",
    "# compute minMPJPE\n",
    "ms = []\n",
    "for i in tqdm(range(200)):\n",
    "    test_samps = test_dist.sample((10,))\n",
    "    minmpjpe = torch.pow(test_samps - x.unsqueeze(-1), 2).sqrt().min(1).values.mean(0)\n",
    "    ms.append(minmpjpe)\n",
    "\n",
    "minmpjpe = torch.stack(ms).mean(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 293,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/l0/5z9p4hy52cb1qp1y62gb48sw0000gn/T/ipykernel_65264/3759466756.py:28: UserWarning: The following kwargs were not used by contour: 'aspect'\n",
      "  ax2.contourf(minmpjpe.reshape(n_means, n_sigmas), origin=\"lower\", extent=extent, aspect=aspect, cmap=cm, levels=15, vmin=0.84, vmax=1.15)\n",
      "/var/folders/l0/5z9p4hy52cb1qp1y62gb48sw0000gn/T/ipykernel_65264/3759466756.py:51: UserWarning: The following kwargs were not used by contour: 'aspect'\n",
      "  contour = ax4.contourf(ece.reshape(n_means, n_sigmas), origin=\"lower\", extent=extent, aspect=aspect, cmap=cm, levels=10)\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 1050x450 with 2 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA7MAAAIICAYAAAC8ZLltAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAABcSAAAXEgFnn9JSAACWiElEQVR4nO3dd5wdVd0/8M+mJ7spJNkUCIZeDCUkVGmhKEFEelEgEEAQUJGfChoeBcGC5QEVxfLQFAFBfVCECNIhIC1AgIC0kJANJNnNQhppm72/P/LMZXZ2yjkzp8583q8XL7K7986cKffe87nfM2caarVaDUREREREREQe6WG7AURERERERESyGGaJiIiIiIjIOwyzRERERERE5B2GWSIiIiIiIvIOwywRERERERF5h2GWiIiIiIiIvMMwS0RERERERN5hmCUiIiIiIiLvMMwSERERERGRdxhmiYiIiIiIyDsMs0REREREROQdhlkiIiIiIiLyDsMsEREREREReYdhloiIiIiIiLzTy3YDiCi/uXPnYvPNN6///NBDD2HSpEn2GkRERESJFi1ahJkzZ6K1tRVtbW1Yu3YthgwZgubmZowfPx5bbbWV7SYSeYWVWSJSoqGhodt/xx57bK5lnXDCCbHLSzNp0qTY5wT/9ejRA4MHD8bYsWNx6KGH4tJLL8Ubb7yR2Za5c+d2Wc5pp50m/Ni4/3r37o3hw4dj3LhxOPnkk3H99ddj5cqVme047bTTMped9d+RRx6ZuR4iorK78cYbC7+fDhkyRHh9S5YswXe+8x2MHz8eo0ePxmGHHYbTTjsNX//61zFt2jSce+65OO6447D11ltj2LBhOPPMM/Hoo4+mLvPSSy8tvA3jx48vtiOJHMAwS0Ta/OMf/0BbW5vUc9rb2/H3v/9deVtqtRqWLVuGd955B/fccw+++93vYtttt8WJJ54o3cYiOjo6sGTJErzyyiu4+eabccYZZ2DjjTfGr3/9a9RqNWPtICIivTo6OvDd734Xm2++OS6//HLMmjUr832+vb0d1113Hfbff3/st99+eOqppwy1lshPHGZMRNqsXbsWN998M84//3zh5/zxj3/EmjVrCq97yy237PJzrVbD0qVLsWTJki6/u+222/DMM8/g8ccfx6hRowqvN2zgwIEYMWJEl9+tW7cObW1t+PDDD+u/W7ZsGc4991y8/PLL+NWvfiW07LFjx6JXL7m38NGjR0s9noioCkaMGIGBAwdKPWfQoEGpf//ggw9w3HHH4f777+/y+wEDBmDSpEmYOHEimpub0djYiMWLF2PBggV48MEH8corr9Qf+9hjj+Hss8/GCy+8kNmejTfeGP3795faho997GNSjydyEcMskcc222wzJ6t5I0eOxKJFiwAAN9xwg1SYveGGG+r/HjVqFBYuXJirDW+++Wbs79977z384Q9/wOWXX14f3jtnzhycfPLJ3TodRR199NG48cYbu/2+s7MTM2fOxBVXXIH//d//rf/+mmuuwV577YWTTz45c9kPP/wwNttsM4WtJSKqph/96Eepl5DIWrlyJfbbbz+89NJL9d8NGzYMF198Mc455xz069cv8blvv/02fvrTn+Laa6/F2rVrhdd58803c84MqiQOMyYi5Y466qj6t9yzZs3Cc889J/S85557rv4N9MCBA7Vc4zl69GhcdNFFePTRR9HY2Fj//QMPPICHH35Y+fri9OjRA7vtthv++te/4lvf+laXv33729928gsKIiISc/bZZ3cJsjvssANmzZqFCy64IDXIAsDmm2+OX/3qV3jttdew9957624qkfdYmSVS6MMPP8TDDz+Md955B+3t7RgxYgT22WcfbLfddonP6ejowOOPP46XX34ZS5cuxUYbbYRddtkFe+yxR+akR6q0t7fjkUcewfz587F69ep6u/POqtjY2Ijjjz8e1113HQDg+uuvx4QJEzKfd/3119f/ffzxx3cJm6pNmDABX//61/Hd7363/ru///3vxr/Zvvzyy3H77bfjrbfeArBhEqkXX3wRO++8s9F2EBFRcX/5y19w880313/edNNN8cgjj2Do0KFSy9lss83w0EMPdflcJKLuWJklkhSeVTYIPqtXr8bXvva1+iyF55xzDi6++GJ84QtfwPbbb49DDjkE8+bN67KcWq2GX/ziF9hkk00wadIkfOlLX8LFF1+Mc889F3vttRfGjRuHxx9/PLUt0dlz0yqLm222Wf1xl156KQCgra0Np5xyCjbeeGMcffTROP/883HRRRdh6tSp2HrrrbHvvvvixRdfzLWfTj/99Pq/b7nllszrYFevXo1bbrkl9vm6HHfccV1+Fq0gq9SzZ08cddRR1ttBRETF/eAHP+jy84033igdZAO9e/fG2WefraJZRKXFMEtUUFtbG/baay9ceeWVWLZsWexj/vWvf2HPPffE3LlzAWyYGCkIj4sXL459zquvvoqDDz4YDz30kJZ2z5o1C+PHj0+dcGnGjBnYZ5998OSTT0ov/xOf+ES9Iv3+++/jb3/7W+rj77jjDrz//vsAgO222w6f+MQnpNcpKzpJVGtrq/Z1utwOIiLK74EHHsDzzz9f/3n//ffHgQceaLFFROXHYcZEBaxfvx4nnngiXnjhBfTu3RtHHHEEPvGJT2Dw4MGYO3cubrnllvrw0YULF2LKlCl49NFHce6559bD3T777IPJkydj9OjRaG9vx5133onHHnsMwIZq5ZQpU/Cf//xH6ZDbRYsW4fDDD8eCBQvQ1NSEI444ArvtthsGDhyI+fPn47bbbsOrr74KAFi+fDk+//nP4+WXX8aAAQOk1jN16lRcdNFFADZM7HTCCSckPjY8lGrq1Kk5tkpeR0dHl5979uxpZL2utoOIiPK76667uvzMqiqRfgyzRAU8/vjjqNVq2HrrrXHnnXd2uzb24osvxlFHHYV//vOfADZMs/+Nb3wD1113HZqamnDrrbfiM5/5TJfnBNdxBkOBW1pacP311+PLX/6ysnb/7ne/Q2dnJw4++GDcdNNN3W5Jc/HFF+Pss8+uB8y3334bN954I84991yp9UyZMgUXX3wxOjo6cN9996GlpQVjxozp9rh33nkHDz74IIANQW7KlCk5t0zOa6+91uXn6G10THGlHURElN8jjzzS5eeDDjrIUkuIqoPDjIkKqNVqGDJkCB588MHYSZ769u2L6667Dn379q3/7qc//SkA4Pbbb+8WZAPf+c53sNNOO9V//tOf/qS03Z2dnZgwYQLuvvvu2Hur9urVC9dcc02XW7+Er2cVNWrUKBx66KH1df7+97+PfdwNN9yAzs5OAMChhx6q/H6vSW666aYuP++xxx5G1hu2atUq/OUvf7HeDiIiym/NmjWYNWtW/eexY8fyi0kiAxhmiQqaNm1abLUxMHr0aBx88MFdfveZz3ymHvLiNDQ0dLnX6HPPPddtKGpRv/zlL9GnT5/Ev/ft27fLffdmzpyZqw3hiZzi7rlaq9W6/N7ExE8AMH36dPzqV7/q8rtjjjnGyLoD69evx9lnn93lXro77rgjttlmm8znbr755l0m/xL5L7hmm4iIPjJ16lTp99Po51lbW1v9S1lgw3u0SQcccID0Npi6HR2RTgyzRAWJDImN3pbmlFNOkXrO6tWrlQaRbbfdFnvttVfm4/bcc8/CbfjMZz5T/3b6zTffxKOPPtrl7w888EB9uSNGjEisVhdVq9WwdOlSzJgxA1/84hdx+OGHdwnnxx13HCZOnKhl3WEdHR1YsGABbrvtNuy1117dqsM//OEPtbeBiIjUWrJkSZefhwwZYqchRBXDa2aJChg7dixGjhyZ+bjoY0SGkUaH2n7wwQdSbUsTDqlpNtlkk8Jt6NWrF0455RT893//N4ANEz3tt99+9b+HJ346+eST0bt3b+l1xJG5R+/EiRPr98RV6fe//33i0Oo43//+93HYYYcJPXbs2LHo1UvuLVzVviUiKpMRI0Zg4MCBUs8ZNGhQl5+XL1/e5eempqbC7ZKx8cYbo3///lLPkX08kYsYZokKEL22MzoTsUgAjj5n5cqV4g3LINru6Idx3jacfvrp9TD7l7/8Bb/85S/R1NSEDz74AHfccUeXx5k0YMAAnHvuubj88svRr18/o+sO22KLLfCzn/0Mhx9+uPBzHn744S7XNBMRUT4/+tGPulxWk0c0DK9YsaLQ8mTdfPPNmDRpktF1ErmAYZaogLwBKM/zarVarnWpWn+RNnz84x/HHnvsgaeeegorV67EbbfdhjPOOAO33HILVq9eDQDYfffdMW7cuFzLjxO9d2tDQwOampowZMgQbLfddthjjz1w1FFHYfDgwcrWGTVw4MBuE4D07t0bgwYNQnNzM8aPH48DDzywfq0TERH5adiwYV1+VjmaioiSMcwSkRGnn346nnrqKQAbZi8+44wzugwxVl2VffPNN5UuL4+jjz46dtIrIiIql+HDh6NHjx71SaA44R6RGZwAioiMOPHEEzFgwAAAG+7P++c//xkzZ84EsOG6nRNPPNFm84iIiHLr27cvdt555/rPc+fORWtrq8UWEVUDwywRGTFo0CAce+yx9Z/POOOM+r+PPvporcN9iYiIdNt///27/PzAAw9YaglRdTDMEpEx4aHE4ZkfTU/8REREpFr01nK/+93vLLWEqDoYZonImP3226/bxEybb745DjjgAEstIiIiUuOggw7CLrvsUv/5oYcewiOPPGKxRUTlxzBLRMY0NDTgggsuwM4771z/76tf/Spn8iUiolKYNm1al59PPfXU3DMbr1u3jtVdogwMs0Rk1HnnnYcXXnih/t9XvvIV200iIiJS4thjj8VJJ51U/3nevHnYf//98d5770ktZ+7cuTjggANwzTXXqG4iUakwzBIRERERKfLb3/4WO+64Y/3nF198ETvvvDN+8YtfYM2aNanPffvtt/GlL30J2267LR5//HHdTSXyHu8zS0TkoUmTJqFXL/m3cBfuv0tE5JKLLroI3/ve96Sfd/PNN2OPPfbo9vvGxkY8+uijOO6443D//fcDAFpbW3H++edj2rRpOOCAAzBx4kQMHz4cAwYMwOLFi7FgwQI89NBDmD17dq5tOOmkk9C/f3/p5z3yyCPYZJNNcq2TyAUMs0REEnr0cGNAy7x582w3gYioFBYvXozFixdLP2/VqlWJfxsyZAj++c9/4nvf+x6uvPLK+gz+K1euxF133YW77rorc/kHHXQQfvKTnwi15d133xVrdMS6detyPY/IFW70yoiIHLV69eouPzc1NVlqCRER+aRXr1649NJL8fbbb+O//uu/sNNOO2VOeDhs2DCcddZZeOKJJ3D//fd3mR2ZiLprqNVqNduNICJy1TPPPIPdd9+9/vO0adPw/e9/32KLiIjIV4sWLcLMmTOxePFitLW1Yd26dRgyZAhGjBiB8ePHd7t9HRGlq+ww47lz52LzzTcvtAx+D0BUfnPmzOny8xZbbGGpJURE5LuRI0fi05/+tO1mEJUGhxnnNGrUKNtNICIDHnvssS4/77TTTpZaQkRERERhla3MDho0COedd57w499//33ccsst9Z+nTJmio1lE5JDW1lb88Y9/rP88evRoTJgwwWKLiIiIiChQ2TA7dOhQ/PKXvxR+/M9//vMuYfb000/X0SwickBnZydmzJiBL33pS1i6dGn992eeeSZ69uxpsWVEREREFOAEUILGjx+PWbNmAQD23ntvzJgxw3KLiEi1k046CU888QRaW1uxcuXKLn/beuut8cILL2DAgAGWWkdEREREYbxmVsBzzz1XD7IAq7JEZbVgwQLMnTu3W5Ddbbfd8MgjjzDIEhERETmkssOMZVx//fX1fzc1NeH444+32Boi0m3gwIEYOXIk9txzTxx99NE48sgjM+8NSERERERmcZhxhjVr1mD06NF4//33AWyoyl533XWWW0VERERERFRtHGac4W9/+1s9yAIcYkxEREREROQCDjPOEB5ivO2222LvvfeWen5TU1PhNoSv32toaOB1e0REnvnwww8RDIRqaGhAZ2en5Rapx887IiIy/XnHMJti/vz5uP/+++s/56nKRieSKapWqylfJhERmVPWq3v4eUdERGEmPu84zDjFjTfeWP82oVevXpgyZYrlFhERERERERHAymyiWq2GG2+8sf7zpz/9aYwaNUp6OY2NjYXbEv1mWsUyiYjInCpUGPl5R0REpj/vGGYTPPLII5gzZ07957wTP61YsaJwW5qamuonRmNjo5JlEhGROdH38TLi5x0REZn+vOMw4wThiZ9GjhyJww47zGJriIiIiIiIKIyV2RjLli3DX//61/rPU6ZMQa9ebu6qe+65R+hxbW1twstsbW0V+l1zc3Pi7+IeL7KurHYOHz489e9xbRJdt0w74toiuu6sfRNdd9p6wv8OLzf87zzbUuR5ecStK7qfZI6tKqq2zwbR17yubWxubhZ+H8i7fFE62iG6/gsuuED5uqvo3nvvzf3cTTfdVGFLymXMmDG2m0DknJaWFttNcNb8+fMT/3bIIYcYbMlHWJmNcdttt+HDDz+s/+zrvWXb2trq/xWRpyMo2tGLPm748OGxneuk3xeR1sas9cX9LWs/tba2SgdZUUWCbBE6lx89PjqDURLd+08nkdeLzrDuSpDN83jTyyOyhZ12oq74mkiWFmRtcrPcaFl4iPEnPvEJbLfddhZbI0ZVpzvaAS3SIRWtzMRVc4cPH462tjbpznZra6vSjmbQjjzrF913actPCs1J61AVZGWem+c45aX6+IowuX2q1592/vpYdS5y7GVflzraQHYEHTBWaOOFO++s1FIVMcBmczXIAqzMdvPqq6/iySefrP/selVWReU1YHMoXtxjXelsR9uR1S6RCixQ7NjFrcNkRTbK5Ppkz1PR45HGdoW2yPqTRjr4RlWIZBitLpc7Y65oaWlhx54qg+e7GNffO1mZjQhXZZuamnDCCSdYbI1aeUKADBWdRFXVE5n1iaxLtkKbRGYZIoEjqFTaDLLh9bpUoVV9DgX7VWQbVZ3H4WMps/6o8Plb5SAbXp7OyyfIXazSigk6+KzUUhkxwIpxPcQGGGZDOjo6cNNNN9V/Pu6449DU1GSxRfkV7USrDAJ5Oo5FJo/RNRQ1bwjQHS5FgmzWPgkH0aLDk2X3U9HrhEWvrVV1XshsY5HzOGm/5P3SwMcQC+gLkLJfODDIlsv8+fMZaAVwCDKVBQOsHF+CLMAw28X06dOxaNGi+s+uDzEOUxk+k5ZVpPKWN9CmtUcVHbOuFg2wefZzWpAN/m+iQ276GlOVx05FoI/u4zznV9b6bV/Ha4qJ81Xk+ORth41Jy0gcq7RyWK0lHzHEyvEpxAZ4zWxIeIjxtttui3322cdia8SouB4wurw4KqqLeTuEzc3N3lRFRK6DzTpmOoKsSrqvB7ZFZr8nbVvSeSpzDovuN9/2ryzZW+8UnaxORTvCGGT94WPnzSZeZ0iuC85RnqdyfH0vZGX2/yxevBh33313/eepU6dabI06Ou/VaXpmWdPX08oQCbBJvyuyD9PWm7TOrOHGaWSrvOHl+VRJVHWNdFRWFVB2nS5XaIsc+7z3kM06L9PeQ+KODYNsdbBKK49DkMk1DK/5+BpiAwyz/+emm25CR0cHAKBnz56YMmWK5Rbll9aRYicrXt6hxjYnW7K9TNkvM5ImINIVHHVzJUi60o5A3LF04UsNkXNVxSUHfI/1G6+lzYfBlmxhgC3G9yALcJhx3de+9jXUajXUajV0dHRg9OjRtpvklKQOaLQqEvf38H9FqB5SHV12HjITAcUNNc1T+RENfqrWF0irLutStPIf3u9Zy4qbOThL9HFZXyTp2F8uBVlVZPZT+LimHWOR96Gi99lmkC2HMnTubOIQT9KN51hx8+fPL817HSuzJCwt0OocAqy7g2i6AyoSqpL2dZ4KZlBt0jUkXMWy06qzJoey59m/0eMV3R86zy/XgqzKCrvMeVW0opoVcEXawSBbLhx2rAYnjSJVGFzVKUuIDTDMei7pOi+Tt8IB9Fw/60vn0NQwWZUz7MrKOhamr592TVygrRodrwHZQJt3HaKPSVpHFY93VTDUqhENIgy3JIIBVq2yhdgAhxmXgKoQoTvwiC5D58ykcetzUTQY2LymVHQfiTwurZLoWpVRlopjJLMPfN9fonS+RjmMmESVtRNoC4eJUhKeG3qU+T2MldmSiFZW81ZadQ3Xc7GioXL/yFZnZe5n6tPkSFWo0KZto2uTMZmi+xx1aeSHyWHk5BZWafXg5FHVxtCqV5lDbIBhloyEj7wzBbsUDIL9VCTwx83kC2TPAGtLnu0sEjxcntk4brKzuO1MmrVZJZdeF6aOl8pAyxmLqQjOeKwPhyNXAwOsGVUIsgDDrPfCnX8XqrMqOvJxs8rKzBosIs81xdGfo8tICmIibZep1FJXKifLiipyrbCuUOtSkDWtaKBlCCVVWKU1g1XbcmB4NasqITbAMFsyKu6TmGc5Sdd4ynS808KHiWqXikpwONCmLStp9meXQq1rE4JFZR2rIiFXZtuzttXEuWuLjfM0z7nFEEu6sEprDqu2/mB4tadqQRZgmC0dVZMwqSISEJM6xHGd1qzliXR0k7ZPRdiIVpVF7s+btgxKlufLB137VuS8K3OolaHiSyOZQMsgS7qxSmtHXGBiwDWPwdUNVQyxAYbZkhOpsKro7MUNsS3aYVVxqw1VE7WI3Es37bpXkX1RphCbZ+ht3nu86qBqhEOcovcRduVa8iL73lSgZZAlkxhq7WPA1YvB1T1VDrEBhlnPhTuUtjtuokNsi5LpCKvcJzIhNu0x0baXKcQCYl9CBMewbNtehMy+sBloVR0zV0J5HpzNmNIw1LqFAVceQ6sfGGQ3YJitAJ1VpihfO6d5uVRN9E3Wfoies6Zv+WOyOpv3PDL1etN1ziYtV+bLKtO3/RKZDI4I4PW0LssKa1UIuwys/mKI7YphtiSyOlOudrh8DXa+tlu3ooEz7RxNGj6uk63hxiaXkbZsW/LOCh7QcczSzjlX31/JPlZp/SQS9FwOvAyq5cQQG49htgREO1HscKlRhSBr8jzJey9bwEyo1R1oVSxDZaD17fw2MXO2yPL5/kppGGrLh4GRTGKQTcYwWzFV63ClXatadHlFmOiA21yfCNMzbxfZftdfN6rv7+wi0dCu+jjJnDeunydkH4ceE5EMhthsDLOe87njpLPznDSzcN7OvsoQG/23rpAZPTdUrC9tGa7fKkUk0Kfd59eHoKL6/s6uSXoN6/qyJmmZWTObE6VhlZaIsjDEimOYrSAfOuV5yMwqbLqzL3ItqKrOuOitmFR2/lUF2bS/q2hvWugp0+Rloue5T0E2kBZoVRE91+LeS8v6/krqMdQSURRDrLwethtAdjQ3N1sfdlp0SGS4Iy7bKRd9vO4gm+dxqpaRZ31x543t80hWkVssJVWkXd0HadvkY5A1QeZYxp1LDLIka/78+ezAElUc3wfyY5itOFc74aKioVb2uUX+XgZFO96y50/W4/MGQ9nnpAVamePuw+sn7osf389t2+1vbW1lkCXl2Jklqia+7othmCWnK0u6JXWKdVwjq1vedSVdW5sl7zkjOjOs6HOCv6kKtFmC14up14yqc6gMITZMx7aouJ6cqCiGWqJq4GtdDYZZkhJ0iKP/5aX7OsWggpLW0Yy238cgW5RsW4sGOZlAKxJkwz8XHSZqU/h8DZ+3rrVTdFZh3e12JZy7dnyoHNjJJSonhli1OAEU1WVNXCJz/Z0Lk+nEVRyTgo4rnWLbsjrlqieNKrK+rL/JXKtsa2RCnmucbY+iCF7bw4cPd+J1o+o+u+H9Knv+kH7BPT3HjBljuSVmcZIoovJggNWDlVnqQlVH2XYnN6mDaarj6WMHN2smYZO3PpF9XlyYsR360hSpWvpwbsXdgkqnpFtxiY4iiQbZ6O/imKg8U3dBqK0aVnKI/MXXr16szFI3cVWJPOFUtGKiusIjcvsXU/d29Z2JQCh7K5OkIBt3HoneD9RUdVbV+WGrSuvCiIskKt5DVO9Pl79Q8VlVq7QAK7VEPmGANYOV2ZKIu9ZO5HpRQO8EUKYrtDaHBtoMsqrXbXpSMJn7eoZFw9Xw4cNzV2l1Hj9dVTwXq4Oys/yaDshJX3jESfqbyD5nkNWvqlVagJUeIpfx9WkWw6znRMOqiLihdiraUmSSKJ2ddZXLdS1QlJGpyqnq88LEueHr+ReuqvvC131dVlUOtAA7zUQu4evRDobZkss7s2v436JBNG81L2n5eTqNpm7PUnS9SYrcLkYl0x12leuLO59kly86qsElpmYPDvaviv1sS7jtaW3Oe9sq2cdSMS0tLQy17EQTWcPXn90vFhlmS0w04JjqdCVN0hKnSJs4vE8NUxXFIkM2RW6rVHQ7fAy1ukX3c9Y+ijt+tquxcYE2beKqPPvVp/OmDKoeaAF2qolMCV5rfL3Zf+/lBFAlZatCmSU8KZRMkJWdoEd04p88y05bp4r9aPNWMVGyEw3pOI+y1p02ckDHUHJXjk0ak21VtY9t3Oon/H4UvO5UhFiyp8qTQ4WFO9icLIpIHYbXj9gOsQFWZkvI9c52kWtoZZkOYa7v+7yyhmK6WL304Vpr3XQfl7zLtl2VDTP1ZQiZ5UonywWsHhEVx9dRVy69xzLMloyKMFWmWXkBPwOmieuFZeWZKbuovNskO6NunuX7FHRszt4tcwzzhtyixyMItKbvj0t68VrartgZJ5LH101XLr6vMsyWiI+hLUxn51FkcirXqrPsTOeTFmRV71MV1+Oa4srs3UWqsllfqKgKtHztlYtrHS/b2DknysbXSXeuvpcyzJZEUoAKQpzrQddU5zFrXzDQmqPqllLh5YlUZHUE2iLLdC3QZoVNW+dkmV8LpJ+L1QTbOIENUVd8TcRz/f2TYbYE0oKsyOPSmJ6QxZS0UOtioC06669LwtuStE2qJjCT/X0ReW7/45q0+77mCe15zsekdYtSUZ2l8nK5Q2YTO/BUZTz/k/nwnsnZjEssOiuu6My+RWTNVJwkayZgHSFN5P6SroXDcJuzvsRwMSyJEpnROWv7RP6u6/68IstVNfu1LJHtthnqVKy7yLGNrt+lyapIDc54nCzo0HMGZCo7htd0PoTYAMNsCaQFnCIVDdMd2qQQpitwyDzWtVArQvaLDFPCIS5ryHeR89kmmXb6cG7FDdXOanfWvYHjQmLc/WuJdGlpaWGgTcBb+1BZMcRm8ynIAgyzpSNSuRPpIOYJsuHOaZF7RoZDrcqOvorrGl0KHjL7x7VqrWhVMm97RZ+nozorw6XzCeh639UsRfdd2j2nXTlPqfxYpc3GYEu+Y4AV41uIDTDMei4tFOTtEBYNsuHfFanuujiJku3wU5Stoa1xfN6PZaZiRIbosY1blyvnJ1ULQ60YDkMmXzDAyvE1yAIMsxShKsi6QFen2KVAm6ctLgVaF7h0PKusjOckzyv/cOixGFZryVUMsXJ8DrEBhtkKsDmZS9HqbF66O8a+ByAG2q58P56yZLZX9tZGqmai9l2VzqeyYZVWDoMt2cYAm08ZgizAMFt6uoOkSFXWZKA1fc/OvB1WkWubdZO9jjaunWUNImRGWc8fBtlyYJVWHoMtmcIAm19ZQmyAYbakTIRH14YXq5jgCZDriOYJtHlmhlXdhrC0Kq3MjLWuBJOkdmRNblS16qwOeau9ZcHzp3xYpc2PwZZUY4AtpmwhNsAwW0LhIGv63q1JdFZni3aMi4bLpMfL3gLI9qy6RavFqocuxy2ryD5y7cuXsokeG9GZil2cKZwoiqG2GAZbyoPhVZ2yBlmAYbZ0RINs9O+6O5KuBllAzbaLdsjT2mtj2LLITNgiy9MdYqN/03W+2v5SwSSRbRX9QiHrnrJJy5MZ4l62e/eSnzj0uLhoQGG4pTAGWLXKHGIDDLOUm+g9KVUHWZeHKIoEMRttEAkDSY+J/k7n5FEy94cN2pLn+VnLrkoYSvtyQGRfFt1Pouel6GNtqso5Q6zSqsaqbbUxvOpRhRAbYJilQrICrcog63JHNotMSNPRKVZZAbMdZIs+R3S5roQTE8Nwo+vQFWSTzi/RZbkeaKlaGGrVY9W2/Bhe9atSkAUYZun/FOm8i1Zoo+uLSlo/O6/lZ+IY+x6ETARslSFWxRdZSUOafT6OVD4Mtfow3PqP4dWcqoXYAMMsKREXaJM6syLXaZaJ7HblmYAqypWqoghTQTb8f5F1ulSddYXJ/ZG2LlOBlpOGkQxeT6sfw63bGFztqGqIDTDMek71xDtFOqvhQCsbZHUqeuucImwNyfVlKKfu9SRts2io1RVoRW9ppPo2TkWE15v1Os+7XNnnyZ7n4XBq6t7XVC2s0poVF54YcM1gcLWv6iE2wDBLSqV1EH2pvKoKc0Xve1v0dj+iy7TBZDU26zG22yLbBhvHMS7IRv8NqAuIJr540Xm7MCKGWnuSQhZDbn4Mru5hkP0Iw2yJuNwxs1VhUl31AZKDmGi1TVR4H6kKXEn73VQ4MvWFRnR70o5N1j7Oc6668qVBUUkhNun1YaPyKRpo44YMM9CSbgy17kgLZAy6DKy+YIjtjmGWrDExS6tqpm+9o2uZRfZ5UhiUeQ5l03VP4qx1qqqK5g2KPr0fEIliqHVbVpDzPewyqPqPITYZw2xJxHUaZYfguTK5i8vS9qnNa3NNiu4D2UqnCdFQVuR2Q3nO1TyBP886dN7GKTjOwTrC18Sn7a+ilc68lXAd+0NmpnaXhvGTuzhJlJ9UhcGioZihtHoYYrMxzJacK7exsNWOvB1ME18CuBD6dFC5PUXOG5Fjb3Oiq7Tjr+O+xLLnW7DscLgNgmre4cQ677esK0jGbXMSH0ebkHms0lYXwyiJYogVxzBbAlmdyap3rFTc6iaOqv1qOugnTSwlsz0m26wr0Kq8p2oeKq+DBvRMmhS9bjtcpa0ahlpSjaGWiKIYYuX1sN0AKsanTqXNjl1ra2v9v6Kam5uVbws7vd2p2idxk4+5XA3X0TZV10gXnU1b5+PTqLxfrI5KNFVbS0sLO7BEFcf3gfwYZskoF0JbONjGBR1bXNg3Mny6xjrPlxm+HQ8ZRa7vNvkacTUMtrW1efVFIvmBnVmi6uHrvjgOM6bKc6nD7Mo1zrbZDpIqwnOeZem4j7DqCnf0HPV5NuuigVRm6DEVU6WJkzj8mKj8GGDVYZgtORv3fcyiMrCV8dq0rIl60rbVdGjQEb6Tts+HoJ82mZNr52je/Zk0U7Su7fNhluDweyuDrT5VC3lV216iKmCIVY9htsSinargZ1dCbVmpmqU4z+1GigRh2iDvPhK9/Y/uSaXCy4+uK++9X+PWE12+zu0rsmzT4ZLVWv2qVKUFGGqJyoAhVh+GWc8lhR0dHSkXq7wuUl11Vjkbs0u3q1Et65zUFS7yTmwUPQ6qJieLLjP8O5GZz2XaEXc+RbdP5fmUJ9Qm3StWx3sYA6w5VQx4VdxmIt8xxOrHMBvx1ltv4c9//jOmT5+OefPmYdGiRWhsbMTIkSOx+eabY99998WkSZOw55572m4qAHuVNlZ59RG972jeMJQUaG3ONluUyHmYFGqibAxr1bkvVR3vOLaGvMseI53vUwywdlWtSgt07RxXbduJfMEQaw7D7P9Zvnw5LrnkElx99dXo6Ojo8rc1a9agvb0dr776KqZPnw4AWLduHXr1cnP36a7KJv3eVrAty9BZk2Gy6JBQXUGlLMfSNdH7xaYRrc7aPlY6hjXLLJMh1h1VrlhWeduJXMQQa56bacywJUuW4JOf/CSef/75+u9GjhyJPfbYAyNGjMD69euxcOFCvPTSS86fpDY7WKLVWpVByHaHuijb1U2ZCpdoWzkZjphg36s6B1QOH9cxBFoXG1/M8Lx2UxWrtAGGWiJ7XM8Gutne/sqH2dWrV+Oggw7CrFmzAADbbbcdrrzySkyePBkNDQ3dHv/666/j1ltvRY8e5bpFr8qhlaommfGVyx3/OKqGocYdc9GhvUXInGsm2iPDl3PFhy+N0valbDhPez906fyh7qoe6qq+/UQm2Q5xLnBhH1Q+zH7729+uB9ndd98d9957L4YMGZL4+G222QaXXHKJodbJ0dXJyrPcqgZaX8JJVNF2px1rlQHS1O15fLgdTMCXdtpk6nXJY+GOKldpAYZaIp1cCHC2ubQPKh1mX3/9dVx55ZUAgAEDBuDWW29NDbJESXwNsUWJfmEhEmhNBQHXqrN55dlfPoV02+L2Vfi84X50HwMdJ4siUsWl8GaTi/uhXGNlJV1zzTXo7OwEAHzuc5/DFltsYblF+RXpnIdvAaNSXJvKGPp0bVNbW1uX/1wj26Y825AVGFzcL7o1NzdL36op+C/4meQxyPrLxc6XDS0tLdwXRJL4uvmIq/uhspXZWq2Gm266qf7z8ccfb7E17rJRwfJhJlUgvp1x4SrPPky6/rTIMlUpEiDzVEV1DC1WVZ01HQxV3m9YdnllIHKLKyonVmk/wn1BlM3V4GaD6/uispXZV155Be3t7fWfJ06cCAC4++67ceyxx2Ls2LHo27cvhg8fjokTJ+Kiiy7CW2+9Zau5mWSGe4ZFO3fRn21UvrI6l+x8mjsu0epw0fWmBcik++uGf28yPLpYwYzuj7yPyfPYqqviKIAyYpXlI8G+4P4g2oCvie582BeVrcw+/fTT9X83Njaid+/eOOqoo/C3v/2ty+OWLFmCJUuW4LnnnsNVV12Fiy66CJdddlnsTMe2ZVXusoJs9PdBaAyeJ1vJKtL5i1bjXAuwZQ4Aujrtuu5/XMWQkfTayHteVuVa2uB9RWRb4x4TVPST9nMV9mFZVH2CqChWa6mqfAhrNvi0XyobZt955536vwcMGIBjjjkG999/PwBg9OjR2HfffTFo0CDMmzcPjz76KNasWYN169bhe9/7HhYtWoTf/e53Qutpamoq3NaVK1dKPycaQEWDbPQx4c5Z3lBbhO+dQ98mGrIdZNOCho0vEHwIear2iw/bqoLObSzzl1wibH3e5cUA1x0njKKq8CmsmeTjfqlsmH3//ffr/25tbcX999+PhoYG/OAHP8DXv/519Or10a5paWnBlClT8NBDDwEA/ud//gcHHHAAPve5z2Wux+QHc5y4cCLT4Yq7tk4k1BZdb3SdZRNsm0udX9tBNlCWUKXqulxTtyMiMWWZDVsH2593eTHUxmOwpbLxMaiZ5Ov+qew1sytWrOj2u8suuwzf/OY3uwRZYMOb+PTp0/Hxj3+8/rtLL720PhOyT4oMQ4xyeaZdl6kIaqo7064E2UDWtdwqiG5znnWr2p+mQz2vod1AZBZtvu+Vj68dORN4LSH5iuduNt/3T2Urs/369evy88iRI3HRRRelPv6HP/whjjjiCAAb7lE7c+ZM7LbbbqnraWxsLNxWFd92q+igps2Ayo5ddyJBzoWqm2tBNuBShTauLSLHrUgVL7w+0+dJkevVqzRjMN/3unLl864IVmmzsWJLrvM5mJlUlv1U2TA7cODALj8ffvjh6N27d+pzDj30UPTr1w+rV68GAMyYMSMzzMZVgGU1NTUV+oBX3Ql2KWT4Jm6/xQUVUxMbuRpkAyLnrmuTQEXb4vuwVJFgKzLDctYysp5r6j2H7235ufB5pwpDrRgGW3JFWYKZKWXaX5UNs8OGDevy87hx4zKf07t3b2yzzTZ48cUXAbh/Iuis5FT1PpUuUBWMVAdAnwObCJNf4rj6utI9wiNtHSb2v6v7nexhqBXHYEumud4Pd1EZ91llw2z4+ldAfBbGcEV3+fLlStukisoQG11W3FDLqnUA0/ZvUCV0PdgxyJZL9Hj6cDxk3qdsv8f41FbSg7fykcNgS7qUMYyZUOb9Vtkwu+OOO3b5WXR4VDjADh48WGmbVFE5U27WPSyr0nGT2Zd5Zu+VUTQs6xiSa/q2TbaGFZv68qaKXxIlMbkfovudM7BTGKu0+TDYUlFlDmK6VWHfVTbMbrrppthuu+3wn//8BwAwe/bszOd0dHTg9ddfr/88duxYbe1TQfWkMVXrqOkYpq0qpOQNtLpDoM6qtCvXxWadF9FreIvO6Jz1OnZlv+hg4z0nz+u+au+NVcdQm1+0Y819SHGqEMBMqMp+rGyYBYDjjjsOl19+OQDgrrvuwrp161IngZo+fXp98icAmDRpku4mFqbzfqZl6sCZnik267iIBBSZ4Ggy8KgOtD6GNZXDzWXPTR+GGIvw4f3FhzaSPgy1xTHcElCd0GVK1fZnpcPs2Wefjf/+7//Ghx9+iIULF+InP/kJpk2bFvvYNWvW4L/+67/qP+++++7YYYcdTDW1MFZpN7B9G5yAqna4GvRUBDlTsznrCn+uh8qs17DN10q0bS7cwirK1/dAUo+hVh2G22qoWtgypar7tdJhdpNNNsE3v/lNfOc73wEAfPvb30afPn1wwQUXoGfPnvXHvfvuu5gyZQpeeuklAECPHj1wxRVXWGlzES52CHXQtY2mrws1LbpdRcNkkaDoakh3jcx+kg1fNt4vkm5dlfQ3wE7oZpClOAy16jHc+q+qAcukqu/jSodZALj44ovx/PPP44477kBnZye+8Y1v4KqrrsK+++6LQYMGYd68eXjkkUewZs2a+nOuuOIKHHDAARZbnZ+KDqpLHTkTHdmy3Tc0Ttz2xP1ONmTm2VdVCbI6LgFI2td5X7M6L1NIWlfW77IeU4Uv7MhtnPlYn7hOO/e1O6oeqkzj/t6g8mG2R48euPXWW3HRRRfh6quvRmdnJ959913cdttt3R47ePBg/OIXv8CUKVMstFSdIoHWdpA11VHNClRpIc1kAChKNmgGj5cJnEWu7a3C/Yx9GDGh+5yOG1ZcdFmm2pqmbF96kThWac1hwLWDQcoe7vuuKh9mAaBv37742c9+htNPPx1/+MMfcN9992HBggVYtmwZhg0bhu233x6TJ0/GF77wBWy00Ua2m9uF6qGhrnElvCY9J7r/wx1d10NKkY52dMbeLFmBNm5Z4X1XtlvVqLgmVHT/q9xvOs5pkfbJnm/Bcm2+/hhkCWCotSWps8/jII/ByR08FvEYZkN22mkn/PSnP7XdDCllC69hNoYQF1U0dPky67Cq8C+zrDIF2qL3MwXyBTwfqDrGtr9IKuOxofwYat2QFQaqeHwYkNzHY5SOYbaCbHfysrjevkBWEBTdjqROb54hvbqpmBQKyLdtuoKsrYm9fDnPAz60N6uNPl0CQOXEUOs20dDgw/FjAPIfj6EYhtmKKdqJ010dM93JzFvdSgs+RUOsSbbuVSuyrPAwURMV2TJO7KWK7fAncr7ItNH2EGQihlq/MWSQTjy/5DDMVojNzlvWuqvWsczqnIdDle7hpHmuZy2rtG2tYtDV/bo0OaRY1b1ryzTcnexjqCWiAENsPgyzFeFqWHShXbJhsWio8SUcutBOl0JDeH9UIdiWKcimtUHHdrrwvkZ+CXdiGWyJqoUhthiG2RLT1aFSVZlwqcNnajIdkXUk3fPVVHXWhRDrOlvX2UZlnRd5XqcuvS5NyHMdbdx7YNX2m2nz588HAGy66aaWW6Ifq7VE1cAQqwbDbImouHesqSqFrx2/IuHF9ZDoevtcpGJGaNuBOMzU69J0VVZkfXmqtL6+j/mMoZaIfMcQqxbDrOeKdqbiriNTsVwf6QwVokFRVxt4nZ8+soE2ei64Emp9e81H26tisjCZQMt5AOyaP39+JQItwFBLVBYMsXowzFZYkU5fkXBUtU6eqopnnqHGLu9rkzMViwrvL5l2iQTarGNnczZll8+TOElBNo7s+VX0Olrf9qXPqlSlBRhqiXzEAKtfD9sNILOam5vr/xUl0mljx05OWuApGmRdOxaqzkMd8rSrra0t9hgl/d4EF1+jWftWdXtMDx129ZwusyDUVkVLSws7yESO4+vUHFZmPZfWccpbZZKdCCVp+UnLqdI9Hl0OMdSdiiBiczKtuOpu0igKl8+RtJEfum6nI7vctPexKr3HuaJqVVqAMyATuaiKAdb2F4oMsyVmskIQDrVl7sSZuL4xLpBwcia/mDpeSZVgoOs5Gg5zvrw+ZWYMLvK+k+d5QbsYaN1TxVALcAgykW1VDLGA/SALcJgxRRTtfKmcXdQ14eCge+hodF0y2IHWa/jw4Vq+zFC9zOh509ra6t25EW6vSNtFR6oEP/u2P0icCx0sGzi0kcic4PVWxdfc/PnznXmfZWWWrDFRuQh36HXcVidt0p6iYTfP8010zqPr8PGLiTyix9nUvYmLsDmplCoqz2kdr4+s6izZU9UqLcAhyEQ6VTG8BlwJsGEMs1Rno0qhK9AmDb+U7diLhJU8Q491XFNpq8oUt16VnXgXbiuUdGxtBlrR9eoItKq+JFLJ1Dli+1wkeVUOtQCHIBOpUOUAG3AxyAIMs6Uh0qF0tYqkMtCK3P4E0LO/wsuOe27cOn2o7oXJ3IMzq9MvEuhdGAZqO6ypeH2IBto819WWofpbFK+P9UOV7k0bh9VaInkMse6G2ADDrOdMVwNlOmwyFYwincE825PVAS+yj2SrVqaPi6l1pAXa8H4RCfQ2qrOiry0VX0ioCINZ+0jmi5y016PopFNlxKqs/6pepQ0w2BIlY4DdwPUQG+AEUKSN6xOspF0Hq4LJjn3ZO9ll3z5Zceeo6D7SFbyrHmR5jvrFpclLbKvqBDZEYVWezCmOT++PrMxWTFpHVqQ6mmcYou6qWpHKmM4hkqIVWpPDjIscizzVc5H1ZZ2TtrgyfFbXNeVp2ya6zjz7J+3e1K4SbSuHG/uHldqPsFpLVcPg2p1PITbAyqznVN8iRqbTJiOrg1e0A6hqpmJdwTI4TtHjZePYFdnXqgJIsN2uXy8sMwFYXjomJctLJsQWDfpp6wpGddge3dHc3Cx9zvsU0ukjrNR2xSoVlRXP7Xg+vweyMlsSItesiXaCRasLslWIpCqdqs6qT5Mp6WqnT5Uhn46VCxVawMw+M3n+qJxQTKWi6/LpdUhdVX2SqDis2JLvGFyT+Rpgw1iZLRlVnV2ZCm2Rjp/qDl/e0KG6wm2TyPFwoTrrE93XVxdpgyvL001nOAzex4q+n0WXSX7yuUKhG6ta5BOeq+nK8j7HymwJxVVp83RcZaoLoo914Z6hVSByPIpePxssg/JTVfHVcd9iFxV9/zD93sP3Or/xetp0rNiSaxhcxZQlxAYYZktMRcdWNtACYtfH6hyGp3O4sWthPO0LCxNDHas0nDI63NhUcExbTzQMy577Lg2hFpX3NejS65b8wlCbjcGWbGGAFVe2EBtgmK24aEc26ZYfsveX1T3hUxafrp9NkjXra9EgE6xD9/WBedeRFLJsHtci4U/1RE9Zt8jx/fxPI3tOMciSCgy1YqLhguGWVGJ4lVfWEBtgmPWc6qCQJE+gDdiq3PkaaFXuL93DjWXWIyPt/BT5AiaOqlvC5A2ZKpYts3zR8990dVam0pxG9LxlkCXVGGrlsGpLRTHA5lP2EBtgmK0okdmPVbA9BFV1lUp3xzhuf+kc2lyGjr7slxbhfaxj+2XDoey5Kbp814Yb2wrWrl0aQOXBUCuPVVsSwfBaTFVCbIBhtuJEOph5A6ntIBvma5U2EFdVDH8hEbdtWftfRQfflWOc9/hG26/6Prq6ZIW+POvXGWh17A8GVHIFQ21+DLcEMLyqUrUQG2CY9ZzODp0rQUUV1wNt3tmgo9skeo/gvGTPizzrUh2sZO5nCvgRlJL2UZFzXMeIDQZZqgqG2uLiQg0DbrkwuKpX1RAbYJilblSEWBXL0DFTrquBVmY70wKX7mps2b7gSOLL0NRo+FR1boeXU+TezTqYGurvw/EnNzHUqsXqrd8YXvWpeogNMMxSnaqgoirIBv/3LdDKdoaLDuMW3Ue+BVnbt43xKdToPJ9Fg62JL4lMXrPuyxca5C6GWj2SwhFDrl0MreYwxHbFMEulr7bF3f9WV6CNdoajbdChjEHWJT6FWt10B9aksGxj4rUsro7yIPcw1JrBkGsGQ6s9DLHxGGYrTvX9Y1WIdlyLrDe8LN3tz7rXarQ9Wc9xhc02ylRn806EJYqVOn+lHbvo+REd8RD3vOCcrMI9fUkdhlo70sIXg248Bla3MMSmY5itKNsBBYivwiR1OJOCaFrYiVtWeDkqKyuyEwyZZHKyJx1sDzcOK3uV1sXtMzmqIW6YsciXGKzSkgyGWndkhbayhV2GVL8wxIphmK2YpHBiquoU7vAVDSnBsuKWI7otRTuhRSrGKoJie3s7AGDo0KGJ68lL5bXPRbkUaAFzQ8hNSQt1Zdi+qLTtTXp8GfcD2cVQ676i4U9HGGYgLT+GWDkMsxWS1mET6aiJ3jomieg9bfPM0hsNO6KdTxvVlPDkVkCx0JgUYsPLz8OFimyUa4E2oDvo6LoXbnSZcce8TAEu7TiJfLmU9nxWZfVraWkpXZUswFBbXgyeJIMhNp8ethtA5dDa2mo9AIncbzX8u6Id0Dz3W00a+qyaC0FWZGimrLa2tsTjxkBRTNy16j4I3ntMDvWPjjAhM8oeDObPn1//j4iqga/74hhmK8LWxEdZRCbsSbpWVmR5SbML65woKCopxEYfo3J9eZn6QiI6gY4s1wKErv1m+gui6KiBJMOHDzdWJU/6UiouwIpUV1W1Je2LFdKnpaWl9KEWADu3RCXH17g6HGZMhdiuxsaJG3Ic/XsSlUNGZZej4jpaU0FWZfjOe91y2kRiZWDrtZV2bKP7WvVsvklDyWX2Rd7XsKnZ2kmNINCWdehxgEOQicqFAVY9hlnPiQQBHR003Z2+8EyieRS5vlJkRtesduUNe6puQyRLdJ0qQqzq8OlKdazskwSlHTfXblGj4liU+ViWSdVCLcBgS+QbBli9OMy4BExXplQH2aQOcNH1xC1XZl2y1wEHw4lVdKLzVHXzEN1GFduVpqzV1bxcqxDK3OvXFhVBWtVEeGReFYYeBzg8kcgPVXqt2nwPZmW2JEzc59CVTpzMdoYrtHn3T7TKo+K2JSJtEq3SFgmyIlQPKXZV0jGWUcbqrOwxs1GlTboGvmzHgtJVpUobYLWWyD1VCa9htr9MZJgtOVUB1JUgm4eKYdjhocdFA2z0d1mBVgcXg6yJL2TiuBZ4XHqtJR0zkdtKmTqeafeu1hVoGZTdVrVQC/DaWiLbGGLtYZilVCo71kmdW5erdWXkUlhyVVpVvL29PfX+vgw6H9EdaJMuJSgSaEUfK3JtPdlV5VALMNgS6VbFAAu4E2IDDLMlIXKPVVk6Qk+4c5v3PqO2FO20xm236sm7ikxapVt4W6PHXudxzRquHRdK0h6fFmRVEGmvqQClYnZh2UArM3lb3LKT2mtilAODrZtaWloqFWgDrNYS6cEQ6xaGWc/pul9q0Rl1s4Yf5qEr8Ihcm6qykyq6HXmOgerAqisEuDLrbZjKfac7cLoQaF1R9AsylRhs3VXFKm2A1Vqi4qoaYAOuBlmAsxmXiuzsu2nLySPcedM9+62M4cOHF+rk2tgO21XUMBdCdVFlPIYm93HRLx90h0yR17jpc1LV+zGp1dLS4nSnTLcqza5KVFTweqnya8aH90xWZkvC9kRPSWGhyH1Tw/J2pot2ok2HIFc7vyKVwGjboz+78uWGSXkrqKKvG1ZoifKpcqUWYLWWKEmVg2uY6wE2jGHWc7ZDLJAdUkSGHpsge+0eg2xXabcoEn1+mOn9q+qLFVkccryBrdmqwzg5F0VVPdQCDLZEDLAf8SnEBhhmK65o5152ltA861NZlU3qUEfbxiAbT/V1pSr4EE7yhCiZ14vJWy0VuT6VgZZcxVC7AYMtVQUDbFc+htgAw2wF2QwRpqq0Pl0j60uQdZXMlxC2qrNA+UJUVpXW5r7OUrZjQeow1H6EwZbKhgG2O59DbIBh1nMy9zp0qWMp2tHVUcVJq86aVuSYtLe3d/lZ9y1jfOD6vT/z3PPU5VmW8wRaF6qzQPF94dL7KanHUNsVgy35igE2WRmCLMAwWxpxHatoR82Va1dtc6EjXUQ0xIZ/70ugDbZBV3tdDrV5Am3wvKJc2B8uvf7yBtqqv4dWCUNtdwy25DoG2HRlCbEBhtkSEp2QCSjWKcsTGGTXl7eKk3Rdn0sdaSBf5W3o0KGJgdZ14XabCN7Rc9SVEJL3Gtrw812QVpUt0kaTMydzyDGJYKiNFw0NDLdkA8OrmLKF2ADDbIkUuYYVyN/5zHPbFlPCnWLXgmxA1VBSl6uytsO3K+FPFReDrQhXX4MyfNrfpB5DbTqGWzKFAVZcWUNsgGG2JNLCpGhYKhKqkgKtio5f0WvsytCBjvKlOlu0jS5PIlSUqoqgraqibOW0jK9Dqi6GWjEMt6QKw6u8sofYAMOs50SHFIsOsywyHLOsocOEosONXarKqg7ZDLTuMTEE2ORQY1Gy56GPx5bkMNTKYbglUQyv+VQlwIYxzJZUUidKJtS6FCBcmQFVJ9f2uQzZAOtS+LbNt0CbJ2C6/trVcQx8OqZUHENtPgy3FGB4LaaKITbAMFtCIp0okVDrc7iS5cp1tbL7XHS4sa4JkHQOdQ6fx2U/F30JtC4HWZfOER+OJenBUFtMXKBhwC0fBld1qhxiAwyzJZN3htSkTqBLHcS81VmZoJC1DhdDR1aVU6a9PlyHW1YunlsBW8N9XRpqLPo+6OoxJLMYatVh9dZvDK56MMR+hGG25EQrjmmhVWWgjbZDV0c12t602wi50lkO6PwCwYUvJ0SGGFc1ELgYaF2uxkbpmMROdv1EYQy16iWFI4ZcuxhazWCI7Y5htuREO5UmrqGNa4uuyktce32eOVaVIscwGkJ1XifrYqgzxbVtz/MatTVsv+h7VNy+Z0WWVGCo1Y8hVz8GVnsYYpNpC7Onn346xo8fj5133hkTJkzAwIEDda0qt4cffhgHHHCA9PNWrVqFfv36aWhRcWkVyKTHinKhqidDtL0uDWUE1F/XWiQcpQXQ8N/Sgq2KyZ58Ou9UCG+vCyEpCKV5Qm3RQCv6+lR1jnDGYtIp3CFlsDUjK4Ax7H6EYdUtDLBitIXZG2+8EQ0NDQCAr33ta/jxj3+sa1UUIy3AFOn05Q20tocdVr3DKTuplKy4YFs0xPK4baBqP6gYqZAn1JZ5JnKen1QEq7VukAlwvgZfhlS/MMTK0TrMuFar1QOt6wYOHIgpU6YIPbZXLz9GZ0c7wVWrbgXY4RSnooqq8rY7VT1no4oG2rj9KDOKI0p2NEPRQOva6AmA7yumBZ1xX8NEGoZafzAUkk4MsfloTWVxQXbOnDlYuXIlevfujc0228yZ4bpDhw7FL3/5S9vNUE5HGLA13NhEdSdtHSauA2R4oyR5A23WOZU31JoOtC5hkLVn/vz5pQy0AIcgE1URA2xxRkqML7/8Mo4//njcc889WLlyZZe/bbXVVvjUpz6Fww8/HJ/61KdMNIcUkAm0WR1YF6suYdG2lalTXgaywcLnLwxkA63MtuYJtSZfu0XXxVEq5VHmKm2A1VqicmOIVUd7mK3Varj33nvr/45644038Oabb+Kaa67BVltthQsvvBBnnHGG7mYRdRHtKGd1mm3N1kofyVsd820isyjRQFvkFjWAnuqjjS+C4rYj6xxw/Qs22qBKoRZgsCUqA4ZY9XqYWEkQYtOun63VanjjjTdw1llnYf/998fbb79tomlUgEhn17ewN3z4cOmhk6r4ErBsD7Fsbm5Wcj9Q29tRhOjQ4aLrEJ0NXEaR14zMurKOcdLfgnUkrcvn86as5s+fX4lrGVtaWtgRJvJQ8Nrl61cP7ZXZIMDWajXsuOOO+OQnP4nNNtsMtVoN77zzDmbNmoUZM2Zg9erV9cc99thj2HvvvXHvvfdixx131N1EokI47JjKTKQSbKqSKboOFYGTlVn/VKFSC7BaS+SLqoRX218mGhlmPGDAAPzhD3/A0UcfHfuY1atX4/bbb8dVV12FWbNmoaGhAQsXLsTBBx+M559/HhtvvLHuZqKjowP33XcfZs6cidbWVvTp0wfDhg3DzjvvjL322gtNTU3a25CH69eBiQa9rM6wqcmfbHZgfRn+aruNKobB2t6GorK2Pfi7ye0UuW1PkdexzGtT5D69Sfsmaz0y1y2zimtHVUItwGtriVxTlQAL2A+xASOV2e9///uJQRYA+vXrhylTpuCUU07Bz3/+c1x44YVYv349Wltb8bnPfQ6PPPKI7mZiwYIFiRNQ9e/fH1OmTMG3v/1tbLLJJlLLVRGCo5NmJTHdgfU9EMTJG2hZnTVP52RILpPZZhtfkMS9hkyF2DhxwdbEPqlikDX5eSeizDMfR7FaS2RPlQJswJUgCxi4z2zPnj1x2mmnCT2+oaEBX/3qV7HddtvhiCOOwLp16zBjxgzccccdOOqoo3Q2NdWqVavw29/+Fn/5y19w66234pOf/KTwc1V+MIsy0WHTsWzbldGiGGjNK0tAFZUnINms0oow+ZpXtQ+K3ve3rGx83mWpUpU2wGBLpF8VAyzgVogNaJsAqkePHmhoaEBzczMGDx4s9dzJkyfjiiuuqP/8k5/8RHXz6pqbm3HuuefijjvuwFtvvYUVK1ZgzZo1aGlpwf/+7//isMMOqz92yZIlOPLII/H0009ra49Krkxy41tAtVlFsq29vd34+rL+o/JOeuXq60XFvia3VGWSqChOPEOkVlVfTy6/hzbU4u6Xo8CwYcPw/vvvY9SoUXj33Xeln79+/XpsvfXWmDt3Lnr06IFFixZh2LBhStu4YsUK9OnTB3369El93O23346TTz4Z69atAwDssMMOmDVrFnr0yP4uQPWwq8bGRqxYsaL+87Rp06TCl6pZTmUVrdTYqHjm7WgXbautamMQHIcOHWp0faJMtcs1OoKR7DmmK5y5GGZF5yFI2ifR3//ud78DsOGzIHgvj76Pl4XOz7tx48YVXnZYlSq1UazWEsmpYngNyATY2bNnAzD/eadtmPHQoUPx/vvvo62tDStXrkRjY6PU83v27ImjjjoKV111FWq1Gh5//HF89rOfVdpG0Q/e448/Hq2trfjSl74EAHj55Zdx55134sgjj8x8rooDGD4p4oQ7hFlBysaQQ8D9IbhxkwpV9frZ9vZ2J4Ojq+3SSVeIdGGyMdeDbPjnuH0lMtTYxW3UycTnnSpVHH4c4DBkomxVDrCAm8OJk2gbZhzcUmf9+vWYPn16rmVss8029X/nqe6q9MUvfrHLm/7dd99tsTXJgvukZnWi8g45NNEBNh0Ew9ukavvCx8GHDq2N4cV5n8ehx2roHgorep9ak9LuHRveH3GhVmR/hR/jw+ue3B46ZwKHIRN9hK8HP98TtYXZT3ziE/V/X3755ejo6Ci0vA8++KBgi4rp2bMnDjrooPrPr7zyisXWiBHpTJmcDbZI5y4aDpP+k5VUcQmoCtY+BVtAb7hVsWzRZfh8Da6J6y5lA5qIaIiNe42Zfh20tbXVX8uio1fitjst1PI6Wb/52IFTjR15qprwOV/1897n90Btw4w///nPY9q0aVi/fj1mz56Ns846C9dff73UMsKBcdCgQaqbKC18v1ufh5HqInKtWdIQXFWdWxX3uIx2SlXNsiyzftsVLV3DeVWGyaRhxz4FVhekDaXNE2STfu9q2CsyQ3SRZZCbqjz8OCzasedwZCqLqofWKF8DbJi2MLvxxhtjypQpuP7669HQ0IDf//73WLJkCa699lqhD/729nb86U9/6rI828LXA8leA2ySrgmh4kJWVpXChapMGtHgKBtoffuyY+jQodongNIRMst8Ha3pABh9LeQNeTpeT0WFv0RTvV4G2XJiqO2K19mSzxhguytDiA1ovc/sz372Mzz88MN4++23AQB33XUXtt12W5x//vk488wzsckmm8Q+b+HChTjuuOPqnaKePXti//3319lUIc8991z930ltt0k2QOWt/sl03lyoMsrI0zHVEVxt7DefQmzedfkWfIuGS1nBeadrBmUVE6zlJTsxm8jrL20/+X7fbNqAobY7BltyHcNrsjKF2IDWMNvU1ISHHnoIn/zkJ/H666+joaEBH3zwAS677DJcdtllGDduHPbcc09ss802aGpqwooVKzBz5kzceeedWL16NQCgoaEBhx56KDbaaCOdTc308ssv49///nf95wMOOMBia7rKE6ZMBNnwc/LezkdlZzCpMytTTVLZFtXLdJFLQ359C7JRWeeoqgCqMzS7EGjDimwrK7LVEu4AMth+hMORyRUMsOnKGGIDWsMssOFN/4knnsA555yDP//5z2hoaAAA1Go1vPzyy/V7EoXVarX64wYMGICrrrpKebtWrlyJAQMG1NeTZvny5ZgyZQo6OzsBAP3798fxxx+vvE15mAyyRdi6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UGtXFYItwHBL5BOGV70YZgX16dMHQ4YMwcKFCwEAy5cvt9wiNfKG2jQyQTb6GJnqo+wQ26Tn5JnxNS7EA3qGWSetM6Di1ill63jrDLFFjqfuSqMtooHW9e3K8+Vg0ntoFb4scl1Vgi3AcEvkkiqFVxe2tYftBviitbUVixcvrv+8+eabW2yNenkrvCJUVGJUdYJFAorJ23iQei4HiDKfM21tbc7sexv7Oe491HZVnz7iQofLpKptL5ELxowZU6nXnivbysqsgM7OTnzta19DZ2cnAGDgwIGYPHmy5VapJxpogwlNkn4uSvXyiIhM0PmlYNUdcsghtptAREQOYphNsHbtWixcuBBPPPEErr76ajzxxBMAgB49euDqq6/GkCFD7DaQiIiIiIiowip9a56whQsXYvTo0amPaW5uxg033IDDDjtMeLlNTU1Fm1af3jrQ2NhYeJlERGRO9H28jB+9/LwjIiLTn3eszAqaOnUqfv7zn2PgwIFSz4seUBV0LJOIiKgIft4REZFprMz+n+XLl+Nb3/pW/eeVK1eipaUFTz/9NJYtWwYAGDFiBC699FKcc845wsttaGhQ3lYiIvJbGT96+XlHRERRuj/vGGYzrFq1Ctdeey2mTZuGFStWAADOO+88/PKXvxR6Podd+Yn73Czub/O4z83iMGMxPC/N4z43i/vbPO5zs0x/3jHMCpoxYwYmTZqE9evXAwD+/Oc/49hjjzWy7qampvqJ0djYWA/VpA/3uVnc3+Zxn5vF/S2G+8k87nOzuL/N4z43y/T+5n1mBe2zzz445ZRT6j//+Mc/ttgaIiIiIiKiamOYlRC+z93MmTOxatUqi60hIiIiIiKqLoZZCUOHDq3/u7OzE++//77F1hAREREREVUXw6yE9957r8vP4XBLRERERERE5jDMSvj73/9e//cWW2yBfv36WWwNERERERFRdVU2zC5ZskRqqug77rgDd9xxR/3n448/XkeziIiIiIiISEBlw+xNN92ECRMm4LrrrsOSJUsSH7d48WJcfPHFOOGEE+q/GzFiBC688EITzSQiIiIiIqIYvWw3wKYXXngBZ555Js466yxsvfXW2H777TF06FD07t0by5Ytw2uvvYZZs2bV7y0LbLhO9u6778ZGG21kseVERERERETVVtkw27dv3/q/Ozs78dprr+G1115Lfc6RRx6Jn/3sZxg7dqzu5hEREREREVGKyobZc845B5/61Kdw//334+mnn8bs2bMxb948fPDBB+jo6EBTUxOGDh2KcePGYc8998QJJ5yALbfc0naziYiIiIiICBUOswCw5ZZbYsstt8TZZ59tuylEREREREQkobITQBEREREREZG/GGaJiIiIiIjIOwyzRERERERE5B2GWSIiIiIiIvIOwywRERERERF5p6FWq9VsN4KIiIiIiIhIBiuzRERERERE5B2GWSIiIiIiIvIOwywRERERERF5h2GWiIiIiIiIvMMwS0RERERERN5hmCUiIiIiIiLvMMwSERERERGRd3rZbgCp8/LLL+OBBx7A448/jtmzZ2PBggVYuXIlBg4ciNGjR2OPPfbAMcccg0MPPRQ9evB7jKLWrl2Ll156CTNnzsSzzz6LmTNn4qWXXsK6desAAGPHjsXcuXPtNtID06dPxy233IKnn34a7777Lnr27IlNNtkE++67L0455RTss88+tptYCrVaDW+88UaX8/W5557D8uXL6495++23sdlmm9lrZIksWLAA999/Px599FG89NJLmDNnDpYtW4Z+/fph+PDhmDBhAg455BB8/vOfR2Njo+3meoefd2bx8644ftaZw887s6x/3tXIe7feemttq622qgEQ+m/cuHG1Z555xnazvXb11VfX+vTpk7qfx44da7uZTnvvvfdqkydPzjxfTznllNqyZctsN9drzzzzTG3w4MGZ+/rtt9+23VTvzZo1q7bXXnvVGhoahN6Phw4dWrv55pttN9sb/Lwzj593xfCzzix+3pnjyucdK7MlMGPGDLz55pv1nxsaGjBu3Dhsu+22GDZsGJYuXYonn3wS8+bNAwDMnj0b++67L+666y4cdNBBtprttba2Nqxdu9Z2M7z1wQcf4OCDD8bs2bPrvxs3bhwmTJiAdevW4amnnsLbb78NALjpppuwYMEC/POf/0SfPn1sNdlrK1aswNKlS203oxJef/11/Pvf/+7yu0033RTjx4/HiBEjsG7dOrz44ot44YUXAADt7e046aSTMHfuXEybNs1Ci/3Czzvz+HmXHz/rzOPnnTmufN4xzJbIrrvuijPOOAPHHXcchg0b1uVvtVoNt912G8455xx88MEHWL16NY477ji8/vrrGD58uKUW+2+TTTbBrrvuWv/vnnvuwc9//nPbzXLemWee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Tav/7stf/jKHXZHzarUazjnnHFx//fX1311++eX41re+ZbFV5cHPO/IFP+uo7Fz5vGuo1Wo1o2sk5U444QTcfvvt9Z8nTJggdc3QZZddhqFDh+poWqmNHz++2+8WLlyIRYsWAQB69+6Nj3/8490ec9lll+Gzn/2s7uY57YMPPsDee++NV155pf67HXbYARMmTEBHRweefPJJzJkzp/63Aw44APfccw9vHVHAmWeeiWeffbbL71asWIG33nqr/vP222/fbR9/9rOfxWWXXWakjWXw61//Gueee27955EjR+LYY48Vfv4pp5yCPfbYQ0fTSoGfd3bw8y4fftbZwc87M5z5vKuR9/bff/8agNz/vf3227Y3wUt59/cNN9xgu+lOePfdd2uHHHJI5v466aSTakuXLrXdXO/lfZ849dRTbTfdK5dcckmh92O+P6Tj550dPJ/z42edefy8M8OVzzveZ5aIrBg9ejTuueceTJ8+HTfffDOefvppvPfee+jRowc22WQT7LPPPpgyZQondCEiIm/xs45ILw4zJiIiIiIiIu9wAigiIiIiIiLyDsMsEREREREReYdhloiIiIiIiLzDMEtERERERETeYZglIiIiIiIi7zDMEhERERERkXcYZomIiIiIiMg7DLNERERERETkHYZZIiIiIiIi8g7DLBEREREREXmHYZaIiIiIiIi8wzBLRERERERE3mGYJSIiIiIiIu8wzBIREREREZF3GGaJiIiIiIjIOwyzRERERERE5B2GWSIiIiIiIvIOwywRERERERF5h2GWiIiIiIiIvMMwS0RERERERN5hmCUio1pbW9HQ0FD/78477xR63r/+9a8uz1u8eLHmlhIRERGRyxhmiciomTNndvl51113lX7eJptsghEjRihtFxERERH5hWGWiIx67rnn6v8eNWoUNt54Y6HnPfvss/V/T5w4UXm7iIiIiMgvDLNEZFS4wioTSsPPmzBhgtI2EREREZF/GGaJyKhwZVZ0iHFbWxvmzZtX/5mVWSIiIiJimCUiY9rb2zF37tz6z6KhNHqdLSuzRERERMQwS0TGhKuyQL4wO3LkSOHrbImIiIiovBhmiciYcJgdPXo0J38iIiIiotwYZonIGE7+RERERESqMMwSkTHhyqxomG1tbcU777wj/TwiIiIiKjeGWSIyYunSpXjrrbfqP4vOZMzJn4iIiIgoDsMsERnx/PPPo1ar1X8WrbCGr5cdPnw4PvaxjylvGxERERH5h2GWiIwIV1hHjRqF0aNHCz3voYceqv+bVVkiIiIiCjDMEpER4etlt9xyS6HnLFq0CI899lj9Z4ZZIiIiIgowzBKREdF7zIr46U9/inXr1tV/5uRPRERERBRoqIUvYiMi0mDFihUYPHgwOjs7AQADBw7Ee++9h8bGxsTnPPTQQ/jUpz6Fjo6O+u/eeustbLHFFtrbS0RERETuY2WWiLR74YUX6kEWAJYvX45zzjkHH374YbfHdnZ24vrrr8fhhx/eJcgCwJgxY7S3lYiIiIj80Mt2A4io/MKTPw0YMAAffvghbrrpJvzrX//CkUceic022wwNDQ14++23ce+992Lu3LkAgGHDhmHJkiX15371q19FrVbD5z73Oey3336mN4OIiIiIHMJhxkSk3amnnoo//OEPAIBDDz0UAwcOxO233576nGnTpmHVqlW46qqruv1t8eLFaG5u1tJWIiIiIvIDhxkTkXbhyuwuu+yCG2+8Eaeccgp69Oj+FjRq1CjcdNNN+P73v4+zzz4bTU1NXf6+9957M8gSERERESuzRKTXqlWrMHDgQKxfvx4A8Je//AXHHHMMAGDOnDl49NFHsXDhQmy00UbYbrvtsM8++6Bnz57158+dOxf/+Mc/0LNnT+y2227YbbfdrGwHEREREbmFYZaItHryySex11571X/mjMREREREpAKHGRORVuEhxoMHD8bmm29usTVEREREVBYMs0Sk1XPPPVf/9/jx49HQ0GCxNURERERUFgyzRKRVdPInIiIiIiIVGGaJSJs1a9bglVdeqf/MMEtEREREqjDMEpE2L774ItatW1f/mWGWiIiIiFRhmCUibcLXy/bt2xfbb7+9xdYQERERUZnw1jxERERERETkHVZmiYiIiIiIyDsMs0REREREROQdhlkiIiIiIiLyDsMsEREREREReYdhloiIiIiIiLzDMEtERERERETeYZglIiIiIiIi7zDMEhERERERkXcYZomIiIiIiMg7DLNERERERETkHYZZIiIiIiIi8g7DLBEREREREXmHYZaIiIiIiIi8wzBLRERERERE3mGYJSIiIiIiIu8wzBIREREREZF3/j+QP6UxMsy0CwAAAABJRU5ErkJggg==\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(2 * 3.5, 3), dpi=150, sharey=True)\n",
    "\n",
    "sns.set_context(\"talk\")\n",
    "fig.set_facecolor((1.0, 1.0, 1.0))\n",
    "for ax in [ax1, ax2]:\n",
    "    ax.set_facecolor((1.0, 1.0, 1.0))\n",
    "\n",
    "extent = [\n",
    "    means.min().numpy(),\n",
    "    means.max().numpy(),\n",
    "    sigmas.min().numpy(),\n",
    "    sigmas.max().numpy(),\n",
    "]\n",
    "aspect = (means.max() - means.min()) / (sigmas.max() - sigmas.min())\n",
    "cm = plt.cm.gray\n",
    "\n",
    "sigma_idx, mean_idx = np.where(\n",
    "    nll.reshape(n_means, n_sigmas) == nll.reshape(n_means, n_sigmas).min()\n",
    ")\n",
    "true_mean, true_sigma = means[mean_idx], sigmas[sigma_idx]\n",
    "\n",
    "ax1.contourf(\n",
    "    minmpjpe.reshape(n_means, n_sigmas),\n",
    "    origin=\"lower\",\n",
    "    extent=extent,\n",
    "    aspect=aspect,\n",
    "    cmap=cm,\n",
    "    levels=15,\n",
    "    vmin=0.84,\n",
    "    vmax=1.15,\n",
    ")\n",
    "sigma_idx, mean_idx = np.where(\n",
    "    minmpjpe.reshape(n_means, n_sigmas) == minmpjpe.reshape(n_means, n_sigmas).min()\n",
    ")\n",
    "ax1.scatter(true_mean, true_sigma, c=\"#EDAC32\", marker=\"*\", s=200)\n",
    "ax1.set_xlim(-2, 2)\n",
    "ax1.set_ylim(3, 7)\n",
    "ax1.set_xticks([-2, -1, 0, 1, 2])\n",
    "ax1.set_title(\"minMPJPE\")\n",
    "ax1.set_xlabel(r\"$\\mu$\")\n",
    "ax1.set_ylabel(r\"$\\sigma$\")\n",
    "\n",
    "contour = ax2.contourf(\n",
    "    ece.reshape(n_means, n_sigmas),\n",
    "    origin=\"lower\",\n",
    "    extent=extent,\n",
    "    aspect=aspect,\n",
    "    cmap=cm,\n",
    "    levels=10,\n",
    ")\n",
    "sigma_idx, mean_idx = np.where(\n",
    "    ece_from_error.reshape(n_means, n_sigmas)\n",
    "    == ece_from_error.reshape(n_means, n_sigmas).min()\n",
    ")\n",
    "_x_ = np.linspace(-2, 2)\n",
    "ax2.scatter(true_mean, true_sigma, c=\"#EDAC32\", marker=\"*\", zorder=3, s=200)\n",
    "ax2.set_xlim(-2, 2)\n",
    "ax2.set_ylim(3, 7)\n",
    "ax2.set_title(\"ECE\")\n",
    "ax2.set_xticks([-2, -1, 0, 1, 2])\n",
    "\n",
    "fig.savefig(\"nll_vs_minmpjpe_landscape.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 331,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 30x600 with 2 Axes>",
      "image/png": "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hvhghvhghvhghvhghvhghvhghvhghvhghvhghvhghvhghvhghvhghvhghi8KghmOfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfDBDfO0UFhbK4/HI4/EoNzfXenf6NOKDGeKDGeKDGeKDGeKDGeK7zW7cuKEvvvhC8+fPV2pqqrxer7xer1JTUzV//nyVlJToxo0bXa7vOI6GDh3qXoEfO3asy7GfffaZO87j8aioqKjLsXV1dYqOjpbH41F0dLTq6+t79DxDQXy30c6dOzVu3DgtWbJEGzZsUGVlpZqamtTU1KTKykpt2LBBhYWFmjBhgvbs2dPpHO3f8tm2bVuX29u6davfz7cau2PHDrW0tEiSJk+erISEhCCeWXgQ322yefNmzZo1S6dOnXLvy8zM1FNPPaWCggJlZma69588eVIzZ85UaWlpp3P973//c5fbB9bGcRxt377d7779+/frypUrnY73DdN3/l7lhMDr9TqS3FtcXFxYb75ze73eUHYxZAUFBe62c3JyQprj7NmzTmJiojtPWlqas3fv3g7jdu3a5dx7773uuKFDhzrV1dUdxh07dswdk5iY6LS0tHQYc+TIEXfM8OHD3eXvvvuu032cMGGCO+bHH38M6Xn2VFjiu903r9fb41ugwhHfsmXL3DmSkpKcs2fPdjn25MmTTkJCgjv+2Wef7XTcyJEj3TFlZWUdHv/ggw/cx1euXOkuv/LKKx3Gnj9/3n18wIABTnNzc0jPs6fuiPjCcQtUT+O7fPmy39F71apV3a7z3nvvueMHDhzo1NfXdxjz5JNPumPefffdDo/PmTPHkeTExMQ4jY2NzogRIxxJTmZmZoex69atc+fKzc0N+jmGC6/5wmzv3r1qbm6WJPXv318FBQXdrrN06VJFR9/8zqampibt27evw5iZM2e6y+0vJFpaWvTTTz9JkrKzs+X1et3Xcb/99psuXbrkN973daPvvL0tpG+p8nq94d6PTrW9WO6t7YXDwYMH3eWMjAwNHjy423WGDh2qCRMm6MiRI5KksrIyzZo1y2+M70XBzp07df36dcXExLjbvHz5sqT/j2nmzJn66quv1Nraqu3bt2vevHnu+hFxsaEQ47tw4UK496PPuHjxoruckpIS8HqpqalufL5ztElOTlZaWppOnTrlHh1nzJghyT+mtvjaXyG3xVdZWanTp09LkuLj45WVlRXwPoYbp90wa2hocJeDOWLHx8d3Ooevrk69badRr9er7OxsSTdjTU9P73KsJM2YMcM93VsgvjAbNGiQu9zVe2ydaWxs7HQOX52933f9+nXt3r1bkjR9+nT179+/w/jjx4/r3LlzkiLnlCsRX9gNGzbMXa6srAx4vbZTYfs5fPnG0vYGsu8FTvuLh86OlL5vRBNfHzNp0iR3uby83L0QuJVLly7p6NGj7s+TJ0/udNzw4cOVkZEh6eZnxjt37rzlleujjz4qj8cj6eaR8ujRo/r7778l3bzImThxYmBP6jYhvjCbOnWq4uLiJN0MZM2aNd2uU1xcrH///VeSNHDgQE2ZMqXLse1PvW1HtM5i8o1127Ztfqfc3NxcN0wrxBdmgwYNUn5+vvvz8uXLVVVV1eX406dP6+2333Z/Ligo8Lv4aM83vk2bNumXX36R1HVMbeOrqqr06aefdjqPGbO3tyNUOD5eq6qq8vtsNz093dm3b1+HcXv27HFSUlK6/WzXV11dndOvX78On+B8/PHHnY7fuHFjp5/4VFRUhPTcwsnjOPz/DvgqLCxUSUmJpJtvXdx3331Brf/rr79KuvlXLfPmzdO1a9fcxyZNmqSMjAx5PB4dOXJEhw4dch+LjY3VN998o8cee6zbbWRlZenAgQN+9x0/flxjxozpMLa+vl5JSUnun09J0qhRo1RdXR3U87otrOuPNL5HvlBuvn7++WcnNTW123XS09OdXbt2BbyPr732mt/6o0ePvuX47Oxsv/H5+fkh/duEG6/5bqPp06eroqJCn3/+uebOnavk5GTFxcUpLi5OycnJmjt3roqLi3Xs2DFNmzYt4HnbX9V29/ot2PG9hdMuzHDkgxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnigxnig5n/A27kziPViu9nAAAAAElFTkSuQmCC\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pylab as pl\n",
    "\n",
    "a = np.array([[0, 1], [0, 1]])\n",
    "pl.figure(figsize=(0.2, 4), dpi=150)\n",
    "img = pl.contourf(a, cmap=cm, levels=15)\n",
    "pl.gca().set_visible(False)\n",
    "cax = pl.axes([0.1, 0.2, 0.8, 0.6])\n",
    "pl.colorbar(cax=cax)\n",
    "plt.ylim(0, 1)\n",
    "plt.yticks([0, 1], [\"Low\", \"High\"])\n",
    "plt.savefig(\"colorbar.pdf\", bbox_inches=\"tight\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}