{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dogs = torch.load(\"dogs_tensor.pt\")\n",
    "planes = torch.load(\"plane_tensor.pt\")\n",
    "\n",
    "from labproject.plotting import STYLE_PATH\n",
    "\n",
    "plt.style.use(STYLE_PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "mean = torch.tensor([0.485, 0.456, 0.406]).view(-1, 1, 1)\n",
    "std = torch.tensor([0.229, 0.224, 0.225]).view(-1, 1, 1)\n",
    "\n",
    "# Undo normalization\n",
    "dogs = dogs * std + mean\n",
    "planes = planes * std + mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.offsetbox as offsetbox\n",
    "\n",
    "def imscatter(x, y, images, ax=None, zoom=1, edgecolor='black'):\n",
    "    if ax is None:\n",
    "        ax = plt.gca()\n",
    "    x, y = np.atleast_1d(x, y)\n",
    "    artists = []\n",
    "    for x0, y0, img0 in zip(x, y, images):\n",
    "        im = offsetbox.OffsetImage(img0.permute(1, 2, 0).numpy(), zoom=zoom)\n",
    "        ab = offsetbox.AnnotationBbox(im, (x0, y0), xycoords='data', frameon=True, bboxprops=dict(edgecolor=edgecolor, lw=2))\n",
    "        artists.append(ax.add_artist(ab))\n",
    "    ax.update_datalim(np.column_stack([x, y]))\n",
    "    ax.autoscale()\n",
    "    return artists"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x7fc6ca927610>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.manual_seed(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "dogs_xs = torch.randn(50)\n",
    "dogs_ys = torch.randn(50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAKEAAACgCAYAAABkDQwTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABXhklEQVR4nO29d5xdR3n//5457fa923e1q97cm9w7xjaml1ASCGBC8iMQICGEQIAQCHxDAqF8gZA4gTRCCb032+CKjYvkIslW79t3b7/3tJn5/XFWsmztSrIsWWt/9Xm95PXuPeeeOXM+55lnniqMMYYTOIHjCHm8B3ACJ3CChCdw3HGChCdw3HGChCdw3HGChCdw3HGChCdw3HGChCdw3GEf7wE8EX/9pdsp14PjPYwDUMx5fPQPLzvew3hWYs6RsFwPKNX84z2ME3gaMedIuBdCQDGXOt7DoFz3OeFTOraYsyQs5lJ8/s+uPt7D4B2fvemEZD7GmLMk3IvjrSOW6/6+n+/47E3ACf3waGPOk3Cu6IjGMCfG8WzEnCfhXswFHfGEfnhs8Iwh4VzQEU/oh8cGzxgSwtzUD+GEjvhU8Ywi4Qn98NmJZxQJ92Iu6IdwQkc8WnhGknAu6IdwQkc8WjgRwHACxx3PSEn4RHz9rWfx7XWaqWqF8dFxLjhtKen1G9hcjelwDTor+OOzLNaW+zg1P4+7KlN8f+co8zszLGgvcvmiefz7fes5fel8XlOcZDK/jEvkJhq1Uf7mQYdVlsM1nV1gYOBnjx7v233W4VlBwp0jIa1AM1mq09/XSag1dQ1BBH3d4GX7aHNP5rfRVr50/3rmdWWoVEOksJisj/PLB3bwhXNX0pPL8merR7i6azXFfkVzrJePDSxldXkHETHSPCuma87haZ/VQ5lZ9ppBngx8k6LRmqQtm6JUazI6UWFxymUiisHAO089h78e3sTqrROkbcG2LVM4AjbtqeJIQU/R5S/XbeXvzTIwcOPWOneNZnkeEYuuWwCbGmy0YxY1a0/l1k9gFjztJDwWZpblfT3cPxaglaKxc4rJSkRb0WFJEf72wpfwZzseYle5gYkVUTWiK6155++v4oe3PMCWXTH1qYDIi3j76g284+Q2ViwV/HZTilMuvoj7egt88/4G5ZqPFbf40VEd+QnAcdyYCAHt+dQB/4Q4gu9K51AGgjDkz8/Q3HCdx+7JkLZsFipVNoxUqPsh73jZKto7NeeeVaDWLOGmJf0DNv39kMcQK8V/b6kyVY14caaN0Qcf5p+/8SOGxiap+Q2U5Rz9iTiB46cTzmZmORKzh93WyeTkBD2mxGuv6WVyapSTivDWk07j1mCSejPk4tMG+clt93LpOd1ces4ZXPOyP+D19SmqlQpbH7mTf/rOrTQ3NxmuaH4y0sbyTIPvlRrUHZfxySrvOjfHtkr56Nw8x9/7MxuOh/fnWaFpu5ksH14luWrhMoyIqPsGbIt8Os1HNm+jx9G0qiXSKYdXPu8qTr3gBehYYwwUu/s4Z97reHfnIj706S+zY0PMXbsbvOGkIsNSUmu0+D/nxLx8uQC8Ga//RDfe4eCEofsxzBkS/uInP2F0aIhmowewntS5lo64dvk8jF9CxC0emLBY2ucy1KgRa40jYLJUZV5/jmUnn4flZalPjSPjiJTQGCfDwlMu4g9evoV7P/YLKr7glqBFJpfCR/KykzJgYpq1CoUZrj+X3HhH6k06ni/FnCHhlz73OR761a84/c/+jVSh60md++1vfoVLzrdoK3azbscuhrZJVnTm2a5q7BpvMs8SvPKF55DPSlLFXpT0aDUaSB2gtY3latAaJ11EYygoxQ82j9O3sI3xiTpbhyNSSPxKz4wknAtuxL0kOlJv0vH0/swZEgbGAEewKwEm6wGbRi2ckU3874M2Hzz1XP5paDsb4xZdbQ6m2qReHee5V74cmetEYyOFIAwDpNBYKmBqz3a2btqAb0BJQSQkJ7mCjGfT0iFL+trBXzrj9eeCG/GZ7EKcMyQEQd2YI6LhYE8X/dEgE9E2OrsmqepJKi1DJHxqDcX8jMvI5ATzFq7gjh99neUnnYLrZoj8GpgU/sg2vv2d77F9ZIhs1qYZaCwMg6LCw5GgzZFMVeuUJ4ZZedTv++hifGycy865mFgpjDFY0kbaNnEcoeIIpQ1gMMaw+pE1x3u4wBwioQRaR6iUdLdlkDGs7MtzyvImE9WtbLw/xbVLB/nZ7m3Msx1WrjiDh9Zu4J9v3siKNbt57fPPoza2i76BxTSqJX65eg9DjYhIGTpyNqWG4pw2xeohwUgLpkZ9Vi3dfcix5Ds6wXExUUTKc/ndl7+QFQvnY0uBtCQSgZDJqyYQaKPBgMGglQYx/XdtMEZjAIxBG4NSeppMiiiM+OtPfHaGETw2h8YYlI6RSiARKCERxNNHHNmqcywwZ0goSHSrI5kaL1OgOVpHmDFENaAZKbYGPiuUhTAGP/QZm2pQDgw/u/1+Lnvdc9mzeydL+jvJFbsRaCarIdsmW+SkoLvoYBlQSvGXq2DTJJw3z8a2Dj266666jGJbgba2NgZ6u3FsG9e2kEI+ZgM1BjH9izBi+k8GS1oorREIEBpjBGaagMQaIS1sR2JZGsdxZx+ESYiMSSReLGKktJBCoPbO95EYZI8R5gwJ92qERyIL77rrQVYusHl5d5G1O1t88Q7DuX0xv6yOc/lgG0PlKlt37uEN1y/h0pMX8vDmrbzgvIvpm38Sojif2thOLl6eY6jUxI41E5WYxU7MZAsagaHNZGlPG6qB4VBbpkvOOxvLchACLJlIPcuyQBgEEksmZLQse5qUj5FBa4XWifTTxqDj5HetISJMSKUMRnLQnaye/tAARmu0MTiOQEqZzPE0OecK5gwJJSDMkZFwqhFz3bnt6KjFV9fF7GpB3jLsoMJL2rr4Vtpjx1CFmh/wpy85k/ZinsFlZyLa5xPjYmeKLB/Ic/6CMvdv8hMiGIMfwnAd7NgwvzOgu+0g0mcarusipUQKC8exsCwbS2iEkAgpk59C8sRlM1mHJQYNxiDRCMdCaIMwGmnbGK1RxmCUQh7M2WUSvW+vJMQYlFKJNJQWcRxjjJr9/KcZcyae0MJwGKvdzDACHdSoNgLeeE4K0Zsm5Qo2liPG/BZKCEZKIfV6leWnncepl78MWejGSJuW3yKOIzoLOQa6HKpArAy/KRu2TwrGq4KHGwHY0FE8NAkty8K2LVzPwbadRPoImXBMiOll0EyTUUwv09NLsxAIYZK3UTymokghppdokchNIfZJuyfC8zwMZn+KY7QijmOUihFSIi15RC/7scKcISGAfYRLxEgDfOGycSLmTb82rNkZ8NAQTDQ1QkSUA5d5Sxbxy1vuZ/C0i/C6BiFdRDs59mx9lPzgaaAgtrJoAUP1mKwA2zV0thk6PUUpNty2qXHIsbiuQyabQ1pymkQqWZKFmJaEjxExYVhynkEn1Jn+fB85976YYtpyIMzjiPtEeJ77+O9HTy/LCqXUPn1Uirnz6OfOSDjy/VrNGL77UJ3dgaYVaRqBYn1gqBvD14ebFP0qGzfvYvuGdQT1qWQldHPEsWLDunWMDe1g2ZkXsnE0IZkU8JwOQc4WVFrw2xEYakD9MOIJtTZEQYDreEgrediWbWM5Do7jIKTEaINlSRzbxrLsfQQLg9Zj0s+SCCn2kVYKgZAkS70lsO2ZvUpaxQmRpzc8CBshEslnjEJrlXyffHJeqWOJw9IJj6azfba0Sef8P+CCM1+Ll2t/3Of7H7//d7zjszftc7a3AP+s55NespDOXd/l0fHhfcdWtWZJK6Ycan7z6BBWKocJGqjYMD60kwc3bMZYsOrsVVheJx3pAEdHWFaypI01oKFhR8Ww4IxTDnl/2iQbiSBoJvqgFBgDGo1RCh0rEMnOm2nd0BiDFAbPFig0IB5HRK00WoLQAmEMcRihlJ7x+ioKmN/fxc7do/sIjUj0TK0BIiycfWaiuYDDIuGxiAF8or9VejlSXm7Wz/dfqZ/4WVMZvnPrfYQ33knKsomBAlAFHEdwd0PRZUn8csiNP/oOlz3nGqST5h//779QaTZ56Ce3cPe9DzExVWYqhiA01EN4XTFZ6qvAlinB4t6Fh74vrdFCILTGCIU2yVIohcQIzcZff5N0JsPAqusSw7EwlHduQiJRwlDo7sdYLkpptGHfblapGK0UWifXmG13a4CLz1vJzt0jybwCWthIYjQKYyRaq2eeJNyLueAjhQOd7QaIoohcOs3kRAWA5vRnUy1NmytoKEMq0Hzth7dz3qrzcHOCZhBxx5ot2JamNNLgtP40o5O1ZBm1BOM1Q6TAxlBpwIOPbD7k2IxJonPM9NQaYxAiMZs0a2UWXvRi/GqJDXf8nJVXvAhhDBO7NpFK5wn9Ju3tRUJpT9v5NNqIx0iXKHfT246ZSSgQ9PfmppdwMy1Xk/8IIxOprOfOzhieJAnngo8UDvST2sDoeIPrX3EBD6/fzCMjm4inWaqNobPNod5QnJmy2b1jiF/f/Gsue86VtOezeJk0Q8NlTlvmsXWkxhVn9HLvI2O0Qk0uA01jyAAFG6ZKrUMPzkxLbW0w07vcxAKjyeQKaCMIw5A9u4ZZYQwqjkilUrRqJSwvzdCu3XQuWpGYa/ba+5L9BSCm6Tf7Bi6SaX46fgoLXrQSo/ceN33GfqfF/txJVZgzdsKnghjYUfb5+L//lEJGMtjmMFaNUBiUAqUN3ULyrqU9fHHbJP/wr98mKE+Sc6FIRKHTwvdDHh3XTFbG+Ma18NW1hh9sg/nLClx75koGpx7kM+uHDj0WFeMIB4VO9Dop0TqxA2qjuf8H/81UtYXRmjAIqIztIgxapDM5Wo06NX8H7fOXIfbaq4yelq6JGw8SCw5mZp0QIYlEBuv4L1iHjWcFCWF6pRJw6oICEkNPu8uO0RaVliLlWBSEoMtNsyoneHQi4O/+5xZeeFYfnqVRts3Nu0M0cH4BcrbNzilYtqSAsmyCXJGmWUbd33LIcWilUEICAi10shTKhIBTY6P4QYhjWQRKMzU6THV0D64xSCmwXYswjGg2KuTaOvfdlzBimnTJTyPM45Xk/XAolWkuBtMeMQlv+v7/0GxWiIOQTVu30NYzj1e+9BVAYiZoNuvYlsR2PJRKst7UXo+ItPnWN/4Lme/gwfVreeVLXkWtXqHVaFBtBgRhTKVWJwibSGHxj3/3yUOORwK2ENTrEcoY2nM2hZSgI+eS8SyiVLLBeF5fP+e0V3nXZIMv3rEdrTWDRXuf8bcWCP7sdkOYS6NizdRUg1w6w4/XtrDkoS1aURQiAK01aAstEyOz0po1v/wB2C6WFGgVMjY8RD72MbZNqVbHtj2Im9SnxigUOx8zrUiBtCy00sRKIZRAzTKUQ6lMczHk64jthHffeTO/uetOfn3vGtaPx/z7//4EpafND3GMTGwDGJK3XFrJbiyxUUkQEguBjsF2HH788ztRwpr2pxqElLQXezjttIsPOZasJfEkdGdt6i3FZC3GEoJMyiEMNK4tGa+EfHrXEB2ZDEuL3USRJtaarCUp1xOJFQPrG7C1adFQNiOTIV1tHt/+8Y2MDI/SkT10olMUhERRhFaKWCmiKEQpzciOzUjHprO7h1grEIaUMIh0EQsPKSwK3b3EWEStBiASImMwCLRSIBI/tLTsadffswNHLAnPvuAq3JRHJpMjl8vzlx/4GHs3bZZlEwbNhOImCVEyRnPt6/6M//ns++nq6ccYTRTGNGs1fv7ru/G6lzJZqpBKpdDC0N+eQ0YtROnQFQ/OXOgxOhmypD9FrakYSKeIYkXKAuVIpiohC4sZfOCuoMkNw+PUWoYOz6YrKxhtaEycfJcWAmkLRuqKzrTD0FSIY1tkHIHrHHq6oihCSAtIImCEFEgTM7p1A64FKVdQzKWZ8EMy7e04rRqDg0soTY0xOT5CR1sfQ0PDNBbVcb0UxDy2GdEKozUIiefNvOSOT0zx9r/5Z5qjW7E8D6Tk3z7ztwcct1cozAUcMQnnL1wIOsaybFzH4nnXXLXPcKAwWLaTxMhpM/1Q4Ktf/jJaKzZt25hY9eMWHSnBB//8nWwcrrPm7l/ghwFBGDIvY9PR0UmlNHnIsdy5pXnIY/bHq47gfg8XtuMmNr04xnZdhJTJvaqAnq4OJuuCkBTZQoy0UqQmthP1DCLdDLadLPluyiKKosTUY0xiVjEKoQVm2oMSzbKICSFoa89j+3nyHUWyheKsx80VHLFMtwBb2onCbDRnnX4ysVJgEoe77bpIaU0bFZLDKo2IsBWzdt02qrUa23btohFEtEJD2oL29iJGWARBQBD4NBrNfTvCZwoKHe1Ylo10nESHi2K0hjCOUNluRsZG6Zw3CLYNUiAWLWF42w7KW4bQJqQhNG4qNW3LSwIXhEg2JxpQcUQY+AT+zC+ebdvYjo2dyWC5GYQ9s5x5VpBQG00QBWitiCPF4vn9fPAT/4Q2GiktQt9P3mIkQloIKVnY20XcCPjJr+7nhu/ew7dvWs8tq3dz882/5Dd334lluxgDYRDiuS6upfHcubNsHA56+gdZevKpdPb04roOnueAVnhumrvvfYj1uyfZsn0PRtogJA/d+lsWnnEK3WecQltPP8LEQBKWz3Q8TGJn3BvMkOjaepaXUwgxrY8Kmn7Ed772nRmPmy0K53jgiJdjS0rcdAZhDEKCkJIf3nwvH3hHjc72DmDavSTAsm2MUYRRyD133kktiomNxHEsMu29fO273+Uj734buyZrCJLQJxWGGDdLNjNzri883v9cbQRP+8Tuvdz+4/BbbdOfFhFyKSnbcG7nNsRZl7Hg9JgojqiWJ6hMjLJj00bS+QIbNm3BxCG98xeixkeo1Jr0uN5j9kCxN9R/fzP1zJJMxRH33HobOqwSBa3ERz3j2J8NJLSdZGKm/aJCCD7y7j/h4pf/Mff/9MvT0R8WSEkURUgp+c73v82/feXLZLsHWLZ4Pju3bKM+NUbvqeczXvMRCMI4JPAb+C1NWy5LEEWzjmGu5Ps+fhwHLi4DCxYzuHApURiwc+sm2ju7MUtPol6p0KrWqJVLdHR1Y3kunuvgFoqPMVyKaWOhhTBJBIyZloYzIY4jNv7mxxT6FjLVVGTSsyy7zwYSRlEyIVobLAwm8Hnl8y/k7FOXcs7Vr+crn3k38+YNsOahh9m6fSeXXXQ+r3vZlVxy/qm89o/ehXBPo1mr49enGDl1FSMTJcqVKrv3DDM2PsHJ/cuoNerIg/o59/ehJg9mLvq3pWUhgFQ6w8rTzgISibV7x1Ymh0fp6OlJbKt+iCwO0NftouIosb6L5J8xJlG/p3NOHnPJPQEGbCeFsFJkikVMY9cshz0LSPg3n/o08/v6cNMeDpBOu2QzOdoyKf7opVfxjr/5FCaGQFkETZ9//q8f8LznnkdgJB//4Lv5yOe/ip1y6R88nUZzgi995asYkXgEVBTzkkvOZPf2rXQVZ0o334sDJcLc82+LvfFUMJ1fIpFYnsXSFaey7KTTp11zCcFiFaOm7Yt+s5Fs0nyfwPeJoog4Vtj27B4TMERRi0hkQFpoPYtOPXc4eOQkvO03DzM4WKPQ00aj2aRZr1OvVskpn1evPI1aOQKZhA05roPRNnet3ohW8NzzzyPnCa566Yu4c80DLBno5ZXv/SKfff9f0iyPYpBopWjr6CLjzW4g3l/qzUV3FACCZJMxHZovhZgO7d+7zxCANR3lonGEi20ZXNcjncpMSz1NHCu00kRxhFZxkh46A4zWnHvaSjZN1qg36qh4Lk7K43HEJJzYtZmJXVvoHJxPOpMl0jFho4a0Jd/YvBGtY4y2sURArHLYjk0UGqYmyrSffxV/cc0b4b5bufGmm3nFWz9H52A3H/7UJ/jk+z9Is1FDaaiUKrjFzKxj2F/qzeSO+v9e10YQQ+wIOtMCv6kQAqpaEIWatHHwihFRBKqqqfmCxgQUuzV2BEoIUgjC0IA0+MqmXlOkC4uY2j3CoO2zYyLAV4IHyzPrrpZl0TtvcL/MuiSYQRiN0jrxNcdxQrZpL4vRJsmykzFaG5TWQIyWCfG0sFBiZhKmUh4DZ13Afd+/ER20iJ8BFq4jJqHtphAIquPj1OUUWkeJvuJYFFNFtEoeOHYSrmQ7kmYzxNguP/jKf/HBz3+WDdmreVNd0bViOWhBJpOhFfgEQYARAs+zUU8hSdu1wWhDZAsqoaItKymVFO1FTSUQ1BoRpl0QakMtEFgtQ5TVRB6oGEpVTVpB2pL4FrTCiIVdsHFsCyYlSE2nXs6mnkHiQ65Vq1jSQkqZ2BBtC9uySaUzuK6XbDa0IVYRSqmEmCoJxd+bKaeiCBVrwjBARTFxFM98PWGxeqdAptoI6qXEFDQDnhU6YffgEhQkCTMCVKxQsSYlDUZBFCsc26CUQMcRbk7SCGKEtBjaOUppYooPvvxlvOF3Xs3br3s+xUKWS6++guFtW4mCBqXJkykWuxBq9hi+UqnMH17/J2htyJ7zigM+17Yg7QpadUNkQRRofEsQlKEtBSbUGGPToSKUkuxqwMolkvGqIZeGtjrYDkhtaPoC1xPUw+TczjSMVyVer0M4cZDNk4GgFST5IlIgkPvyf/dJx/3yj8VeSQnTO+HpL5neg9mWjSUtXGdmNSX0fbavu53JoR24BDjZ9hmP6+3tnX3MTzOOmITPvfI5BHFEFEWEUUQQRsRKQxSwZdNWMBbCaDA2ygT4vo1G4NiS3buG+dcPfYL5C+bxvZt+xmXnn4OU0BwZ47rnXIFSMZlCEYPGlgemWVYb0/kuloe/8EoAohlyV2qDn9u3i5RSUAfcJOOHJkzraNCU0G5l6bVTNIMqPTqphmDbiUcoimJSZjoR3UAboIB2AUWTfMf+OS/7w/U8LrniiiOd5icNpRXju9fjuG3oyD+4mJ4jOGISXnP+SdOhRoJIGWKlCaOYH/7y12gEV1/3Itbcexfl0ggSjdYWHd1tNOo14iiiWmtQrgT4fszvPOc8pLTQGMIoQhhDOuUitCIMD0yw2meUFgLsNPDYZvFxNju743HnTaeYH/A3A/iAHwNWAawkkDna+/ymhc70FmJGzAV7JQDG4LopCnmPZiNCPANKHB8xCVcunAcwnZYIGMNH/+N7bNi0CT/U/P2fX8/o0GXctWYLN3zja0yVI2773leY19PNTbc/yPd/8Wv+9i/ewvKVS9m97p6kPIa0sGSivLuum9hpD7LlnYs2weON7p4e3vLmP+ZHP/oBaIW2ZvbMPjHb8Ui6JhwtHLnHxErccbZt4bkeUkp2bR/Gtl0uvugs0k7IwMA8xm66l1987QZWXfcH/OSXv+SM5Us5adlSXmldQn9fB1/59vd5wTmLkdNxhp++cYpa8PgtnfWLx5fi3fvA555N8ECUaj6v/9iPj9m1pRAUst4+EjmOw4c//tfk2/r4nde9kO3bZjFWzxFvEzwFEnZ0tCeJ3NOWfIAXXXspf/7m38e0yljSsHm4xutf/3oWLcyBENzwr//OZLnOe//8zxjatpE3/H/v5L3vez9BECWlLZSm6itqT1yB/bkxWUeKYykllTGPJ5PRoGN2bV/D7pFzSHfPXMJpJhtr8rfZffXHCkdMQiETXUNKsOxkKX3d8y7GSbnUqxFB4LP8jAuw4kmGd23Dcmx+9b//gkUSomT0WbzuVS/htPOvoLr9XsJQoXisSObBltrZlr84THzUSWK3pjK+kwsvfg4f/8Q/8dKXXkDov5fxnQa/Weaal94KoebD5yjaL5mHTE3SdXovwnIBhQ4M9aGAys8naYyG1FoxU6HGAmIDH15/eMUAjpXK8NgcGDyp8X2fbMajkMuxZfNaunqLjO3cRrazF05edsD5M9lYi7nUcenbfMQk9FwrMSGYvbYyjZctYLtektRt2ViEKJUoyqefshLHFhAnxwqhGexI0RzfRve8PnZv2fE4g+7BltrZlj8pmwSlzSjbJfSnuPunt5Cy4H3vegu12nt59aurCKeTyAhULEjbYDXSLDj3aqZGN7Hpl7dSWGqRLmRxvCJag+PKpMClkpjQEEsI9OHbLo+VyrB3DtK25trFTT73iU/z6pddzjkrrmHtw2N0dPVSrVZJLzr7qF/7aOOISRhGCikS04fRSZkJIzPYbgrPkTgGwvok2bYijXHNp997PWkH6pFJMk8MgEYajY5DbNtOclSeghG1tO0eJrc/ip92cL2kBgxRSGcuw9998O941as/Qbk0yfCOJhlHIlWE3dZF2jmPtN1Hz4oeqqW7qE0MI9wWzRGLTpEiQFIyhqFslrqEcA55IaIw4tv/+Z9YjuTO3zzI1gkLIyzaOjvpEiDX3Q+rDpSEcwlHTMKUt7cOn0iin41hZKTELd/+IS85fyXCQFgdJ1agwjqLBvtIZdupVraT0NACaSFSOWrVEZTZm+y917X1GN71losoFtKkPYds1qMRvxbIHTCmjff+jHBqiEY6R8dAN7HxmWoG6LBFRjgsGnwbp51yMh/8wHvpG3iYDRs20Lp8Af3zc3T3L6flD+AHFzExup2goYm66/zyZ/dQmRxip07UBf0kX5JatcyHP/KXGCMIQ584Tsq0GZ0oH0mlBAs5bcxutXy0jshkcmgVEcWKRjNg67at3HLzb2a4guG6l7+QbFsnFz3nGga6uxkZmqCjp4Bru9x+1+onNd7jgSMmYasVJBl1croCqLDoKWa4OLeYRpD4Uf1I8eWvfp22dMwfvuoFGK1wUnlAoFRMpAX5TJqx8RApQM8SJuc4SSUqpCA+iDM0qA0R+1WCsEolVSdoaa6+5CR+cfMaTNwkEJJStcHCwTwvf+lz+PtPbmTPuk2Y5zdJt/di2xamOkY+LONSp5GyuOalZ+C+eiF77phg6rbt7Io099Tqhz1PQkrackWM0dQb1rRLLrkHY8w0MQ3KgA5jMuk0ttNGvV5DKUU2myGVylDInznj9+fb2rn2BZfT1V3ASyU20zt+/VvGa2NMliZwXZsrLll12OM9HjhiEkonldS6k9OxbkYQKoEtp3VFIWnLubznTa+gVi0TxoI7b7+FeYuX4zgpUCF+pLnp1ttYPtCNJSVS2swkCbUWWJYk5do4joWIxIyrtpSgjE84UcEqGASawXZBI4ix01mIWuzZvZu77rwZaQIafkTHFTdQjhU9GiY3P0h1bDNRWCdolJFANFVid9BGPZ4kj8tpGZcedfjSUEpJOptBRSFSClSsiOMATUJIz3OIogi/1SLGIowiDALLcrAsm0a9OW2LndlMHgQBf/We93HpVZcgUDT9iO9+45ssPeVU+ufPZ3h45LDHerxw5LtjywIMlpAICZawcF0X23GSqBCtQVpJwruwaTR8blo7xZnRLs497SRCkyJSLTrbknhBKS1my0LMZFwKuRQ9XTnaci5rtsskSfgJUFGQlFML/MSnLUMWDnZw/Yvnc/vGAqN7thPGMf/+Xz/kLW9+NSsX9VP1m/xwfT/lnet51eRmprbdhS1s/AUWTdPAtjJMbtzO2vtrXJ3tYjKqg3foiq375kkIuju7USoiimL8ZhVh99BsNLAdl8BvEEUB+XwbQjj4rQZT5QZhGCKEJpXJJmWCZyF+s9HkgQfvgZSHMTrZFDouI2MlnHSeB++977DHerzwlHJMEhgwItGV9no4hMCyk/4ZUghkPofjFHjX619AGEZEcYwjNW4mTTadwpgYYyCK4hmjO1Iph5TrknIdMilv1rgaEwdIAQ4G23ZRKCI/5syTsgyXM4hoHllXsHL5Mn74szs4/8wU2x5ZzcJTL6XldvNJ8xIW9V7M5PAwf3jzfaBqyFizKMxzSQMqlUncj51OV1/34U+UEMSxj8FFSk06WyCKQtJpJ8nB8TJIKQnDmDAKmCrV+OGPfkRbxsfzXPL5NvL5FG3Fvpmfg21x6mknc9JJiwjDmPHRCZZf8xx27hymp6uN7p6ZAxjmEo6YhAMnnXUUh/EY7F/ddIBx2rEsXNcmn02RSbuzFniUto1A4diCoN5AWhHCODRqmquuuprffPoL9HR2cP0bXsfvvPatGBXz5j8a55E1v8V4RSaGRykV2uk8bRUfaiviZAvc9aMbWHnBy9m5/re8ZudNmLu24OV3c9XvHd79CMDzMijjEYUNLNNCSQvXdZIa0lYS3uXaVXYNRdzwz//K4kUFXvzy6/FcD62jpFrEQRKW+gfmoWJFGPg8unYdF3dfhlAxY3uG6eub92Sm/7jgGVEQKeXapDwbz7Vwp+2TM+G+2+6mmJdkbAdRLZDJO6SzaVp1i9ru1bSimDe//neZGBsl7bpIIYgDn107diHcCYrt3Uzs3sSCZSv42Y3/QawC2joH2HD3N/Ebo9SNJqeyjG+bOOyxCwS2ZaHCkHQ6i1E20gpBByAzhGELpSTKLnDHnTfieina8h6FfAGtNUFocDwHR89sHNdakysUCAOf0mSJSm2KoNXCtSUPrlnDvPnzD3usR9Kt9FA4nNa1zwgS2o7c18jGniWZG+CRAJaXSnQUs9i5Kql0gWwWKqJIpenyR9e/lVe85lXceeftOI4DsWLn1q0Uui8nnU3jeSlGdzeJ/RrSgnxhAVr5qKiMxOCnbNbcu4errho8/MELkHYawiogQVgYbKI4RGmDJVMoY2g0yzyw+n6M1nR3d+PYBtvN40QhQaAJw5klYXt7Ox/7s489memcFcfLn/ykSHgs3pSZrvFEWAiMEaAlJrJmtWdXqhH1OjhxAy8YIVOwSKUsOgYv4YGbbuGTX/0CURTgV1r841//Ob+66T4eqrWhyhM4dg/Vsd1sffinZLMOjeoeauU92K6LMYZBNMN+zDiCyBy+f7VWrfCZj3+EOAo56fSLOffCq/ni575ArVGn0ahTrzdIew7Veh2tNbYlGB7ag+W1IW0HSwV4tpouknlscTRdjE8msuhJkfB4vSnNliJdjxnVDe5evZ2qORPhHkiEsBKiDcSBplWqYfWUae+HSSEp7dnJbb++g0suvRBPaoYe+gWb15epF5dwzmXPoVVrENcnaOvoY2zPVq584R8xNT7Bi89L8dHPf4MBDDEw1jA06uFhjz2OFRs2DiOkYPfwz4kDh/PPu4wLL3gu+Y5uPvPpDzAyMkSzFdCKWhgtWb9pivUP3cVZqy5HOGkiEaPMsa9EcTRdjE+mBN1hkfBQkRWPj8J47E0K/MdC85OcE5FUrJ8+2OyfUzydjdZSSYHJ/fHgo0OU6wFDI3WM1iy9zswYXOrWYpqOJo4lG0cU3u4hLjtnio0DY/zhOd1UK5NASHunwz2fvp1RinQsvQAd+VQmhqlWSqw4+zq6O4ts27CB8091WdVZxrFtVtUq3NHtcO38HMXCgd6a2WAQNAIHEMS1kG9+97tccM555L0MZ557MZdcch0Cw2c++6F98xDHmrVr7mD5Saso5HP7KljMNvdPZnU6nnGDs+GwSHgoxXL/KIz936QH77qNVrNF2Grgeg7jUw1s254uEhkQhRGWJZPCj0jCyPDzPe201ONJePu9u2jLuWQ8m7asx2y1Kit12NGAdltxcaegIyfoLuZYExr+eUuW8x/+IBlZY9uGe1h2eQffuykmpxQb126kOrUNrTRt7V30drRx49pf8Z3PfJLvfPEz5IzCM4ZqJWJjrcLOcsSHDmfiSOyf7Z09iOnskbRnce8Dq9mw8VEeeXg11173UkarTVzHoRUrLEuiteah9eOsfPBOzrnwGnw/AjPzTR/N1SkOW6y78weoOCKIfOIoJA5DlImnu5Pa7K0woaKYWEVUKhUajaR41Vs/8Jkjuu4xrbTYqNepVSo0Wy1qTUMum05aFwhNFEZIO0Xo+7heDiyPfCE/4843lbaRUpD1bM45ZyWFwsy2L7+uOLXNcFG3pFNKBk7P4RU6qdeavODVv8d5Zyyg/OhqbOqsfO6bsITCsSSXnd3Lf93wQa659HSq1Srf/u9/4u/e/3pGN61my3jMyVGIZZJ+Jj1Zi3Ll8Hu6CCHIZrJksjlWLFnEuWeeQXtnN1O1Gg9veBjXsUirMq0gwHbcfd04wzBm88Z1YHRSpVXPohQajRtXcaMqnqom/x9XSakaaV0jY+rkRGP6X50cNbKmNuPqZgz4foNms0rkt9CxxpgYHRt8v47fatBqVWnUq9SbNfxWC8txyRdy9Pb1HPacPBHHdHfcbDYRlkXKdadLxUGurUCzMoGbTfrZBTJF02+QSqcJwpB9CR37wbVE8rBci4/845d45+ceBP9AveyCfouVaZtTzu3HcyTZYpFb45Noa7qsOG0VD5XWcu7Z5yDVJEoZwkhww4evJR038XJ1/vo9L8btOgmhq/zk9ddgveYqXnhVkdL3IzTQ0eWyoxI9qbJqUko8L5Okw9g2P/rFTZx2+tlUymVGy1P85d++j2azRjabx/OyRGELX8cYBCNjVQwS2wbbnkUFCKqoX3+AWivGj6dTRLWh5kdY4rHOnp5jY1sSz7JQxnDDgzP1bk7KiyRt0GyUipHGZmjrA4xufYgzr3pNokKJpDefJsZog9LhrM19DgfHlITtvfOpTY0SxwqhQRuJUBGZbAq/ZUDHCDL0d3fRrJdxnYiZ0pG0TkoOB7GkVLGJwuCAYwCec9lClp+1EoYmyZ15GraV4e5/uZPdk4pTTv5r5rX9Ln5tDNXSjA8PY4RHeftGOlZdjFfsJ1JJsG4wspVyezvbtu9kYnQP3nTz60VdNgv6XRwOVh/n8dBa02q1cD2PTVu20dnVwwMPrAWjsAQ0m42kkKiwUCrad/e2bbFgwUKkncIoHz+YOc/YsyUvOG+QVMYm8hVxnLSoDXxDFCZzt22iwf3DJbaON4ji/UOHD4SUEomFX5tEpjI0RzaTijIsWXEpUhiMNEgtMFJjjESaGJCzqguHg2NKwjQ+qc52bFviRzpp7qJtlLLwcNGqiecUSOdyNKqTeF4GacETywYICc1WRKsFl1x+GVe84VMwAxFOv/xKrHSGqKmh7uOecyZO+i5Mc5jJPUN0tHWhGmVKE2X++lP/zVRpjN1bHmLZhVcQTO7A7RyEuMque29l3jnX0KxuxrYKTFmSUQF4Lk4YctoFiw97DoyBiYlRHMclm82RchyMzJCyFAt6cqzbsgemJVYcx2gdI6VgcKCbK5/3OzheGqNsQjVzc8dMew+/85E7n8RTmR1xFFIsZEmnHSam1uJPTRC02sl6Dk7eRQiDMIm57LGAJzFdmfzI40CPqU5YKteJ4wjf9zFxjOMVcBw7SQcQSc1qvzZOHNQptuVIZ7Mzfs9ZZ61MGlXbMbVmianS1IzHZRYtxe0o0Pac5+L29SCMxSc+9Boy7T3806c/wf/+49/y/ne8G2P3s23PKK+++mSmRsYJq+P4tSlUrNChoPvUC+nudnHcFBMT0L/QYvl8i9P9Jst1TPWWQ3d22gujFb7foFqdotlsJPWmRQWlIlpR8iJ50yWGwaC1wnUkf/ynf0VPTz/SxBgVImcp+3E0oZSmUq3zyMMb+PB/3cv6YRDawo8C7GJXUqxdApZOjPACkvqxSU/mI8UxlYS2K2k0oyToVQUEkcF104RBC0gq0afb2kmlXEqlFrpVn9EQPT42Rd+CbibHx3nrn76NDWVvRtut1im8+cuo3/JdMhddRbxrO7KzHdsVNKqj3HDXdmwTU6k0EMawZs0WLj+1SBxEREHA1nXrKLoRldIkYRDy0H07KQ0Pk7cFKUuQyksEEv0kigxZts38BcvI5fNs3fwopXKJTCZNqTzJzqEkLlEbnTTFFiLpwdLTQcrz9rX/MsLGdY99tf5WGNOo1unpm0cqbtLetwintZ3U4CKclEsUxUlRVFRSSYy9/ZkthJyjJLzgquc/6XO+8chNED7e5LBzaIJqo0WoNJ//xOe45LWfIp0/0LKvwwbVB24jfdHz8NfdjdPbhz8yhasUL7n6PFI7H+Zsx6HHajAgDA+N1DntwitpNZogBf/6xW/x3EsXMTTpsGfHdq6+7GR+e1eAVSnjxBrRlKRPd/EfOPzdsdaakeFd5OptLFy8kj27tuKlPFJeinqjmTRe1Jo4CpBSkLYlHZ0DZDJ50AGRTpZqHc1shjkaXqy9tsO05/Duj36Kt/3+7/ChD/0FOgrY8MBO+nsGULHBksnLJxAYS2CERmh3unnj4Ye3PRHPCN9xd9c8Jqub8Rsx3e0p8ml3pnBC0qecjbN9K07XPHT/fJSx2DSseOtffQp/3Te5rCeD5wnSmSwvmuexcyjCs1Ok0jkmx0Z4xcufy66dw/Su/xZZWeb+bzQoTvjkzsriP1wnc16e1v11nPGZNwn7E2LvgzXGkE5lqVdLdHd0YLsue4Z2o5RBCmtfiUVjDCnP5eorrqLcqFOq1HEciSUgNoZ4loq1R9NOaFsWIlTcevOtnHrKSlwron9g6XTxdp04FKaLEwid1CEyMkn5lXLmOTms6x6V0R9jTE6UGejqIb/A5aUnn8HD0pqRhNHUBDpj07zpG6QWnUm4+QEWZm2cPGxqlnDaBNvvL7Hcy1DJCX73jCKj2zfRakQMfenfiewity67lueXRrn4zKW08nWqU2Vau+qI5UW0kyEQPsHps1S6moEQSdylpqOjg3Q2j5gqJdXLVAwCXNdDq6RdRMq1cVNpTlt+Ep7nYFkOceQjTYCZJZRrL/ZajZ7ouQpa9X2x6n4Q4vsB7cU2wBxgakpJzaquTpZkF3Lzbb/lyvNOotg7SDNOdtnCEghtIY1GEYGwQMRJ2+anUPPmGUFC1/PwUimkqnBRTx+P2jatmVSQ8hDB+BSpc64ifGQ9ctES1Pqd9Jx/IZt/8vdE7SF956QZufe3XPHq62jcdRvO+BZu+eVqznzuEsY2j7IoV6bjgkWI7nk4U4/Qs6AHFg+gsQlNSHxJiqA2c6UwAWTcpMpWFEY0m01M7HPxhVcQxxFDY8PUayWktEilHWzbJQp9tAFLWszr7+Sks1dR7OhGR01ilcGzoVHzwZrZdSpEQry9pHui5+rmb38B23LRRvEn7/tHnn/1ZbzqyucShyGOa2PZSYS8Vpq4WeWeU5Zz/5p1/Mlr/4h02sNJZdDVOqATyS2TdmlCWog4uWtDUm3sSHFUSXg09ZP9ESmF1ZwAJ83/+f6P6X3lRTOeq5UBpWjcfTM6naP19Z+w+GM/pTq8hUxUo3OjpnlujqltP2PlNR/n1nvvo29Ectp1V7Hu619hoNLg7I98kMo9axme3EnbyYuI1m7BLmbRzRZ4DjQlojqzEp5NWbz5inZKpTI/+ebX6PDHeXTSYnDRSQhpUa1N0NnRjjCgtEZKQRhobNsil83woldeT29vD9J2UTpN5NcJtEUY1FF65r4lh4pUsaxkMzUyOoZrOfzhG3+XqbHRpP6hHyXEIsYgkVqx6JQ+Bpb3MzU6gm4v0ihPUugbxAiDMTJpFCQk2hgUMdq4KBUe1PZ4KBxVEh6rKBsR15GeQyOMyLdZVJstrBlaSwTbtkHcRGiwVyzAOW8lYaRY/aN/oaVKDJy3gGCiQbAsxf3/8JcssCPCBdspmJPxEfRetoCJn3yI7FgLzuxj5Bd3k79kIZ4fE5RqqLxFXGpQf3hmE5ExmiCMGB2bRPktioVuLjn5dLx0jlazTspZyfJli7n9zjsJw5AgjNBxRDaX5oUvfjFR0GDrlo1k8kV6e/tJZ7I06hWkUyAKnlzXqr2QwiUMA770te/zJ//fG5Ka2RZELT/pOUiMNgrHdonDkGatRTadoTE0jmn4DK5cRMpLoaRESIc4ahHHBmk7qFhhOQo79omiw48seiKOCgn390POFFETVEpI255uEJjU/BPTxcSFtAgjH60ivJRH2T8wisYPY4TMkEnBUClk8Swv3fw33fD4P1ya/Lj6nV884Ngrn/j72z9/+Dc8C8IwolYr06qP0rlkBQ89tI5XXLKAbDaH7Vhoc1aiC5Z3MTQyzlS5wlkv/n1WXXwVruswNLSbnVse4dF197Jg6VksXLwk8eeGMevXbZr1untryJTrB+7aDYbv/eJXbN0ywiUXn42UMnG1GU0UxMlzMEnznmwux4JFi4nqDQoD83GyKdLZAs1aGW1ZhCYijvzp2tk+WgkiFWNURBwdZ51w/yibmSJqbv/AW3Db5qFzBRZ2L0R6mkw+T9Sok+vowW5bAuk0Ip3mjf/82wOWGGMcMDqpqOC6aGavE3g80ahXuX/1ThYM9rFwcZH+efOpN5P0zpRnk/JcdFTjxvseJetILClZsuJ0HKmIwph0OkPv4FK2blnH6t/+mjBoUezq5Tvf+Dq7d26H//i3Ga+7t4bMTKpQo9Hg17c9xMrlC5GJdXm6X7IEDVorjFA4MocxBi+TI53Oks6lcL0skd/CsdNEBKCj6UYEiZvRiBhQKC3RHGdJeOirWCjTojrqE3f1kqVI2AqSnIswxLTKoFoQz+wxWXnaWXi2RdBqEMka8inoH8cSxhhu+cX/8ro/fB+ZXBrH81BaoHVIsxUTBAFRHHHW0kFuf3gXvl/lox/+EB/7xKeQQlNv+gzv2cXO7Vuo12pUajW2bxtNEqJmyTs+FH726ztpNBq86+3XI4Wc7h4gsCyIwyRKBi0wRuHXG1jSIuV6qFgTyRDXzVBr1ZFOUncIw3SUd+Iv1irpGDBbc5/DwdNCwvmLzmAyrOEKHwTEukmaHI1qlUK2gEBibBdqlRnP//63fvC43/dK26cj3eBwsHcz1dc/wLdue/iQx7/5+jce4ohDNxk/XPz8xnt4zStewMBgX7KPFRLLktiWTSgsYq2xRISKQqxYksunMUoTlmuErkEXBIHfIOsVmRjbg5tLuilonZRPFsJCWhoze+OtQ+JpIWFoJEZL0pkcKorQCHAhl+5CWhJdayRbfC/9pL53LhV6nKvo7OzklS9/HgILI5PI9mw2T6vRQFoCEcWsXHkW6++5D8tSNCpTZDJpMDbZvjytVguEhbQsHvzFf5MfPIll516CVhJjknYX+0oIHSGeFhLuGdmDMIZULktrsoRJZ0kbgUmniZWN7TrIZhMTHJ5e8XQVcpxpkzVbKsPTOa4ngyWLBqabhRuETjotpLMFHHeCIBB0dnWze8Natg3tpLctR95No3SDdL6NVqtJOpcDbWjWa4RBE0cpGqNjuB0daCNQGoxST6m55dNCwu2lCTJY9FsWUSpDxpIERqBjg7Sg2YhpTIwzsms3Ri9+zPw/C56uQo4zbbIOlsBTrgdPm3pwuLkif/q2308K3BvQKIQRSKnoH1jA2OgerFbMnnKZwSUDVMYmcTFYfkS1NEop2MrlVz+XerPG5Og4lpPGLvRiPDdxkGgDRqF1TDxb5Pdh4IhJ+Ndfun1Gk0B5hlYOjeyVAMhAYE1YiMnptloGhFTTbbY8YGnyR56e9NJD4WAP+pmiCtjWdGJZ4qBOEqaMQMUxeTfDjp0bkdmkQXi2s0Bp1xgpJ40xhm3r1nPFNdfSqFcpTU3S1rcCN5VOeuapGK2SpKxEIh65UnjEJCzXg4M+hMc9JGs/Xe+JL8w+l+jjxfmcf8jGIHVrX1i7bVkorXBcj1QqWaZt+7FUhSfm4c60nB+bLgDWdIajTrqEYmg2mgSTk+jYMLB8BRjN0NAQlfIElShgfHSCWEM9bNGoV9m2ZTOua+Pm+okjk0S2Czvp8mrUdDevw482fyKe8nJ8tGsyP7F59v4tS/a/TtMP930o5XShTgx+yyfa23LriVXmxN5eSY//m46TvBHLTsKRwsBH7lcirNjfdsA4dVDn7RdlueW3t3L73feR8Wwsofk/n/8PMBrfj1l58op9x+9dxvf39T4xx3f/pV5rRVgvY0uBNobeeQP7jnuiXnpwXdTs6yCa9KeWrP7tvdjCsPjkk+ls60AIQaG9B61CVp1vaDaq7Nm5nZ3bdjA2PMLI6G4KxU5q5RqF9ja68hmEFQBJZqDSmvhJlMt7Ip4yCY91G4fZ0kk//+UbyaQ8pKXJ5VykDLEsidI5du94hK/+9w+SMnFJk5XEnIBASIkUSXsu13NpViaIG3vwm02WnP18IiW4+9YfMbBoCUIIXCfFNz9+8wHjsh2bcnk3i+d1UzlpGeND2+koFmnv6GT9uo38+3/+J/96w5F7YYJ6me/+4/Ws6u8kCgK+OVk75JzMBKUNUk43DdISLaF9sB+tFd293dP6d2IAFJaFJTX5QpHFy0+lv3eQVr3Ki1/1esKgxZYN6yiXKhgZo5QN07VrtVGzdh09HDwjomhmgo4DwliSsm1azQismO4OhziyGFy4AsexHydR96ZSSpm4BR3Xw7YdOooeqWyeoTGFipo4XjHJjJsuUmlmqb8hLZs1O+u88pw8/ZkFRGV42+d+QeOv/oZ0OoNlH7yT0kw67/46qJSSrGtx6fJFdBUO1vP54BgfncTzHFKpNOm0g23bLFu0FGkJNBKhNUiRhOmLJNjBGI1SAbaJaO/rx02nyWTznHNh13TTb00UhcSRplYrUa1PUasdmW8bjjIJO7uLaG2wbQvbcXA8F8txiaMQISAOQmzXJWj5XHr2xWzevpndI8MolWxOtNY0/RYYkJkCJo540ds+TybfccC10mY3QbgAT21D5ZdgOS5138KOy2RSLu/5vTP41NcfQomksLst5LRklCAFnmexsMvnnJVdXHj+2fzbl29nOJRoaSOkRb1SIp3Lk8nlZ7xXYwz1pk+lEtOc2sM9OxTYWbK5HNVqjSg+uKJ+ODrv4q5O0rbL5t1HXm212awShi6tVoNmw8bzXNLpTPJ8HAfPdZEknhRgn944vHETPf392I43XY2XpBSlSVQaKRwc29BW7CabbaOn6zhsTGaC43r7MjaVijGtGBk06WkrsXgerHlUYkIHE8GeoQ0MjY5R6OynVZ1Aa0O1WoVpsR7XK0jbmdUGmqo8SKrTxbJCfG0T+yHaOKhYI60Qd8VzecnlVaZkH7fdeg+d7iTlSpmevvk0VJ5OaxdRkKFSETz6yBivf+MVfPZ/KoTawXGSNhgqjonCmYkihKCYS9O58nwCK88pA/08T3fjeh5Q26+I6MwQAtqykij0cb3HJN3+/Ul+b9VpDE1MUXkKzYQq5Sq265LyIAwd/JaL7zewbRfHtslks6RSWVw36c5lhMZog52yaUyM4eSySDsPqKQolTH7wraM0BiVRA+JJ9FW44k4uiRMZTBGJJLQbpFyfAa7qkhlqDVStMI8rpvCdhQbd4ygtaY0PsyKFady9qoL+N53vkpbexc7tz1KHMY4tpi1t129VqXHvYta3ytIZz20stEmomlSqNDG1hbLr3g56UyBTD7H+jt/yujEFA888ACnrexH2x4pzybb1slo2ae0doKB/k6274lwXBcv5eKlUwdNZbz84lU0qhE/un8Sx6mSb2vDsR3iWFGvlQ86VynT4NqprxD6mld+8qf7/r5X3+vrn8f7/+FAXfTJ4g//4qNHdN6yc1/4lK99uDiqJHzFy67Bb1YIw5Abf34bo9WQqaEisbRZtGgxA/MjUqksGogjRavVYMvGtZyyfAW10iTl0hjl0gSpVJYoqmLb7qx26zCMiJWFV1sP6QvxUlm0CRE6Jmj5VFothIhIpcuct3IBF17wUf70+lcCgkAJ7MhQbMvz85vXcO3V12Kn23nPO8/m7e/9KbbjEkUROctJsslmwZq1m1jgRsSxIpPNUylXiMIYz7PZsHHmnnL7YKC8O6CwYuDgx/0/gKNKwpRVY9O27Ty0dpiWL0ErPvyu9/Dg5h1sG93Nxo2PMDk+ieU6FNo6cFNpLMvmuz/8FqlMDqU16XQaz3M4feWp3PvgI7Ney3HSaKVxajtQvVeglUJKC9tOEQchQihqpTH8hkN+dCudq15FZ+8ChndtIQpjTDpFsxmxZGEfZ69QnHnVc2nWxnC9LFJanPK8t5DKtgFixm6YsbH5zXg3v8Fgsv2MRgaTTQgb2zEDl54343l7BXuLNDcOvAlagptnOG42Y/1cdA0+VRxVEvb2LaK3byFu2xBSTTI8GvLVH/+QbXt20tnVl+QiSEFpYoxmrUq9XuXK576Em3/5PWq1YQA8N83vv/hKFgwMsGDeAPEsolAPPg87XE0tdyntro2RDlLE6FAAktD3qdXKaBXhhGP0DN3Pn3/gH/jAn7+ZWiNkzbpHOf/siBWDeZxUmjhKMTnRxJYaDDipHHYq2ZTMuIEQAi1mTnPcW0z2oBsPITHTuuBMxz0VY/1c9zY9EUeVhLlsDildXnh1Gy1fcfudq+lo62SiPMb46BC/95o/4tF197P64dWkswUyuQK/vesWlEoCF2wLFs/XrHnkh6zfZJCuS4f7uzNeSzpFItVNJAto7SGlQUoHRFJ6LmiVqZXHaTaryLYiZWse2Vw3/QvOwnEdlnIfCxf2sn14krd/+Me8/z3zOW/VAGHkP04FmGs9lQ/n4c55b9MTcFRJmE6nEdLB6AjXkTz3qkv4h7//v+hI4zoWP/75D7n0vPM4P52h1mrxyNr7iYI6TGfyF/I26bREWEUce4LFS5rU7BlblqCUoJE5G9fNY4xExyESgdERImxRr0wRRwGNepVmOkPND7jrxp8mEkwbCvkspbIPwmJkaIiNWydZ2B3iWpDNPVaibq71VN5/n/ZEiVdtBFgy6X88V3A46sNRJaGXKiTBCJaDjuq4KZuPfez9DO0Z4ev/8x2aQZ37H76f9q5eJkaHWbRkGZNTk2zduJaUZ+HakrERn8H5Ra599d/jN6d4qGLNWDFHOpJASSyjEEbhuWmCqIpbWUs9yBCNrgcrT7lcJZPOMTY5xcMPraFRr+E5gqhWI/AjOjqLvPnNb+SM05fzza/dwNK+pdzdbB604/xcwUwSrz0/N16aJ4OjSkLLspDSRgqDcnIQR0mJC23Ys2c3K5afTIzBc2zCKMR2Usyfv4QdWzbi2AZDijBOoUyWrvYOaO/gUT8/Y1dNx86DpUin0zhelkhHCCNwCgvo3fY9tngeyg+JI0W9Xmd49w5KE3toNSOaRGSFJggCmi2fnbt205UvE8UB11xS4Etfrc1KwitWphmZCIgNnN2XoZBOk/IM+ZQBJJYBY3wcAUIYNBaSAGUsLEsACj+SVFuGqWaAigVaQyvWtHxBDbA7BClbcusDB8ZXzqYeHJvgh6cHR5WESbtY8IMASYSXKjA8PMT//MfXsGyHjZs2MG9gAUEuoKO9Hb/VYmJ8FK0VuUIPF1/yXDZtehSUw4bN21m4YD5xFIB14DBtx0YageVmCcOIVFoibIeIAiK2kH6VZu8r6ehO3HVDUjLv8lMwxmBJgRBJVQGtDc2UxwOBTTBwCf/xoMP5rzkFO5VsGp645A284gYWSDEdCGGIMdSBRKnYi8fYsNczq83eQAIwrRLxj95NJYbRmqE8ndtezGrm9TsUihaFQmbGOZ5NPXgyhcrnGo4qCV0vi1IxnucRK4vdu/fw7W//hI/+5dv55vdvYs369SwYXMrgwAJy7Vn8VoMHHl5P5qwLGJy/mGp5kssvvoK+nn6+9F83MNBdY+A5f49tHZgAZXCJTRO0IpVNk8q41CdGEP440svjpitgp7HEYzqJZ8/8YAEaEWB51EJw9stpfuKSJzMd7M33ORIIkn7J9w+Bl4GugmDREujtTlHICzLpHMISSPGMdes/aRzVO5XSSSSNZWHZkiVLFvGud/8p99x9Hy974SXsGJ1gZHQH3b0dVHeN0QxihJS0t3fS256l7lk8umk9u4aHiOOYOFLMlrxg2ymkkChjQBhqlTpGetj5BTiDLdrkIiglyuRc2+EakxRQf+01GWxbYEkL4SYpoNqWWNKZNbuuWa/yuY+/j3f+1d8/zaM/djiqJMykPaSVRRuNJS3e/vY/5XNf+DwvfekLePCuOwiCBosWLePOu+/kpBWncNFpgzy8Ncspp55JNuWRS2myWYedwxNs23wjnjO77ziOQrI5iWWl0NhgaVSkyAifOL+SIL5n37FzbYcrBUTC0JFNgSUQMsKyXJSQSOmgpYtwZiah1hojjjyAdC7iqJJQI1FRiGNbSCn59Gc+w9v++O2ceeopNCtVmq0Wa9c/xEknn4cwPqefdhb5ziY//tXdPLRlN+9+08spZF0826ItZ4GcfdETegTjZ/ByAX7QgeMo7HSW8ZKm1ZpEmxxCzt796XjCACcvTHFn2aXlpHEth4XlSRYvEuQ9gxLRrJsMIQVtM9RmfCbjqJb/lEJjSZCWg5AWxbY8//Wf/8Yfv+Od7B4fQ2lDJp0nCAOEZbNmw04yWYcXXn0ZV561mHUPryYsDXPRxRchsOAgyTMiGsca/SXV0MOYmCjWTI5O0fBDhJVnaqpEs3n4HdqfThgDWxauZE+2ly1uH305hbe4jy/+ssRDGxqYMCRqzZx5aAyUKzNXBXum4uh7TCwPpMBx0ggToZSizQ6xbYcoaCFzeYJmleE9k9TrLdrb28mkM8S1Ef7qfW+lWh7jjhv/l6tf8Afc9MuvzyrI1NDdyMUXYZfuJsyfjXBcqjUfL+Pw/a/9E1OlcZY85/oDztvyyEOkckXybW1kM1m0NjjuYwGoe1soJP8f8OC9v2b3rmGEZF/5s6SzvdgXNh/HMX7LZ3KqzF33bqQ7207adfi7f/rEjGNP2YKvLV7Pl9RiAgQvdWP+OcjgPOds/vc7v+FPOwdoy8285CZGnrlZgeJIcXRNNE4KrQKEcTAqwrKnlW3jcP2b3sDHPvJRxob30NHRSxSHNJtNUqkU5WqdHdu38ej61ZDt4gc3300oXCYnFTO3mk4efqnq02SA3970JWr1gKnyJJaERMDPTN+1azdiSdBRQCaTZtGyFcxbsJhdmx7GTmVp7x0km8mgwhpEVfKORRQHCCGSgNh9A0iq2MdaEccxjUaTUqlKVG9ityJmUekAiB2bb6ZP56ypKguzNd5dX0AzjrAbDVRo+L/fG0KEguu/MMO5SuGm5mIlniPHUSWh0slu1nU8pIixrDRGR2ilSWfzTJZrfPM736FerfL5//sF0BGO45LyLPLFbj7xP79i06ZHSWfz1KtlUp4zawG+7eUC6+7+KROVINn+CpGEBWNjWdbjpNv+aFQmcD0PISxWnH4W0igeefB+tjz8AF2DCylPjKJCH9dNoXRMvVFDCIs4TpZHIZIYR6OT+NtYKcIgolRpsn13GctyyfR3k3YPokoIyakmJCub/EVtER3hOBkEm2/ZjmMgC7zn+pm7VrX8kL/792/zjved2B3PCGc6WteyBEak0CpCSAcpFTf8yw20txd533veA8JBWjZT4yMoK0VvRxvXP/8qHh4aJ9SCemmUOuC49qyJ8Df95l7iKMK23aRalzF4qTRGGcKoSSZTeLzk2ovmEEHDYIwhCC5ANae4547fsOikMzBoxnZuJwyb0w17NDqoUejqp3P+cjrnLWHrxrVMjO2k2aiyYfMOKtUW0rIZGgt4ZEdMD7sZ37MOLTzeN8s8tUmNGq7zb7KDjKmjjM1IJURN1XEcwZJed9byu0kK8bNLEh7VjYlSMZHSKA1aRUjp4DoWtg1vecPvU+zowXazSNtl+9YNCGkztGcby5YtI8TmVS96PqvvuZ3R8XFy+Ry+H866S9TqsZrLSilUHIER+H4T1/FQcTijibHWCKiUpli26jrSuTa+//X/Jt89HxM1CRsV/EaFRrlEGMQ0KlO0Wj4jQzvYvmEtm9bcQUc+wxmrrqCnfxmbN+9i3fqNbNu6k9GhnVgmYDR1DrujRYw0Z09OahjB9zK9VO007SJgOHQp/eSRpNVZCOeudFEHKX4307v1TMZRlYRCOtNLokRaHlIk+QcY+MK//Se27dFqtRgf3UMcx0xMjPDJT36WcrnK2kcfItXRSzqTJZcrEIYhCAtLziwJlQqTXBAVJQZy26bZrCZJ6CrGcuzpXOTHoxVEDO8Zpn3jWm77xde56PmvxrLTtCoTSZ/kUBHEirhVwU3naFRGqTQaBMMNIn8tg10OC1ecQbpzIbuGR8hYoCKfq666jlK5xMaNm6npBuogSmFoBMooHK2oG48/cPbw4CLBLbsMSEMcmINWPlXxCTvhrNCG6ZRKjTA+iBSlUpU3vuHNIC2iKKY0ObZvgoUQfORv/gopYNWFl7Nt5zYajTptxQ6i0OfU5Tm8VIaZioCuue+2Q45nJn9q1GqQsgxTezYighqb1tzOGZe+hM9/6b+ZHJ/gygtWYgmN7Ti0uQXqfkyj6VP1AzKpNvI9i9n08G857ZJO2gs5sp5ACou2Qp7+vj66cznK1Qq7R/bMOq60UEw4NilsVoZDDJoGnee3gd2g4Uds3tSgt+PADENI7IT6BAlnRxxWkI5DaLKkPBejFX/zwfejtEIKi2a9RhyH030xko5OfhjheR5bt22jVq9RbO9kdGQPC+dleMkrX8e6wCMKjp7FuTS+Ey+VpVYaJZ3JErUqCGG48OKL+epXv0GtNE6oNK7n0ZJpymNT2OkUYdikvb1AZXKY9oUrGTch6Jhstg0pbVbf/XOmKj7DkyWK+QKN1ux5uL6RTLUMmXqNF3YKvDjFUCPiuvNyPLjJpzTl86tbJnnbDOea6ZTaZxOOqnbR9DUKD4xK9MOwyfoN29EGfL9FELTQWqONxrbspAqC4+HYKSbHRtj0yFqEDrn6miv4+L98k7Jop9Y4ugbnjB3R0ZahVdoMUZ2ouov7fv0t+vryvO8dr6dn3gI6ewdoNCrc9ZvbGJkq0apX6enIUa/uoGRl2VoNue3O2xlcsZjApFFWjkDByPgotVoJFVfp6zhIMKfWpCKf9oZPa7LMpqkazUARxZLlS2xOOilHrm1mNSTlOZy2cuFRnZPjjaMbwCCSzkPGdgGfNWsexhgIghAMhKGftC7QiW/ZkAQ7JM0FQcV18gWHeedexA9+8UPGxkYoLPwdJEeWNzFTKLyOW/iVYVxLEjbGcdNFjNakc20ENZtHNm7D8SRp19DV1cbo2Dht/fOwOuZB0CRf7MWxJcvmDVKu+9xx633ERtL0yzhehkXdfdjEs3anh6Q0R23HMP9npeCH9yk6u2OyKag3mzSjiFALcp0zm5hsS9LdPnNC/jMVR5WEURRiWXZSbUF4fPpTnyFWCrQhioKkhITWWJaFEAIpbYzWaJKNRrPZYMWlLyCoTLFrz25U0KAwvbk4WnkT47qXNpmnfV4nk+USnYVejHGoTI6SalvAmkd2kCvYrDxpkO2jmwkI2TQ2xIRSnLl0JV1d/aTTOaTQDMxPYULYvmUD40N1utoLOKkMYdA6aJCBMJpBN2ZryXD7thora4bLV7k4Xpqscai2DI+MzHyv0rK49rIznvI8zCUcVRJeefm1j/t9zZoHnvJ3zlYHcX/sH1U8U1XV/dG37HxSjqC/p5vh++9gdGyMerWE621h8dJxBl5yCjuGdnN7c4TQDSmkOnh0eBdZ02DlWeeRyXXgpVI06iXGSlWGrVG6Fw6iVt/HSYuXEMYao9K4zuyuNQF0TUzw+Xsh0IkbTmsLYxt0ZFPIaM44aebYR601rVkacD9TMecjJw+nKuv+u+BDVVX9oz/5CyyZeD2uevHrCMOQ3bt2MTK8CyWaTNx0P9KxyacyDJd9Jm1FYUE3ODbfvvV7WFdErNuxgc17NlGbnOK8M85iweIlSdiZkERxgCMN3iweG4CMJTh3aTfnLqnz+R/5RIHG10CksFMeEgvPzPziCSD0n10BDM8ys+ehobQhUgalDfH0v0y+QHf/AnLZeXz4pe/lvS/6CxalF9CsNXEci6lKAynBStt8947vs6e8nWqlwqXnXEQ+04OZavCC330Ve3btZmTXLnSsKbb3zjoGY6ASa4yVZkk39BUFIQptZ9DaIjCaMJ5ZkgopcJ2DV/x6pmHOS8Kjjb2VVc10o2ulVFLPWSe2QVcYCuk8qxafya/uuoV0Oo2bdrEsi1Q6zRXnvZjxqV10FEew3QKnDi5j1+h2duhhrnjelTTLVaTl4Hmzx/wpoxmp1nFSmt6CoegJsCwiHSCMJIpiLG/2VASeZaH/T/lunmnZ/o1mCx1rEEkIVhRFVCpl6rUqYehTzNgYpeksdtHVWSCMAgwWqbRNvdakUhtjsjLBvOIAv1l/D2s3r6HcqGApxRtf/XukwzDZcB3EvyuFxLUF1bpmoimY32dR8QVexgMrRNqdNJn5npKWYHMwUvcp4CmT8JmW7T85WUZM19oKWk3CKKRSmqReqxCFAYX5XdSrZSZGt/PCc6/lwfpG1j+6Fa1iHM/mlgdvxdYO20c3kXaLPOesK9k9vA0TV6BhoWKNkTGI2aNoDAZpu3S0pWk7PSYULu05D6VjwtgCVPIdM0AIiMPD7zz/TMARk/CpFuaZqR9IaXKclh+STjlonUgqpQ0Z18Kxkr66oRFEOumS3gpaCJFGK4WXyiAOURMQwPd9jNZEYUgQtoiixDQUtFoEfoNa1WV45zbCSOO0WizuWsRGextd3R2UyyWy2TSWtjh13kXsqe+iqRr09AywZUOJn935M1587QvxN40cvAe1kIi0i2W7uJaFNpKWiIi1RNoKLE0Uzaz3KW2Q1glJCDz1XiIz1V1+y6uvpTfrsm3nEH6zyY6dQ+wZa3DB0izLu1I4/fP57pbdjO6Zor03j5P2WHnW63jg1tVc/rI/Ip09tBG3UqmgtQajCYMWURjQrFUJgyatZp3qlE4KV7ppqlHAdcsvZcf2zbTsiHkDXSxrP4titsjaPavJupJ7N/yGWqmEDmM6iwXWDW1mmd2Gah1idbAlSIumjvBsDyEMykAU5UG3CMTMJLSkJHUQffOZiDml4ZYndmPiDmxiJkpVtEmKJFmWha/gpj1VYl+T7y9g57JIV+GlIjK53KG7T0+jUqkQBgFaRcRxiIoCmo0Kkd8gikLs3k4yhS7COElJ2Lbufl5wyqVMuHn8qMrm4Q3c9cgtlKYqWEhQCh1EFPIOcRgTNOu0QhcdHTzIwOg8oQVIGz9KShjbroNQEVpmsWeIAIJkAzUyXnqyUzunMadI+L+/Wn/E5x5uBYJWq4VWCq1DosAnaDVQsUIZiGOFZTtkCx34E8O0FTuIW1P09c8n1BHDux9laHQjo+u2ooVFuiePiUMsaZFJe4S+j6NtopZ/0Fo2bZ39fOJbs/cvPhQ6ige2tHgmY06R8Ghg/936TLvmMPAxJkbHiigKk9rUSmFUIrm8TI7y+ATtnX0MDA7QqIdkBzr5zo8/x+Z1mxjavBuvu4jxPFQc4TkuSsHI7gmM0px3qsAPApQ6NuFWQkr2DI0dk+8+XnjWGav37tafWEZtLwK/SRQESVRPs07/vHksXLIUy3a48pprEXYKP4i4+uqr2b55C8tPWoloGF676k28/so/ZP6pp5BKu+Q8iY6hWQmIlUEhKLTn6BAF4tgQhsfGtaaUIpuaO6XfjgaeNZJwpt36TL7joNXEsiy0VrR3dXPG6SejtcWqc86hWgsYH93IQ2vu4+F772T5KWdTKU3iOjbdHUWy6ZW8s/AGqo1xHhzawh0P3k/sWXS0d5CpVFhQyHDhGefyi5tuJD5Ic5mnEhHUVuzggx/+lyd17lzHcSfh023sbjXr+1psladG2bxhLTu3bGCqUqdSrXD++Rdj2Zqdu3axaftm8u3trDzlDGzbIZPO0lfMkadG/+KVXLv4ZKpjOxgf2YXp6MLL5Nj24K309w2yecuGWcfwTLOtHmscdxI+3Q8kU5xHdXxLkkQeJx3Pe3q68VJpBIZ6dYx0OkV7zyCnLz6ZkZExFixqkMnmMAYsJ4Xr5YhUBb9WBiPo6l1AaXKM8dE9FAp5Rhp1VDz7cvxUCjSdKJx+FPF0TOZMy/Hqe25hx9ZHuerK54BRgAHLQlo2QmhUFKAcm4suupyLLr2SRqXMyPgY2WweyxbEXh6tR4jjpOu57aaZGhui2azRVuwD4+P7TcKDmGjmSoGmuYLjRsKno3H2TGab737zy0fhmy98SmcfCxXkyfjP5xqO+3L8/yJO6ISPxwkSHgccy6Kdz0Sd8f8JEs6FcLO944ATOuET8f8ECU8sf3Mbz2oSztWlaa6O63hBmGdC15gTeFbjWec7PoFnHk6Q8ASOO06Q8ASOO06Q8ASOO06Q8ASOO06Q8ASOO06Q8ASOO/5/f0BzPe2toMUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "plt.axis('off')\n",
    "_ = imscatter(dogs_xs, dogs_ys, dogs, ax=ax, edgecolor=\"#5b82b3\", zoom=0.3)\n",
    "fig.savefig(\"dog_scatter.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "planes_x = torch.randn(50)\n",
    "planes_y = torch.randn(50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "plt.axis('off')\n",
    "_ = imscatter(planes_x, planes_y, planes, ax=ax,edgecolor=\"#c23335\", zoom=0.3)\n",
    "fig.savefig(\"plane_scatter.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "dog_embedding = torch.load(\"../../../data/dog_embedding.pt\")\n",
    "plane_embedding = torch.load(\"../../../data/plane_embedding.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x7f6cb2ce9a70>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.manual_seed(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.distributions import MultivariateNormal, MixtureSameFamily\n",
    "\n",
    "# Correlated matrix\n",
    "correlation = torch.tensor([[1, 0.8], [0.8, 1]])\n",
    "correlation2 = torch.tensor([[1, -0.8], [-0.8, 1]])\n",
    "\n",
    "mean = torch.tensor([0, 0.])\n",
    "mean2 = torch.tensor([0.3, 0.3])\n",
    "\n",
    "p0 = MultivariateNormal(mean, correlation)\n",
    "p1 = MultivariateNormal(mean2, correlation2)\n",
    "\n",
    "samples1 = p0.sample((40,))\n",
    "samples1 = torch.concatenate([samples1, torch.concat([torch.randn((10,1))*0.5, 2+torch.randn((10, 1))*0.2], axis=-1)], dim=0)\n",
    "samples2 = p1.sample((50,))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "m_est = samples1.mean(0)\n",
    "m_est2 = samples2.mean(0)\n",
    "\n",
    "cov_est = (samples1 - m_est).t() @ (samples1 - m_est) / 50\n",
    "cov_est2 = (samples2 - m_est2).t() @ (samples2 - m_est2) / 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "p0_est = MultivariateNormal(m_est, cov_est)\n",
    "p1_est = MultivariateNormal(m_est2, cov_est2)\n",
    "\n",
    "x = torch.linspace(-3, 3, 100)\n",
    "y = torch.linspace(-3, 3, 100)\n",
    "X, Y = torch.meshgrid(x, y)\n",
    "xy = torch.stack([X, Y], -1)\n",
    "\n",
    "Z0 = p0_est.log_prob(xy).exp()\n",
    "Z1 = p1_est.log_prob(xy).exp()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "\n",
    "plt.scatter(samples1[:, 0], samples1[:, 1], color=\"#5b82b3\")\n",
    "plt.contour(X, Y, Z0, levels=5, colors=\"#5b82b3\", alpha=0.5)\n",
    "\n",
    "\n",
    "plt.ylim(-3, 3)\n",
    "plt.xlim(-3, 3)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.ylabel(\"dim 2\")\n",
    "plt.xlabel(\"dim 1\")\n",
    "plt.savefig(\"embedding_dogs.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAJcAAACXCAYAAAAYn8l5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAfo0lEQVR4nO2deXTU15XnP79aVKpNtWgpLUgsQsbsIHYQiwFjs5jV6cTujtvpM3MycZwZxz4zObZPOukz045nuuMsdjs9aU9sJyTBNthgFoPZDRgjgST2RUgItJZUKlWVVKXaf/NHSYWESkLCFIjy73OOz7Hqt71f1Zf37rvv3vsEURRFJCTigOx+N0AicZHEJRE3JHFJxA1JXBJxQxKXRNyQxCURNyRxScQNRbwfIIoiHo8HAI1GgyAI8X6kxBAh7j2Xx+NBp9Oh0+miIpP4ZiANixJxQxKXRNxIOHH5rFYcJ0/is1rvd1O+8cTdoL+XNG7dRsVrv4BwGGQyCl55mcy1a+53s76xJEzP5bNabwoLIBym4rVfSD3YfSRhxNVRU3NTWF2Ew3TU1N6fBkkkjrjUubkgu+V1ZDLUucPuT4MkEkdcKouFgldevimwTptLZbHc34Z9gxHiHYnqdrvR6XQAtLe3o9Vq4/k4fFYrHTW1qHOHScK6zyTUbBEiPZgkqqFBwgyLEkMPSVwScUMSl0TckMQlETckcUnEDUlcEnFDEpdE3JDEJRE3JHFJxI2E89BDJCnE39yMv6WFkNuNGAwhKBTINWoUKQaS0lKRJyff72YmPAklLlEUcVdU4Dx5imBbW7/nKlJSSM7KIjl3GOrcXGRJSfeold8cEmbhWhRFWg4ewl1RAYAsKQmVxYIiRY8glxMOBgm53QQcToJOZ49rBbkcdV4emtH5aPLyEBQJ9W/uvpEw36Lr9GncFRUIcjmG6dPQT5iArA+RhH0+fE1NeOvq8FRfJ+h04jp3DvuxY6gsFgzTpqEfNxaFXn+P3yKxSAhxhYNBXOWnATDNm4t+7NiY57WdP4+zvBzDlCnox49HnZuLcdYsqv/9/1L/l79Gz3NXXEU39mE0o0aRMnkSqvT0e/IeiUZCiMtbV0fY50Oh06F7+OGY51z+2T/RtHNn9O+MlSsZ808/o+5PG6n9f3/oca796FGSc4fhqazEU1mJOjcXw7RCKZRnkCSEuAKtDgBUmZkxywW0nT/fQ1gATTt3krZ0MdfefKv3DUWRlMmTEQQBd2UlHTU1dNTUoM7LwzhzBkmpqfF4jYQjIcQlBgMAyFSqmMed5eUxP7cdPAyx5jOCQMqE8RH7a/o0XKVltFdU0HHjBh01NWhHj8Y4cwaKzomKRGwSwokqKJQAhP3+mMcNU6bE/Dzs88b8PPup76AwGABQpqSQumgh2X/zLTT5o6DT3VH/wYc4Tp4iHAx+/RdIUIa0uAaaPa3QR3qQwC0uhi7048eTsXJlj880BQVo8/NJXbwYug2lxpkzUWi11P5pI9adu3BXVBAOBlEaDKQvXUrm+nWoMjMRg0Gcp07R8NFmPNXXv+abJiZDdlgcTPZ0UloaAIGWFsLBYEwXRO73nkVQKui4fgPN6HyyN6xHk5+PIAh4GxtxV1xFrtUg+gN01NYQaLHjra3FW1uLTPUluofHoB8/HlV6OpbVT+CpqqL1+FcEXS6a9+xBM3IkprlzpKGyG0PSieqzWil+Yk3PJFeZjJnbt8WcsYmiSP1fNxFsayP9sWVoRozodY515y5s+/ZjP3o0YmfdRrABhwN3ZRXuy5dvevtlMrSj8zFMnYrSaCQcCOAsLcN15gyEwwhKJaZZs9CNGyvVIWOIDouDzZ4WBAF1p6DcVytjnuO5ehX7kSM3DfjbpPsrjUaM0wpJfWQRycNyIg7VcBj3lQrqP/wI28GDhL1eTLNmkrV+HSqLBTEQwH70KE07dhJwue7k1ROKITksRrOnb+m5+sue1haMpu3sWTqqqwl5vT0WpsVQCL/d3vuiTsGqLBbCPh+ea9fw22yEfX4EuRxn+Wnq/vznaE838kfPk5SRQUd1Ne4rFXgqq9CPH4ehsBDLmtW0nT+P40Qx3vp6GjZvwTR7Frqx39xebEj2XHeSPZ2UlkZSejpiKETb+Qs9D8pkKM3m3hd1Ctbb2Ejdpg9oOfwFbecv4L56FUdpKXUbN/bo6a799k10D48hc/06knNyEEMhXGfOUrfpA9ovXUI/fjxZT25AlZUV6cWOHKV5zx5CHR136Zt5sBiSNlcXg82edl+9im3/AWTJyeQ8/RQypTJ6rH7zZlqPHe9lc6Uve5T6Dz+KePgNBjQjRyLXqGk7d46qX/6q1zMsq5/APL+IlIkTCXV00PrlcQIOBwAqSwbm+fNRms20nT2Lo7gEMRRCrtGQunAB6ry8Ab97IjCkxTVYxHCY+g8/Iuh0YpwxHUNhYfSY/egx2s6fR5WVRXJ2dlSwzvJyHCeKUaaayVy7NjrTjDmpALKffgqFVouvuZmw10vao0tJMptxlJxEDARAJiNl8iSMhYUEXC5s+w8Q6BySUyZPwjhjBoJcHrfvYCgxJIfFO0WQyTBOnwaA6/SZHsOResRwAAKtrRimTon2hIGWyA+vHV3Qw4URHZq720uCgCotDcepUqxbt9G8ew8XX/rvXPvtW6Q/9hiaUSMhHMZVVk7Dx58gBoNkrluLfvz4aJus27cTbG+P6/cwVEgocQFo8vNJSksj7PfjKC6Jfp6cnY1cqyXs9eKpqop+LoqRnkmQ9/4qjLNn9VweEkWuvfkWrtLSHue5ysqofe895FodqY8sQq7REGhtpXHbp7QcPISQpMQwrRCZSoXP2kTDlo/pqK27uy8+BEk4cQmCgHnePADaL13C1xhxNQgyGfpxkVAc5+nTdFkDCl0kZqtr8bsLMRikceu23g/ow4rwNjRG7KwTxaRMK0Q9ahTtFy5y6eVXOPfc85z9wQ+RqVQR4Xu9NO3ahbOsjETe7jLhxAWgyrSgGzMGgJYjRxA71/9048YhS0oi0GKP9l6qrEwAvDU1PX5o17lzhDyensMi9P67E3PRXBQGAyGPh9YjRwna7RG/WheiSNUbv8I4e1akbaKIo7gE2759hAOBu/XqQ4qEFBdEhjS5Wk3AbsdZVgaAPDkZ/cSJAJGZXDBIck4OsqQkgu3t+Orro9d3VF9HodWS++zf93SJvPoKacuW9Xpe1S9/hbeuDv2kSQhyOW0XLvQ6B1HEtncf5vlFmBfMR5DL8VRdo3HbttvG/D+IJKy45MnJmIoiw6OzrDw6PKZMnoRcqyXocuE6cwaZQoG2YDQArjNno9eLoRAAGatWMnP7Nib++++YuX0bmWvXMPa1/8W4X/2y5wM7l6BcpaXoJ06Irhjcit9ux7p9B+q8PCyrVkXssxY7jZ9sTbjiwAkrLgDtqFFoHyqI9BgHDxL2+ZAplZhmzwLAWVpGwOFAP2ECCAIdN25Ef+Cu+PmA3Y7KYsE4fVoPX1vYGztcx9fUjKv8NEkmE5lPPnlzGBUEcp75LklmMz6rlcaPPwEgc91aklJTCXV0YN2+A3e3ycaDTkKLC8A8dy4KvZ6gy0XLkaN4Gxvxt7aiSElBDIVoOXQYRUoKuoceAqD1+HFEUSQ5JwcAT9W1XkZ37cY/c+nlV2M+L3XRQgSlEp/ViiotldGvvkzmhg2RGDGNBt34cShMJkIeD9YdO/DW12NZsxr18OGIoRC2fftxnT6DKIoP/IYNCeVE7Quf1Urjp9tpv3DxpodeEEhdtDASVTpjOtoxY6j/4EPEQADzgvloRo6kbuOfEUMhLKufIDkrCwBvfT0la9bFnDWa5s7BMH0ahmnT6Ki+jrc2stCelJGBIJPha2wk6HYj1+lQGgwEOz37KVOnYJg2Dcfxr2g7fx6AYFsb9R98OKAIjqHKgHquYDDIb37zG1566SWOdJ8BAT/96U/j0rC7icpiQVtQ0DMqQhRpOXSYoNuN41Qpwba2qAPW8dUJxGAQ7ZhIb+YoLon2Xq5z5/p0R7R+eZzq377F6b//Hs4zZzDNnYOgUOBvaiLgdOC32aj/y1+p+f1/UPUv/xqNnHCVlWM/dBjjrJmYZs8m6HZTv+mDAUdwDFUGJK7vf//7nDp1iuzsbJ555hlef/316LGdtyQ+DFXkWk3vD0UxGkpj27cfzahRkQgJvx/bgYOkTJ6CoFDga2zEfSWSbKvOGVhde+uWj6l974+YF8xHmWrGb2uh8ZOtPc5p+OBD1CNGgkyG++pVmvfsQffwGLT5+b1v+ABu2DAgcZWUlPDHP/6Rl156iRMnTrBx40befvttgAfGCajJy4vps8pY/jhKo5GQ243twMGIi0CpxNfQgPvKZQzTIr1Z8969tBw9itJkxDRnzoCe2XL4ME07dqLOG96nf8z+xRcYpk9DUCrx1tVj3b6DlMmTYrb1QduwYUDiEkURb+fsKCMjgx07dvDaa6+xdevWByZWSWWxUPDqKz1+tMx1a0nOySH9sWXIkpLwNTTQfuECqfOLgMhsUpGix1tbR+1773PhhRcpWbMO9fA8DDNn3rz5rTt3dCPgcOIqK+szGSQcDOA6VYph6hTkGg3+lhZavzrBqJde7NHWjMcfjyaNPCgMyKB/4403eP/993nrrbeYP38+AOXl5Sxfvpy2tjba+1mIHQoGfXd8VivO8tO0X7yIXK0mZfJkTLNn4am+TvPnn4MoYpo3l6DDQdv5C4T9fmrf/2PPmwgCw777d4SDQdTDh5NaNI+mPZ9T/ds3e54nkzHht7+m7cJFAg5Hj6zuLlKXLkE7MjI0GqYV4r4UCatW6HQYZ83Ec6MG96VLCHI5SrMZy6qVyNXqOH5Dd48B9Vwvvvgi77zzDlmdMyaAKVOmcObMGV544YV4tS0uqCwWMh5bhmXlCiBSY8J17hyaEcMxzpwBRAxzVVY2qqws/DZb75uIIqrMTBRaLUGHA0GhIPeZ7zLyv/6oV4CjafZsMtetRaHXo42RDd6ybz+KlBQIh3GWnEQ7ZgxKo5FgezutX53AWDiVnKefQq7VErDbse7Y+cAEH34jXBF94Swri0ZOpC1ZjCY/H/uRo7RfvIggl5O6dCm2zz/nxu//o+eFgsCkP7yDr6aWjpoaFHo9mevWIlerYwY4Nm7dRsU/v9bnLDNzw/qI++LaNQCMM6bjrqwiYLcj12qxPLEKRDEiLLcbZao54t0f4jXGEt6J2h8pU6ZEvPOA7eAhOm7cwFw0D/XwPMRQCPuhQ6QtWRzJbeyGuagI16lS9FMmozAYCLa10bR7D+FAoJc3P7oPZF//hgUBmUqFv6kJ7ejILNFRchLtQwUozWZCbjdNO3YiyOWRIbFzuahp12eEfb74fTl3gW90zwWddb0OHMR99SqCXE7G8sdJslho2rkLX2MjcrUa45zZNH+2G3+LHd3Yh5ElJeFvbkau0WBeMJ+WQ4cJe70kZ2eTMnUKvsZG1Lm5qCwWHCdPcva/PBf74YJA3n/+TyiNRgKtrcj1elSZmXgqKkAQMBcV0Xb2LAGHA4XBQObqJwj5fFg/3U7Y60WVlUXGiuV9loq63wxaXC6XC0enZ7mLvH5iw4e6uCCySN28dx8d168jKJURgZnNWHfsxG+zIddqMRQW0vrll4ihEMl5uYTa2iOC0GoxzZ6F/chRHCUncRQXR27aaXMFXK7ehr4gkP3UdwBIMplIW/Yo9iNHCTqdKFNTUZpMeDrFbl64EGdJCcG2NpLS0rA8sYqgy4V1x07CPh/q4XmkL1uG0M+M9X4xKHH9+Mc/5g9/+AOpqalR/5YgCFT1s9j6IIgLIsGBzZ/vpaOmJiKwFctRGo1Yt++I2j4pUyZHvPehEMk5OfgaG6KpacGODhr+uqnnTWWyyHAY4yse8fwPCbhckbCf7GzSHl1K885dhDo6SM4dhiCT03H9OjKVitRHFmE//EXkWE4OGcsfx9fcTNOOnYihELoxYzAvXDDk3EKDEldBQQFlZWVRsQyEB0VcECki17x7D966umgPpjQase7YGRGYRoN+8iScxSW0nb/QMxjwTukc/jLXrEY3bizW7TsQg0H0kybhb2rC19iIIiUFU9E8bHv3IQYCUTF1XL8RdZ8Ypk/HOK3w9s+7hwyqL508eTK+IW5Efh1kCgXpjz8WyUkMBGja9Rn+FjuWVStRppoJeTy4ysojs8qjR+/OQ0UR+9GjOEpLCfsDpC5cAEDbmTPoxo6NTBhcLtpOnyZt8SMgCLRfvozr9Bk0I4Zj7opZO3mS9itX7k6b7hKDEte6desoKChgwYIFLF68OPpfItElMHVuLmIwSMOWLdgOHMA0cyZJGRmEvV7sx472Pfu7E0SRoNOFo7gYTX5+dAbr+OorzPOLoktDPmsT5rlzI8eKi+m4cQP9uHGkdJaIsn9xBG9Dw91r19dkUNOMV199lV//+tcMHz48Xu0ZEsgUCtKXPcrV//1/bi42CwL5P/kfJOdkE3S7I0szd0tggkCS2YS/uRmf1Ypp1ky8DfUEWuw4jn9FUloq7quVuMrLSV/+OLqxY2m/eBHbgYNkrl+HceYMgi4nnqprNH++l6z164ZEseBB2VyFhYWU3pJWdTseJJurOz6rleJVq3sKSBCYse2TSBnMXbv7trn6EJ5l7RoUWi3IFdT96U89YrXEcBjX6dOY5swh4/HH8NtsVLz2OvYvvoje01xUhKFwKpnr12HbuxeftYmk9HQy16xGFEWs2z7Fb7NFZpVrVt93F8Wgnj5nzhzWrVvHypUrSeq2KcAzzzxz1xt2v+moqektEFHEtv8A2U8/hVyjjRTlrarC8dWJXucl5+XhvXEj+pFx9mySs7MjWdnAiOd+gFynwzB1Kq6zZ7n6i9dBFCPOUa8X05zZvbKHugoBO4qLSVu6lIbNW/A3N+MoKcE0ezbpjy2jYcvH+G02Wo8eI3XRwnh9PQNiUDaXx+PBaDRy7NgxDh48GP0vEYlW2rkFX3NzJLBv5gzSH10aO/YKeggLwHHiBMaZM9FPnBjZdMHvJ2C30/jpp1ztvjQkilS89gtaugc2diGKBF0u3FcqCDqdUfG4Tp/BW1eHQqcjfemSqNHffvn+GvjfeA99f9xa3TDvH74HcjmEw6iyskhf9ig+q5XqN/+NlkOHotelTJkcrYvfHcvq1VhWP4G2YDSea9fwXK3Eefo0Tdt3DKxBMhkP/eNP8dbVoUw1k7V+Pfajx2i/eBGFXk/Wt55EplTiOFWK8+RJBIWCrA3rURqNMW8XWQetia4m3G0GJK5Vq1axY8cORo4cGdNRlwhO1L64dSG6o7YW2959hP1+FAYD6Y8tA1GkYcsWvLX1JJlN6MaPiyRw3PLVdhUxUZpMmGbPIjk3F19DQ58x+T0QBEa/8jIZyx+nftMHhH0+0pYsRp2XR8PmLQTb2kiZNBHTnDmI4TBNuz7DW1dHUloamWvX9Cp+MpiyoHfKgMTV0NBAVlYW16/HLizb3+zxQRdXLPx2O817PifociFLSiJ18SOoLBZaDhyM2GpEyl42fLQ5ek3a44+R+cQqnKdK8VmtKAwGVBkZJKWl4rM2Uf1vb0d+6D4mA6lLFjPmZ/+IXKPBWVqKo+RkpPfasAFvTQ1Nn+0GmYysDetJMpsJut00bN5C2OvFUDgV44wZ0XsNtizonTIgg37v3r39Hk9Eg74/ksxmMteuoXnvPnwNDTTv+RzjzBmkPbYMV2kpztIylEYjI374HDKtlkBzM4JCQf0HH92c/XVHEMj69rcxz5uLMkVP+bP/0Etg3X903bhxOMvKCbTY8VubIptijRyJ59o1HCeKyVj+OAqtFnPRPGz79uMsP41m5MhoYeL+yoLec3F1Ge2VlZVcvXqVFStWoFQq2b17N+PGjfvGiQtArlZjWbkC+5df0n7hIo4TxfhtNlIXLECVmYntQKRmqhgOY5o3l/YrFbGFBZFhddMmZEoFqoyMmD2X0mBArokkmciTk9GMGon7SgXuqipUmZZI1Or163TcuIG3oYHkrCy0+fkR266yipbDX5C5bi2CTHZHZUHvhAHNFt99913effdd5HI5Z86c4Z133uF3v/sdZWVl/YY4JzqCXE7q/PkRL7pcjqeyisat25DrdGQ9uYHknGzEYBDHiWICLS23vV/A3kr7pUsxj6kys3r83VWlsKu+hdJgiBZfcZWVR88zz52LTKXCc/06DZu3RJJ176As6J0wKD9XXV0d5m61RTUaDQ1DaLnhfqEfN44kcyrN+/ZF6nJ9/Anm+UVkrFyJ6/QZnCdPDsirn/P0d2KXbRIEjNN7Lkp37T/UvWp0ypTJtF+6REdNDQGHA6XRiFyjIeTxROP3K//lXyl49RUy167BNGf2oMqCDpZB+blWrVrFkiVLeOutt3jzzTd55JFH+Pa3v33XG/Ugosq0kNVViDcYpOXgIVoOHUI/fhyZa9egycvDXFTU5/XmhQtov3SZhs1beh0b8aPne//4Xb1Ot6FNmZKCOi8XIOrj8lmt1Lz73s3rOv1oXT3YrTUw7iaD6rneeOMNtmzZwqFDhxAEgZ/85CesXr06Lg17EJFrNGSsWI6rvBzHyVO4r1TgszaRtmQxmevWoh4xAvXwPAKtDpJSzegnTiTk9RLo3IvbWVoas2fTjxvX6zPvjcisVGHsmW6mHV1Ax/UbdFRXY5o1M/ZKQxyM91gMevFpw4YNbNiwIR5tSQgEmQxDYSGqrCxs+w8QdDpp3LoN47RCDIVT0Ywaif2LI/isVtxXrqA0mUhdtBCZQknLkSM07fqs13qm49RJxHAIdU4O4WAQX309rrPnANAVPNTj+ercYSAIBBwOQh5PbOP9HiXYSh76OBLyerEfOYKnKpLVo7JYSF20EIXBgPvyZWz7D+BrakJhMKB/+GGMM2fQvG8/Vb98I2YPZp4/H93DY6J/a8c8ROr8+b0cpPUffEjA4SBj5UrUw3J6OkyB1IULGfPP/zPu2UOSuOKM2LmFXuuxLwn7/QgKBcbp03FXVXG1KyuoM+JB9/AYNPmjUA8bRkdNLZdefqXnzQSBET/8AercPNQjR6DpY8XEuj1SmiltyZJoRpHPasVzo4b2c+cI+/2Y5swmZdKkuL770EwbSSAEQUD30EMkZ2fTcvgLvLW1NO/fT/1fN/VYrL659XEVnsoqxHCo981EEf2EidFqPH0R6iwdICh7lj4H6Lhejf9GDe1XrkjiShQUOh0ZK5bjvnyZ+s1bYkY8pEyZAuEQnqprhDpi1JYYgKMz4HBEa+t3eeThlrXEzp4y/dFHUcax/sTQy0dKUHxWK85Tp1CaTAz726djVrHRjxtL+tKlZP/Nt9AWjCZl8uQexy2rVuJrasJvsyHesnwjiiK+RivNn0eW6tR5eZHARLol5nZdI4rYjxzBdfYs8UTque4BsSIQCl59pUeKv7moCEdxCaY5s2k99mUPMRhnzUKTPwqFVkvrl8eByOqAwmBArk4GEYIuV3RnDrlajXn+TZ9azLVEwH35Cqn9+N6+LpJBH2f6i0AA8FRfJ+hy0XHjBmIwGKkq2N0e6zy/8C8bCbk9dNTW4m9qirmftyCXo8kfhWnWrOg6ZJ9tAEa+8N8Y9nd/e3dfuBtSzxVn+otA6O4dD7a34yguoeXw4ZhOz4DDiXH6NFImT0IMhwm2tRF0uaL1IuQaDUlpaci6hZ930bWWeKvNJVOp4vLOXUjiijMDjUBQ6HSkLX4EVVZmTEeqwpBy80+ZDKXBMChjvPtaIog4T5XGffc0yaCPM4ONQNCPHdurAqK5qIiWg4do2vM5HbV1d1wqtGstsYt4zhRBsrnuGYPdmLTrfJkqCW9dPR3dooAVBkOkMO/o0SgGUVoBIOzzUf/RZkJuN2mLH0FbUDDodxkokrgeEPytrbSfP4+74moPY15lsUQWxHOHoTSb+y1GEmxrw3bgYLT+RPa3nkSIY26jJK4HjHAggKeykvYrFfhuiaXr2nJPaTaj0OuQJalAFAl53PiamqOTC0GpxPLEKlTp6bd93tfJEJLE9QATdLvpuFYdDW3u2vqvP5JzsjEXFfWZbtad/jKEGrduu222kCSuBEEMhfDb7fhtNoJOJ8H2dkR/IFIWU52M0mhCPSynx5JQf9zOP1f8xBrmF3/V7z0kV0SCIMjlqNLTBzTUDYT+/HMgxvT434okLomY3NY/N4AymZKfSyIm/fnnosdug2RzSfTLYP1z3ZGGRYl+6eqp7gRpWJSIG5K4JOKGJC6JuCGJSyJuSOKSiBuSuCTihiQuibghiUsibkjikogbkrgk4oYkLom4IYlLIm5I4pKIG5K4JOKGJC6JuCGJSyJuSOKSiBuSuCTihiQuibghiUsibsQ9QaN7cpHb7Y734yTuIRqNpt/CJ3EXl8fjif6/Jc7bgUjcW26XKigNixJxI+5JseFwGJvNBty+G5V4sLjd7xl3cUl8c5GGRYm4IYlLIm5I4pKIG5K4Bsizzz7Le++9R319PStWrPha93K5XEycOJHq6uq707ghiiSuQZKdnc2uXbvu+Prjx48zb948Ll++fBdbNTSRxNUHoijy4osvUlBQwKJFi6isrASgurqaESNGAJHe7LnnnmPq1Knk5eWxceNGNmzYQH5+Pi+88ELM+/7+97/n7bffJjs7+x69yf1Dqs/VB1u2bOHUqVNcuHABh8PBpD42vqyrq6OsrIz333+f559/nitXrqBWq8nJyeHnP/85xluqJr/77rv3oPVDA6nn6oNDhw6xYcMGlEol6enpfdpZK1euBGD48OFMmDCBjIwM9Ho9ZrMZh8NxD1s89JDE1QeCIPRYdFcqlTHPS+q2S5gijrtRPIhI4uqDpUuXsmnTJnw+Hw6Hg927d9/vJj1wSP/U+mDNmjWUlJQwYcIEMjMzGTt27P1u0gOHtLYoETekYVEibkjikogbkrgk4oYkLom4IYlLIm5I4pKIG5K4JOKGJC6JuCGJSyJuSOKSiBuSuCTixv8Hn7VxEnCpdnUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "plt.scatter(samples2[:, 0], samples2[:, 1], color=\"#c23335\")\n",
    "plt.contour(X, Y, Z1, levels=5, colors=\"#c23335\", alpha=0.5)\n",
    "\n",
    "plt.ylim(-3, 3)\n",
    "plt.xlim(-3, 3)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.ylabel(\"dim 2\")\n",
    "plt.xlabel(\"dim 1\")\n",
    "plt.savefig(\"embedding_planes.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "plt.contour(X, Y, Z1, levels=5, colors=\"#c23335\", alpha=0.5)\n",
    "\n",
    "plt.axis(\"off\")\n",
    "plt.savefig(\"embedding_planes_contour.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(1.5,1.5))\n",
    "ax = plt.gca()\n",
    "plt.contour(X, Y, Z0, levels=5, colors=\"#5b82b3\", alpha=0.5)\n",
    "\n",
    "plt.axis(\"off\")\n",
    "plt.savefig(\"embedding_dogs_contour.svg\", bbox_inches='tight', pad_inches=0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "labproject",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
