{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4ce6f328",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import sys\n",
    "sys.path.append(\"../../src\")\n",
    "import model.sdes as sdes\n",
    "import model.generate as generate\n",
    "import model.image_unet as image_unet\n",
    "import model.util as model_util\n",
    "from plot.plot import plot_mnist_digits\n",
    "from analysis.fid import compute_fid\n",
    "import torch\n",
    "import torchvision\n",
    "import numpy as np\n",
    "import scipy.ndimage\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.font_manager as font_manager\n",
    "import os\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5f452f18",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Plotting defaults\n",
    "font_list = font_manager.findSystemFonts(fontpaths=[\"/home/anon/modules/fonts\"])\n",
    "for font in font_list:\n",
    "    font_manager.fontManager.addfont(font)\n",
    "plot_params = {\n",
    "    \"figure.titlesize\": 22,\n",
    "    \"axes.titlesize\": 22,\n",
    "    \"axes.labelsize\": 20,\n",
    "    \"legend.fontsize\": 18,\n",
    "    \"font.size\": 13,\n",
    "    \"xtick.labelsize\": 16,\n",
    "    \"ytick.labelsize\": 16,\n",
    "    \"font.family\": \"Roboto\",\n",
    "    \"font.weight\": \"bold\",\n",
    "    \"svg.fonttype\": \"none\"\n",
    "}\n",
    "plt.rcParams.update(plot_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "df22d86f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define device\n",
    "if torch.cuda.is_available():\n",
    "    DEVICE = \"cuda\"\n",
    "else:\n",
    "    DEVICE = \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6dfb808b",
   "metadata": {},
   "source": [
    "### Define constants and paths"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2cb7c2d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "models_base_path = \"/data/anon/branched_diffusion/models/trained_models/mnist_continuous_class_extension\"\n",
    "\n",
    "branched_before_model_path = os.path.join(models_base_path, \"mnist_continuous_branched_3classes/1/last_ckpt.pth\")\n",
    "branched_after_model_path = os.path.join(models_base_path, \"mnist_extension/8/last_ckpt.pth\")\n",
    "label_guided_before_model_path = os.path.join(models_base_path, \"mnist_continuous_labelguided_3classes/3/last_ckpt.pth\")\n",
    "label_guided_afterone_model_path = os.path.join(models_base_path, \"mnist_extension/9/last_ckpt.pth\")\n",
    "label_guided_afterall_model_path = os.path.join(models_base_path, \"mnist_extension/10/last_ckpt.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7ee483d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the branches\n",
    "classes_049 = [0, 4, 9]\n",
    "branch_defs_049 = [\n",
    "    ((0, 4, 9), 0.5, 1),\n",
    "    ((0,), 0, 0.5),\n",
    "    ((4, 9), 0.35, 0.5),\n",
    "    ((4,), 0, 0.35),\n",
    "    ((9,), 0, 0.35)\n",
    "]\n",
    "\n",
    "classes_0497 = [0, 4, 9, 7]\n",
    "branch_defs_0497 = [\n",
    "    ((0, 4, 7, 9), 0.5, 1),\n",
    "    ((0,), 0, 0.5),\n",
    "    ((4, 7, 9), 0.38, 0.5),\n",
    "    ((7,), 0, 0.38),\n",
    "    ((4, 9), 0.35, 0.38),\n",
    "    ((4,), 0, 0.35),\n",
    "    ((9,), 0, 0.35)\n",
    "]\n",
    "\n",
    "classes_7 = [7]\n",
    "branch_defs_7 = [\n",
    "    ((7,), 0, 0.38)\n",
    "]\n",
    "\n",
    "branch_defs_049_linear = [\n",
    "    ((0, 4, 9), 0, 1)\n",
    "]\n",
    "\n",
    "branch_defs_0497_linear = [\n",
    "    ((0, 4, 7, 9), 0, 1)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0364c0a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "out_path = \"/home/anon/branched_diffusion/figures/mnist_class_extension\"\n",
    "\n",
    "os.makedirs(out_path, exist_ok=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c77b6452",
   "metadata": {},
   "source": [
    "### Create data loaders"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "98285ad2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_049 = torchvision.datasets.MNIST(\n",
    "    \"/data/anon/datasets\", train=True, transform=(lambda img: (np.asarray(img)[None] / 256 * 2) - 1)\n",
    ")\n",
    "dataset_0497 = torchvision.datasets.MNIST(\n",
    "    \"/data/anon/datasets\", train=True, transform=(lambda img: (np.asarray(img)[None] / 256 * 2) - 1)\n",
    ")\n",
    "dataset_7 = torchvision.datasets.MNIST(\n",
    "    \"/data/anon/datasets\", train=True, transform=(lambda img: (np.asarray(img)[None] / 256 * 2) - 1)\n",
    ")\n",
    "\n",
    "# Limit classes\n",
    "inds_049 = np.isin(dataset_049.targets, classes_049)\n",
    "dataset_049.data = dataset_049.data[inds_049]\n",
    "dataset_049.targets = dataset_049.targets[inds_049]\n",
    "inds_0497 = np.isin(dataset_0497.targets, classes_0497)\n",
    "dataset_0497.data = dataset_0497.data[inds_0497]\n",
    "dataset_0497.targets = dataset_0497.targets[inds_0497]\n",
    "inds_7 = np.isin(dataset_7.targets, classes_7)\n",
    "dataset_7.data = dataset_7.data[inds_7]\n",
    "dataset_7.targets = dataset_7.targets[inds_7]\n",
    "\n",
    "data_loader_049 = torch.utils.data.DataLoader(dataset_049, batch_size=128, shuffle=True, num_workers=2)\n",
    "data_loader_0497 = torch.utils.data.DataLoader(dataset_0497, batch_size=128, shuffle=True, num_workers=2)\n",
    "data_loader_7 = torch.utils.data.DataLoader(dataset_7, batch_size=128, shuffle=True, num_workers=2)\n",
    "input_shape = next(iter(data_loader_049))[0].shape[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5be5f5ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "sde = sdes.VariancePreservingSDE(0.1, 20, input_shape)\n",
    "t_limit = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "51fbc829",
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO: this is currently rather inefficient; a decision-tree-style structure\n",
    "# would be better\n",
    "\n",
    "def class_time_to_branch(c, t, branch_defs):\n",
    "    \"\"\"\n",
    "    Given a class and a time (both scalars), return the\n",
    "    corresponding branch index.\n",
    "    \"\"\"\n",
    "    for i, branch_def in enumerate(branch_defs):\n",
    "        if c in branch_def[0] and t >= branch_def[1] and t <= branch_def[2]:\n",
    "            return i\n",
    "    raise ValueError(\"Undefined class and time\")\n",
    "        \n",
    "def class_time_to_branch_tensor(c, t, branch_defs):\n",
    "    \"\"\"\n",
    "    Given tensors of classes and a times, return the\n",
    "    corresponding branch indices as a tensor.\n",
    "    \"\"\"\n",
    "    return torch.tensor([\n",
    "        class_time_to_branch(c_i, t_i, branch_defs) for c_i, t_i in zip(c, t)\n",
    "    ], device=DEVICE)\n",
    "\n",
    "def class_to_class_index_tensor(c, classes):\n",
    "    \"\"\"\n",
    "    Given a tensor of classes, return the corresponding class indices\n",
    "    as a tensor.\n",
    "    \"\"\"\n",
    "    return torch.argmax(\n",
    "        (c[:, None] == torch.tensor(classes, device=c.device)).int(), dim=1\n",
    "    ).to(DEVICE)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c35fc1e8",
   "metadata": {},
   "source": [
    "### Import models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "40e98368",
   "metadata": {},
   "outputs": [],
   "source": [
    "branched_before_model = model_util.load_model(\n",
    "    image_unet.MultitaskMNISTUNetTimeConcat, branched_before_model_path\n",
    ").to(DEVICE)\n",
    "branched_after_model = model_util.load_model(\n",
    "    image_unet.MultitaskMNISTUNetTimeConcat, branched_after_model_path\n",
    ").to(DEVICE)\n",
    "\n",
    "label_guided_before_model = model_util.load_model(\n",
    "    image_unet.LabelGuidedMNISTUNetTimeConcat, label_guided_before_model_path\n",
    ").to(DEVICE)\n",
    "label_guided_afterone_model = model_util.load_model(\n",
    "    image_unet.LabelGuidedMNISTUNetTimeConcat, label_guided_afterone_model_path\n",
    ").to(DEVICE)\n",
    "label_guided_afterall_model = model_util.load_model(\n",
    "    image_unet.LabelGuidedMNISTUNetTimeConcat, label_guided_afterall_model_path\n",
    ").to(DEVICE)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0b38e89f",
   "metadata": {},
   "source": [
    "### Introducing a new digit class"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3738e63d",
   "metadata": {},
   "source": [
    "**Fine-tune new branch on branched model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4701b0f9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n"
     ]
    },
    {
     "data": {
      "image/png": "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AAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKKhSrVY7f7FS6fxFunT++edH3fe///2o27x5c9T169cv6rqzdevWRd2AAQOibsGCBVGX/m/285//POqgER577LGoO/jgg6Pu9ddfj7opU6ZE3ZYtW6Kuu3v11Vejbu+99466efPmRd1hhx0WdVDKuHHjou7++++PukmTJtUyTo/yX//1X1H3qU99KuoqlUot40BNvvKVr0Rd+l0n/Ts5derUqOsNFi1aFHVDhw6NuhUrVkTd+PHjow4aoaOjI+r69OlT1/fdtGlT1LW0tNT1fbuzs846K+pmz57d4Emgduecc07UXXfddVGX3qP9xS9+EXUnn3xy1PH+0s/wvn371vV9fR+ju2ttbY26HXbInvszZsyYWsbplW644YaoS393gg/i6KOPjrp777036s4+++you+OOO6KuO7v11luj7vjjj4+6ESNGRF16X2bUqFFRB43wh3aH/hiumd/rhRdeiLrJkydH3YYNG6Iu3auBRli2bFnUpXsmu+22Wy3j9Ch///d/H3VXXHFF1KXf/z7zmc9EXboPwPurVqud/qH0hF4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFBQc+kBerOvfvWrdT1v69atdT2vhPPPPz/qBgwYUNf33XXXXaPuBz/4QdTts88+tYwDNZk6dWrUvfzyy1G377771jJOj7PffvtF3d577x117e3tUXfPPfdEHXR3jz/+eNTNmDGjwZN0Hz/72c+i7sADD4y6O++8s5ZxYJsYMmRI1K1YsaLBk/ReGzdujLo1a9ZE3WmnnVbDNFCbM844I+r69OkTdVu2bIm6HXbI/n/sb731VtRtT2bPnh111113XdT99V//ddQ98cQTUXfcccdF3VNPPRV1hxxySNTRM11yySVRN2jQoKhL7wOcfPLJUddbLF68OOr69esXdaNGjaplnPdYtWpV1N166611fV9I7bjjjlG3YcOGur7v97///bqel1i5cmXUzZ8/P+pGjhwZdTvvvHPUpb8nPfzww1EHH8Tll18edddcc03UVSqVWsbpURYsWBB1ra2tUZd+FixdujTqSnzeAt3P5MmT63reD3/4w7qeB43Q0tISdc8//3yDJ+l5vvzlL0dduk84cODAqLv//vujjsbxhF4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFBQc+kBerPRo0fX9byHHnqorueVcPXVV0fdokWLom633XaLun79+kXdq6++GnXQCGPGjIm69vb2qNtjjz1qGafXeuSRR6Iu/ff87rvvRt13v/vdqINSrrzyyqirVqtRd+ONN9YwTWPttNNOUTdv3ryo69u3b9Rt2bIl6k455ZSog5Kef/75qNu4cWPUHX744bWM0yutX78+6tLvRE8++WQt40BNFixYEHWPP/541E2dOjXq3n777ajbc889o+7444+Puvvuuy/qurO77ror6j73uc9FXfr9asqUKVG3ZMmSqFuxYkXU0buNHDky6rZu3Rp1AwcOrGWcbmPYsGFRN3PmzKhrbs5+ahg1alTUvfbaa1G31157RV16bXXppZdGHdTbAw88EHVr1qyJukqlEnUXXHBB1J111lldNm1tbdFZ6T/DEUccEXUdHR1Rl37Op0466aS6ngdNTU1Np512WtR94xvfaPAk3Ud6Pzr9zrHPPvvUMs57pNc26XzQCN/73vfqet78+fPrel53NmHChKh77rnn6vq+CxcujLpLLrmkru8LH8Ts2bOjLr1Hm+7L9AZPPPFE1G3YsCHqVq9eHXVz5syJOsrzhF4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFBQc+kBerM+ffrU9bwJEyZEXbVajbqXX365bu977733RmcNHDiwrl2qb9++UfeXf/mXdX1f+CDefPPNqFu/fn3UjRw5MurGjh0bdUuWLIm6evv6178edZ/73OeibsSIEbWM8x433HBDXc+DUv7sz/4s6tLrjFI++clPdtk8/PDD0VlbtmyJuubm7JJ69uzZUQc9wdy5c6NuxowZUbf77rtH3bx586LuYx/7WNR1Zx/5yEeibvny5Q2eBGr37LPPRt0RRxwRdatWrYq6oUOH1vW8u+66K+qefPLJqEuuW+rtl7/8ZdQdcsghUZd+P03v87S3t0ddv379om769OlRR+82a9asqDvjjDOiLr2P8tRTT0XdySefHHWtra1R99Of/jTqjj322KjbunVr1O2wQ32fHbLXXntF3UsvvRR1kyZNqmUcaLj0OmjDhg1R179//6hL//Ym90j222+/6KxNmzZF3QMPPBB16TXVypUro+7www+PunXr1kUdfBDpf0f33HNPgyfZNp555pkum0cffTQ668gjj6xxmsZKrw2hEdJr+s2bN0ddqWvr448/Puo++9nPdtkcc8wx0Vnpzk+lUom61E9+8pO6ngeNkN7PGDx4cNRde+21tYzTLaTfddJ7qg8++GDUHXzwwVGX7tScd955UUfjeEIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoqFKtVjt/sVLp/EW69M///M9Rd/TRR0ddS0tL1I0aNSrqUqtWreqyaW1tjc669957o+5rX/ta1G3atCnqLr300qj7wQ9+EHVQ0ubNm6Ouubk56v7Q34H/q62tLeqGDh0adevXr4+6Z599Nup22WWXqNt///2j7uGHH466o446Kuqgu3vggQei7rvf/W7UPfjgg7WM8x6nn3561P3DP/xDl82+++5b6zh/lEWLFkXduHHjGjwJbDt/8Rd/EXU/+9nP6vq+Z5xxRtT96Ec/qtt7jhkzJupeffXVqFuxYkXU7bbbblHXt2/fqIOeYO+99466p556KurS+y3pd6f0v99bb721y2bjxo3RWRdccEHUVSqVqNt1112jLrVly5aoS//d7bBD9oyCkSNHRh00NeXXD+l9xsmTJ0ddR0dH1L399ttRl96XST8P6u2NN96IuvQ+z+DBg2sZB7qN9H7LV7/61ah7/fXXo+6KK66IujvuuCPq6im99po/f37UpZ/LUNLVV18ddZdddlnUvfLKK1E3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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Samples before fine-tuning\n",
    "branched_before_samples = {}\n",
    "for class_to_sample in classes_049:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    samples = generate.generate_continuous_branched_samples(\n",
    "        branched_before_model, sde, class_to_sample,\n",
    "        lambda c, t: class_time_to_branch_tensor(c, t, branch_defs_049),\n",
    "        sampler=\"pc\", t_limit=t_limit, num_samples=1000\n",
    "    ).cpu().numpy()\n",
    "    branched_before_samples[class_to_sample] = samples\n",
    "    fig = plot_mnist_digits(samples, grid_size=(10, 1), scale=5, title=None)\n",
    "    fig.savefig(\n",
    "        os.path.join(out_path, \"mnist_class_extension_branched_before_%d.svg\" % class_to_sample),\n",
    "        format=\"svg\"\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f5283fb3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n"
     ]
    },
    {
     "data": {
      "image/png": "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Rd38+fOj7vXXX4+6ffbZJ+p4q8suuyzqvv3tb0ddpVKpZTvwDx155JFR95vf/Cbq1qxZE3UvvPBC1DU1NUXdAQccEHXdunWN/0dl8uTJUXfOOedE3cMPPxx1hx56aNTRdd1yyy1Rl55bVqxYEXW77bZb1C1dujTqhg4d2mazaNGiaK1tttkm6tL38c2bN0fdP7s+/3v9+vWLuvT8nV6T9uzZM+rS34FBgwZFHbwdl1xySdSdcsopUTdmzJgadvN/LV68OOpGjBhRt2O2h5UrV0ZdS0tL1E2cODHqbr/99qiDhob8vWjevHlR9/73v7+G3ZBIf2apAQMG1HU9aA/ptcGwYcOibt26dVHXvXv3qOvdu3fUdRXpeajenxfputauXRt1W221VV2Pm95Tffzxx+t63C3JH/7wh6g77LDDou60006LuilTpkQdvB2rV6+uazdy5MioS66Dhg8fHq3V3Nwcdddff33Uffazn426adOmRd1+++0Xden7wbbbbht16dxA+jODkr7yla9E3XXXXddmkz436du3b9TNnj076krN6KTP5d94442oS58pnn/++VFHx5K+t6X3StP7Gal77rkn6o4//vi6HrcrmDp1atQde+yxdT3uxo0bo66xsTHqusq9lmq12uo/pGtMPwEAAAAAAAAAAABAJ2WgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACioR+kN0NAwa9asqFu8eHHU/eQnP6llOwRGjx4ddevWrWvnnUDrfvrTn9Z1vXvuuSfqTj311KjbZZddou5Xv/pV1HUVDz74YNSddNJJUbf99tvXsh26gHnz5kXdmDFjom7NmjVRN2jQoKhbv3591A0dOjTqNm7c2GaT7q2xsTHqFi1aFHXPPPNM1B111FFRV2/VarWu66W/e/B2fOELX4i6r33ta1G31VZbRd38+fPrttaIESOirpRJkyZFXf/+/et63E984hNRd/vtt9f1uHRtq1evjrpPf/rT7bwTUttss03UPffcc+28E6jd/vvvH3W9e/eOuvR6PflM1NDQ0HDMMcdE3ZYmPQ+lvvWtb0XdlVdeWdfj0v6+8pWvRF36OWHBggVRt91220Ud7e+SSy6JusMOOyzqPve5z0XdlClToo6ubdy4cVH3yCOP1PW46X3Q1Nq1a9tslixZEq11zTXXRN1ll10Wdd/4xjeirpTkXlVDQ0PDqFGjoi59lvTKK69EHbwdN998c9R9/OMfr9sxN23aFHWf+cxnou62226rZTvvWPq8Pb3WTM8Z3/72t6OOjiX9+R544IFRV+/Pz+l1y/HHH1/X425JjjvuuKibPn161KXP3NM5hPRcld5DSe/JdES+oRcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRUqVarrb9YqbT+Im1avHhx1PXu3Tvqrr/++qg755xzoo53bsaMGVE3cuTIqBs9enQt24F/6J+d3//eypUro27AgAE17IZ6e+aZZ6Lu5ptvjrqrr766ht1Qwptvvhl1ffr0qWvX0tISdatWrYq6devW1fW4o0aNirpEpVKp21qdwd133x11H/nIR6Ju6dKlUbfTTjtFHTQ05Nfh733ve6Oub9++Udfc3Nxm069fv2itju6BBx6IuiOOOKKux3322Wejbs8996zrcemcZs+eHXX9+/ePujFjxtSwGxLnnXde1H33u9+Nut133z3q5syZE3XQHtavXx916b3hVPrZqXv37nU9bleR3k9LnXjiiVF311131fW4vHNf/OIXo+5nP/tZ1Ln3SnpemTt3btSln3fpnI488sio+81vfhN16e/fG2+8EXV/+tOfou6QQw6JumHDhrXZrFmzJlrrfe97X9S98sorUdfRPf3001G32267RV36zGm//faLOmhoaGj4yU9+EnVHH3101O24445Rt3Dhwjab9JnYoEGDoq6Uet/LveOOO6JuwoQJUUfH8uEPfzjqHnzwwajbtGlT1G3evDnq0uc16XFpf9/61rei7rLLLou69Nq1sbEx6jr6s/5qtdrqBn1DLwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKKhH6Q10ZYMHD4667t27R90555xTy3aoo2HDhkXd0KFD23knbIlmzJgRdYsXL466Bx54oJbtUMiAAQOiburUqe27EYoZNGhQ1L355ptRt2nTprp26XF79MguR/v16xd1iUqlUre1upLZs2dH3Sc/+cmoW7FiRQ27YUtTrVajbvny5VE3cODAqGtpaYm60aNHR11HdtRRR0XdEUccUdfjzpw5M+rGjh1b1+PSOW2zzTZRt/XWW0fd448/Xst2qKPTTz896tavXx91c+bMqWU7UJN77rkn6nr37l3X4z711FNR98EPfrCux93SNDc3R93ChQuj7q677qplO9RRep37s5/9LOrmzZsXdZ/5zGeijq5rwYIFUZdeC9M5bb/99lF3xx13RN3SpUujLr0eef7556PuxBNPjDreubPPPjvq9tlnn7oe99VXX63renRO2223XdS98sorUbd69eqoe+2116IuddNNN7XZXHjhhXU9Zr2dcMIJUbfTTjtF3YYNG6Lu4Ycfjjo6pwcffDDqmpqaou6//uu/ou7zn/981NH5XHnllVF3+eWXR926deuiLr0W7sx8Qy8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACioR+kNdEaPPfZY1HXv3j3q7rjjjlq2QwHbb7991P35z39u553QlfzoRz+Kup133jnqBg4cGHWnnnpq1NGxDB8+POrGjx8fdS+99FIt26EDGzx4cNQ98sgjUbf//vtHXXoOSs2fPz/qhgwZUtfjbkkuuuiiqDv33HOjbvTo0VG37bbbRt3ChQujjo5l0qRJdV2v3ueW9DNbV3DnnXcWOW5TU1OR49I53XPPPVG3Zs2aqJswYUIt2yGwZMmSqBs6dGjU7bvvvjXsBt4d++yzT9S98cYbUbf11ltH3YYNG6KO2lSr1ahrbm5u551QbzfeeGPUbdy4MeqmTZsWddOnT486uq702nXUqFHtvBPawy677BJ1zz//fNS1tLREXf/+/aNu8+bNUXfIIYdEHe3vlFNOKXLcI444oshx6VhuvvnmqHvuueeirrGxMer22GOPqNuS1PtebnqNe+2119b1uLw7li1bVtf10uuHuXPn1vW4dF1Lly6NuvSZ8fXXX1/LdjoF39ALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAK6lF6A51Rnz59om7z5s1RN2/evFq2Qx1de+21UVepVKLu7LPPrmU7bGFOOumkqGtpaYm6V155pZbtUMjVV18dda+++mrUffSjH426W265Jepof1/84heLHPeDH/xg1C1cuDDqxowZE3VTpkyJutNOOy3qaH8rVqyIuvQaN/2donP6j//4j6hLf682bdoUdc8991zUdQXpebRv375R9/LLL0ddY2Nj1B188MFRBw0NDQ2HHXZY1D344IPtvBNSQ4YMibpnnnkm6mbNmlXLdqAmn//856Nuhx12iLrm5uaoW7t2bdSNGzcu6vjH0uvNl156Ker22GOPGnZDPR199NFRlz7XSa9zn3jiiaiD97znPVG3bNmydt4J7eEXv/hFXddL369++9vfRt3JJ59cw24oYe+99466DRs2RN369euj7oYbbog6Oqc//vGPUXfooYdG3Zo1a6KuX79+Ucc79/vf/z7qPve5z7XzTigpvX4YOHBg1HXv3j3qJk2aFHV0XRMnToy69PnUqlWrou6MM86IuvPOOy/qOiLf0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAArqUXoDndGMGTOibsyYMVF37rnn1rAbEp/+9Kej7qSTToq6xx9/POqmT58eddDQ0NAwfPjwqFuyZEnUnXzyybVshzr7wAc+EHXpz61Xr151XY+OI33PamlpibqNGzdG3fr166Muvb4ZNGhQ1C1fvjzq6Dj69u0bdQcddFA774TOID1X9eiRfTQdMGBA1J166qlR1xV84QtfqOt6/fr1i7p77rmnrseFt2P77bcvvYUur1qtRt3q1aujbu+9965lO/CuuOCCC+q6Xs+ePaPuP//zP+t63C1Ner5KpdebdBy77rpr1HXv3j3q7rvvvqibMmVK1MHKlSujbuTIke28E96Oq666Kur233//qGtubo669DP5mWeeGXV0HM8880xd10t/pxYtWhR15513Xi3boZD09+p973tf1K1bty7qvGe9czNnzoy69GdR73MBnVN6/yGVziEce+yxUffrX/+6lu3Qgf34xz+Outdffz3qttlmm6g7/PDDo64z8w29AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgoB6lN9AZDR06NOoaGxvbeSf06JH9Ck+aNCnqpk+fHnUf//jHow7ejvXr10fdsGHDoi79febdkf48NmzYEHW/+MUvatkOHVi/fv2irrm5Oer69OkTdZVKpa4dnc+1114bddVqNeo++tGP1rIdOrg77rgj6tLr9bVr10ZdU1NT1L388stR15Glf5PptUPv3r2j7pVXXom6008/PeqgoaGhYdq0aXVdb+XKlXVdb0ty66231nW9/fffv67rQXs46aSTou69731vXY87d+7cqDvjjDPqetyuIr3uSz377LN1XY+O48QTT4y6wYMHR92bb75Zy3bgLTZt2hR1r732WjvvhLfj1FNPret66fOfGTNmRN2SJUtq2Q519OCDD0Zdr169oi69LzN69Oio23PPPaOOjuWKK66Iuve97311Pe7UqVOjbs2aNXU9bkf2qU99Kuq++c1vRl36M0vPGR/72Meijq4tfUZQb+lzwF//+tftvBNSEydOjLpx48ZF3ebNm6Nu1KhRUXfLLbdEXXrN3Jn5hl4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFBQj9Ib6Iw++clPRt0rr7zSzjvpug4//PCou/3226Nu+fLlUfftb3876uDtOPLII6OuT58+7bwT2kNLS0vUpe8Jzz//fNSdccYZUUfnc//990fd2LFjo27VqlVR179//6gbOHBg1KXvvbS/888/P+omTJgQdatXr466adOmRR2dU+/eveu63vDhw6Oub9++dT1uPX32s5+Nuosuuijqdtpppxp281abN2+Oug9+8IN1PS40NDQ07LHHHlGX/p4+8cQTtWynSzr33HOj7rjjjou6Cy+8MOrmzJkTdVDS1772tSLH/eY3v1nkuKX89Kc/jbqJEyfW9bhPPfVU1LnG6brS+yOpG2+8sa7r0XVdd911UTdmzJioe+mll2rYDfVWqVTqul63btl3bF188cV1PS5vdffdd0fdIYccEnVDhgypZTvvWDqvQOd00kknFTnuySefXOS4JZx++ulRd8MNN9T1uCtXroy69PNL+pyarm3EiBF1XW/FihVRlz5XNNfQ/u66666oO/7446Nu8eLFUdfY2Bh16T2jr371q1G3JfANvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoKAepTfQlf3+978vvYV3zaGHHhp1p512WtQdfPDBUffMM89E3Yc+9KGog/Zw1VVXRV21Wo26Cy64oJbtbPGOPPLIqJsyZUrULVq0KOpmzpwZdSeeeGLU0XVdfPHFUbfzzjtH3cc+9rFatvMW06dPj7qLLroo6m677bYadtMx/OAHP4i6wYMHR93+++8fdVtttVXUbb311lHXt2/fqLvmmmuijq5tu+22q+t6jz76aNStXbu2rscdNGhQ1CXnvvS8XG/r16+PuptvvrmddwKtu+SSS6LuyiuvjLo99tijlu10Kv/93/8ddUcffXTUzZkzJ+rSa1LoDHbbbbeo27x5c9RNnTo16u67776o6+jS+xnp54lHHnkk6iZNmhR1v/vd76KOruvOO++Mug9/+MNRl97PSN976XzS88+XvvSlqEvvHz/++ONRx7tjyJAhUTd//vyoe8973hN1p59+etR165Z9Z9err74adZs2bYq6BQsWRF3699HS0tJm87Of/Sxaa+HChVFXqVSibsCAAVH3/PPPR92OO+4YdV//+tej7t577406Opbrrrsu6tJzxpIlS6KuV69eUVfKmWeeGXWf//zno27EiBFtNo2NjdFaf/3rX6Mu/Zml96Ph7fj+978fdV/96lejbuTIkVHX3NwcdcuWLYu6c845J+pSN910U13X+853vtNm09TUFK3Vp0+fqEvPe+l/49Tw4cOjbsaMGVGX/u7x//mGXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUFClWq22/mKl0vqLW7CHH3446saPHx91lUqllu28Y+n+7rzzzjabPn36RGv16NGjrl1jY2PUQUlTp06NumOPPTbqHnjggag76qijoq6jGz16dNTdfPPNUbf//vtHXf/+/aPun72P/r1u3fw/NJSR/o42NTVFXa9evWrZzlssWLAg6pYtWxZ1++yzTy3b+T9mzZoVdXvuuWfUvfTSS1G3yy67RF1qyZIlUTds2LCoK3XtSseycuXKqEvfT0tJz5Elfu/nzZsXdddee23U/fCHP6xlO/CueP7556MuPbd8+ctfjrr0M1u9/fnPf26z+cAHPhCt9eKLL0bd3nvvHXXQlaTv9xs3boy6xx57LOoOO+ywqKu39N712LFjo653795RN2PGjKj77W9/G3UXXHBB1MHWW28ddatXr466+fPnR91JJ50UddOnT486Oo70faOlpSXqZs+eHXXvf//7o47O6aabboq6cePGRd0OO+wQdelz1PQe7YgRI6Iufc67fv36Npv0GXQqOWZDQ34umDt3btTttddeUUfXlt6nuP7666OuI9/bLOnpp59usznmmGOitRYtWlTjbqDjSJ+19u3bN+p69uxZy3beorm5uchxU8l/v0GDBtX1mBs2bIi6devWRV36O3D55ZdH3ZQpU6KOf6xarbb6Bm26CAAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACioUq1WW3+xUmn9xS3YU089FXU777xz1A0YMCDqNm/eHHVnnXVW1F166aVR97//+79tNuvWrYvWWrZsWdQdf/zxUQedwac+9amou+qqq6JuyJAhUXfXXXdF3eTJk6PuuOOOi7qZM2dG3W9+85uoq7cnn3wy6gYPHhx1Y8eOjbr0/AelPP3001HXr1+/qNtxxx2jbunSpVG3fv36qOvdu3ebTWNjY93WamjIr4N++tOfRt173/veqEvPZ3/961+j7v777486urbx48dHXXqd0bdv36jbaqutoi714osvRl36mW3hwoVtNttuu220Vvp58uqrr466X/ziF1EHncGNN94YdUcddVTUbbfddlG3atWqqLv33nujbsKECVGXXGvcfffd0VonnHBC1MGWaMmSJVE3dOjQqFuxYkXU/eUvf4m6UaNGRd2IESOiLv3sNGzYsKj7whe+EHW33HJL1EEpX//616PuggsuiLoePXpEXfJZoqEh/5tsamqKuvnz50ddKrlnkD7XOfLII6MuvWf06KOPRt3IkSOjrrm5OeqeeOKJqPvsZz8bdfB29OzZM+rSzzDp84tNmzZF3e677x51c+fObbNJP+uk915vu+22qJs+fXrUQXt46aWXom7WrFlRl/6Nf/rTn466RYsWRV36rKNSqUQd8O64+eabo+60006r63EXL14cdQMHDoy6lpaWqEs/2yVd+hkmlX42SZ87pTM/vDuq1Wqrb4C+oRcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRUqVarrb9YqbT+4hasUqlE3caNG6OupaUl6rp1y+ave/bsGXUrVqyIurPPPrvN5qabborWAlr3/PPPR90uu+zSzjv5x5YvXx51GzZsiLqRI0fWsp23mD59etQdfvjhUbd27dpatgNbvGnTpkXdoYceGnXpueX1119vs7n//vujte64446oe+qpp6Kuqakp6qCkb3zjG1F3zTXXtPNO/rHNmzdHXffu3et63OTv99///d+jtX784x/Xuh3Y4l1++eVR95GPfCTq9thjj6hbsGBB1O20005RN2TIkDablStXRmsBrfvVr34VdRMmTIi6f3Y//e+l95DTzwnpZ6L+/ftH3fvf//6oe/rpp6MOuoqxY8dG3Y9+9KOoO/DAA6Nu8eLFUdfY2Bh1gwYNirr0nNbc3Nxm06tXr2itVatWRV26Xu/evaPue9/7XtSdf/75UQcAALRt8uTJUbfDDjtE3Zo1a6Ju7ty5Uffiiy9G3cUXX9xms+uuu0ZrQUNDQ0O1Wm315qFv6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAVVqtVq6y9WKq2/SJtmz54ddWPGjIm65ubmqOvWLZvTvvvuu6PuS1/6UtQB746//e1vUZeeC3bYYYeoW758edQNHDgw6nbfffeomzNnTtQBAO+ehx56KOr22WefqBswYMA738w/sG7duqj70Ic+FHVPPvlkLdsBCjn99NOj7otf/GLUPfzww1F37rnnRh3QsRx11FFRd/LJJ0fdKaecEnU9e/aMuh49ekTdpk2bog7o2qZOnRp1jz76aNR997vfbbPZaaedorUmTZoUdUOHDo26Sy+9NOr+9Kc/RR0AAAC0t2q1WmntNd/QCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACqpUq9XWX6xUWn+RNo0fPz7qbrvttqh75JFHou7ss8+OugULFkQdAAAAAAAAAAAAALWpVquV1l7zDb0AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKCgSrVabf3FSqX1FwEAAAAAAAAAAACASLVarbT2mm/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEGVarVaeg8AAAAAAAAAAAAAsMXyDb0AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIL+H26HXWZl1WAXAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 4\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 9\n"
     ]
    },
    {
     "data": {
      "image/png": "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xkTdu+++W884/z9z5syJukMPPTTqli9fHnVDhgyJOqBl/fv3j7r0NaizePDBB6OuW7duUXf88cfXMw7QQG+88UbU7bPPPlF3ww03RN1FF10UdUD7cumll0bdD3/4w6ibNWtW1J1wwglRB53Jq6++GnUjR46MukWLFkXdsGHDou7aa6+NukMOOaTVZuedd47O6tIl+zf7PXv2jLqddtop6mbOnBl1U6dOjTrYEY0bNy7qTj311Kh77LHHou6ee+6JulS1Wm3oeQCNtmHDhoZ2jzzySNSdfvrpUQe0L88880zUHX744Q19XtdU0DEtXbo06pqamqKub9++9YwDtHObN2+OuvQ1Y8uWLVF39913R93EiROjjvrUarUWL/x8Qy8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACioqfQAHdFtt90Wda+88krU7b333lH34IMPRt26deuiroT99tsv6jZt2hR1jz76aD3jAJ9Ac3Nz6RHapS984QtRV6vV2ngSoNH22Wefhp7305/+tKHnAe3L5MmTo+7ee++NutNOO62ecaBTO+CAA6LuxhtvjLpzzz036jrDNf3atWujbsCAAVG3cePGesYBKpXK7NmzG9ql3nzzzagbMWJEQ58XoJT77rsv6saOHRt1q1evrmccoJ3bsGFD1G3dujXq/uu//quecYBCfv3rX0ddeh/lo48+qmccoJ1bunRp1DU1Zeua6b3carUadddff33UUZ5v6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVVa7Vayw9Wqy0/CH/kwAMPjLrf//73Ubdy5cqo69u3b9QBtJW1a9dG3TvvvBN1o0ePrmMaILH77rtH3bvvvht169ati7ohQ4ZEHdD+vPnmm602Q4cOjc7q0aNHveMADdarV6+o69Il+3fxTz75ZNQNHz681eb9999v2FmVSqXy9ttvR93IkSOjDui4Pvzww6ibPn161H3z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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 7\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Samples after fine-tuning\n",
    "branched_after_samples = {}\n",
    "for class_to_sample in classes_0497:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    samples = generate.generate_continuous_branched_samples(\n",
    "        branched_after_model, sde, class_to_sample,\n",
    "        lambda c, t: class_time_to_branch_tensor(c, t, branch_defs_0497),\n",
    "        sampler=\"pc\", t_limit=t_limit, num_samples=1000\n",
    "    ).cpu().numpy()\n",
    "    branched_after_samples[class_to_sample] = samples\n",
    "    fig = plot_mnist_digits(samples, grid_size=(10, 1), scale=5, title=None)\n",
    "    fig.savefig(\n",
    "        os.path.join(out_path, \"mnist_class_extension_branched_after_%d.svg\" % class_to_sample),\n",
    "        format=\"svg\"\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fe9b5ca7",
   "metadata": {},
   "source": [
    "#### Train additional digit on label-guided (linear) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a7395b41",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACvQAAAEHCAYAAAB78TN5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAx4ElEQVR4nO3cebiXdZ3/8e8XDvthB0GHRUVBucAllSBJswTTRmlRrzJHMrXNljFbpFLTxslGHWwZl0svw2xsJhszndRMqURRE00RQRSIVeEAsh3gsH5/f/2uq98Pj7zyfA/34fB4/Hs/r/v+cDzn/t7L22+5UqmUAAAAAAAAAAAAAIBitCl6AQAAAAAAAAAAAACwLzPQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFqnm7jeVyubKnFgIAAAAAAAAAAAAArVWlUik3ts039AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBaopeANB69O/fP+qWL1/ezCsBAAAAAAAAAACAvYdv6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIAClSuVSuMby+XGNwIAAAAAAAAAAAAAkUqlUm5sm2/oBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgALVFL0AinP88cdH3ejRo3fb3HDDDU1dDsBbateuXdS99tprUde3b9+o+9d//deou+aaa6IOAAAAAAAAgNYlnb158skno+7888+PujFjxkTdmWeeGXVLly6NusmTJ0fdT3/606gD4P/lG3oBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQOVKpdL4xnK58Y20WG/33/RvrVmzJuo6deq026Zjx47Rvp566qmoO+aYY6Lut7/9bdRNmjQp6ubOnRt1QNNNmTIl6j7wgQ9EXdu2baOuQ4cOUderV6+o27x5c9R94hOfiLrf/OY3UQetxQMPPBB1//iP/xh111133W6bGTNmRPv685//HHULFy6MOmDP+fznPx91N998czOvBKBp0mc8X/3qV6PujDPOiLr3ve99UZfeD61YsSLqZs6cGXWPPvpo1P34xz+OOgAAAID/34YNG6Ju+vTpUXfAAQdU9bh9+/aNup07d0bdoEGDom7q1KlR96EPfSjqoLU46qijou53v/td1PXo0SPq2rdvH3Wpn//851H3xBNPRN2tt97alOW0WpVKpdzYNt/QCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUqVyqVxjeWy41vZI+bMmVK1E2YMCHqevTo8c4X00IsXLgw6r7//e9H3eWXXx51r7/+etRddNFFUTdz5syog73Bk08+GXWjR4+OunXr1kXdX//616jr3Llz1K1fvz7qRo0aFXXpOTw97le+8pWog6IsXrw46gYOHBh1L774YtR17dp1t83BBx8c7WvTpk1Rl55XUkuXLo269GcHrcmKFSuqur8//elPUXfWWWfttlm7dm20r7q6uqhraGiIuiOPPDLqgD1n2bJlUbdz587dNgMGDIj2tXnz5qhbuXJl1KXHbdMm+66A5N9aKpVKO3bsiLqampqou/POO6Pu/PPPjzpoTZ5++umo69evX9Slz5rTrlwuRx3Qem3fvj3q1qxZE3V9+vSJuvS6qtrPgwCAPeft5qT+1iOPPBJ148ePb8py3rElS5ZEXTpXc8QRR0Rd9+7do859Hfua559/PuratWsXdSNGjGjKct6xdGalW7duUZe+2+vfv3/UtRaVSqXRk6Rv6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAApUrlUrjG8vlxjdSNT169Ii6m2++Oeo+/vGPR93zzz8fdb/85S9321x77bXRvtavXx91r732WtQddNBBUXfvvfdG3YUXXhh1s2fPjrrhw4dH3fTp06PuJz/5SdT94he/iDpoDgsWLIi69O93+/btUdeuXbuoS6XHTbuGhoao6969e9SVy+Wog2p76aWXom7EiBFRV1dXF3W9e/eOurZt2+62efXVV6N9devWLeo6dOgQdbW1tVGXns+2bNkSdR07dow6KNIbb7wRdennX79+/ZqynF2sXbt2t026tvSzvr6+PuqS816pVCqNGjUq6mbNmhV1QOPe7lnb30qekXTt2jXa18KFC6MuvQ+rtvR+KL1u2bZtW9StXr066vbff/+og73BvHnzom6//faLuq1bt0Zdev+UPkeZM2dO1J1wwglRt3HjxqgDml96rZSeL2pqaqIuPT8ecsghUff+978/6v7whz9EHdA06bnlxhtvjLpLLrmkCasBmkM6L/O5z31ut021n1OkFi9eHHV33HFH1F111VVNWc4urrjiiqi7/PLLo+473/lO1P3gBz+IOmgOU6dOjbqxY8futlmyZEm0r/RZ7vve976oS99PrVixIur69+8fdem9zkknnRR1p59+etT97//+b9S1dJVKpdH/cL6hFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApUrlQqjW8slxvfyG797ne/i7rjjjsu6p544omoO+OMM6KuNTj55JOj7tJLL426sWPHRl3Hjh2jrqamJupSDz30UNSddtppVT0urdupp54adVdddVXUHXPMMVH3dp8/f+u6666LukmTJkVdar/99ou6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nHJK1P3ud7+LOt7aZz7zmag76qijom7btm1Rt3Llyqi79tpro47md8UVV0Td4YcfHnXpfXb79u2jDkqlUun000+Pup49e0Zd+vu3cOHCqBs2bFjUbd++Pep45/r06VPV/T399NNRN3r06Koelz1j2rRpUbdixYqoW758edT17ds36tJz2tChQ6MuPae1dP/0T/8UdY8++mjUpffG48aNizq45JJLou6GG26IunK53JTl7KJSqUTdaaedVtXjFuHEE0+Muk2bNkVd+rODUqlUGjJkSNT96le/irquXbtGXefOnaNu3rx5UXfggQdGXUuW3q+ljj322Kh78MEHo27z5s1Rt2jRoqg78sgjoy41a9asqu6PvdOyZcuirm3btlGXntPmz58fdccff3zUsauNGzdGXW1tbdSlvwO0LH/5y1+iLn3/kz57Tedb0uc3EyZMiDp2NX369Kj761//GnVt2mTfN5te3/z3f/931O3NfEMvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFKim6AXsCR/72MeibvHixVHXpk02Bz1jxoyog/3226+q3YYNG5qyHAry5JNPRl379u2jbseOHVFXLpejrm3btlFH08ybNy/qPvrRj0bdV77ylaj74Q9/GHXsfTZu3FjV/S1btqyq+6P5zZo1K+oWLFgQdf3794+6AQMGRN3DDz8cdennFW/t61//etQdcsghVT1u165dq7o/Wo7PfvazUXfmmWdG3R/+8IeoGzRoUNSl9/e0LGeccUbU/fKXv4y6Dh06NGU5uxg8eHDUbd++varH3ZdUKpVCjrty5cqoGz16dDOvhCKtWrUq6vr161fV46b7O/vss6Nu4cKFTVhN63XyySdHXXoeevHFF6PuP/7jP6Lu4osvjjr2Pun1TVH3vA888EDUPfTQQ828knfuvPPOi7o5c+ZE3VFHHRV1xxxzTNTRuqXPyZ555pmo6927d9Sl16+PP/541J100klRx67SeYD0HW/6HOXuu++Ouvr6+qirra2Nuueffz7q2DstWrQo6rp16xZ16e/VtGnTou62226LuhUrVkTdvuS+++6LupEjR0Zd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dUcddVTUTZkyJeo+97nPRR2t12GHHRZ1c+bMibpFixZF3eDBg6MutWPHjqibP39+1HXv3j3q+vXrt9tm+fLl0b7atm0bdTt37oy6ZG1/jxdeeCHqpk6dGnWXXnppE1bDvuYb3/hG1H3605+Ouv322y/qevToEXVz586NukMPPTTqkvNBfX19tK+XX3456kaNGhV1V1xxRdT9y7/8S9RBc0j/JocOHdrMK2mahQsXRt2BBx4Ydclzo44dO0b7Ksrq1aujLr0eOfvss5uyHGiS//mf/4m697///VGX3k907do16hYsWBB1Bx98cNSl0nu29HnQ9u3bo+6+++6Luk9+8pNRB0W55JJLou6aa66Juq1bt0Zd+n5qxYoVUXfkkUdGHUCplL83+dCHPrTbJn1efs4550Rdeo0GRfr2t78ddV/72teirn379lG3efPmqOvdu3fUFfV+qppef/31qDvggAOi7qSTToq6P/7xj1EHzeHKK6+Muu9+97tRlz4/TM8tqfS46Rxb8px2w4YN0b7SZ0GpZ599NurSZzLvec97mrIcQpVKpdzYNt/QCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUqVyqVxjeWy41vZLc2btwYde3atYu6xx57LOqGDRsWdQcddFDUJR555JGoGz9+fNQ9/fTTUXfLLbdE3Z133hl10Jq8+eabUdezZ8+oW7duXdR179496lIvvfRS1KXnvmXLlkXdTTfdFHU7duyIusmTJ0cdVNuXv/zlqPvWt74VdV26dIm62traqGtoaIi6rVu3Rt3bXdv+X507d472ldq0aVPU3X777VH3ta99rSnLAZpBr169dtuk115A4+66666oO/fcc6MuuS4olUqlhQsXRl01n6OUStm9RNu2bat6zPTf+vOf/zzqLr/88iasBvZO999/f9TV1dVF3UknnRR16TmoXC5H3eOPPx51c+bMibrhw4dH3QknnBB1AADA23vttdei7pBDDmnmlby1Z599Nure9a53Rd327dujbv369bttOnXqFO3rve99b9S98MILUQetydixY6Nu2rRpUbd8+fKo69+/f9S9+OKLUTd06NCoS84bS5YsifaVPrsZMGBA1H3zm9+Mun/7t3+LOvaMSqXS6C+Cb+gFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAApUrlUrjG8vlxjeyx912221Rd+GFF0bdc889F3Vt2ux+7nvjxo3Rvi6++OKomzlzZtQBjTvzzDOj7p577om6HTt2RN2WLVuibu3atVF3wAEHRN3Xv/71qDvkkEOi7nOf+1zUAW/toYceiroPfvCDUbdgwYKo++IXv7jbJl0bANAynXrqqVH3m9/8Jupef/31qGvXrl3Ude3aNep27ty52+bBBx+M9jV//vyou/zyy6MOAAAA2Lf86Ec/irp777036o477rio++1vfxt1l156adRdcMEFUQfsGcnMWalUKi1cuDDqBg4c2ITVvHOvvvrqbptbbrkl2tfRRx8ddZdddlnUpc+3aVkqlUq5sW2+oRcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKVK5UKo1vLJcb3wgAAAAAAAAAAAAARCqVSrmxbb6hFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApUU/QCAAAAAAAAAAAAAGBvdeyxxzZ5H76hFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApUrlQqjW8slxvfCAAAAAAAAAAAAK3QuHHjou73v/99M68EaE0qlUq5sW2+oRcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKVK5UKkWvAQAAAAAAAAAAAAD2Wb6hFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACvR/AIfMt+QObFsrAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 4\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 9\n"
     ]
    },
    {
     "data": {
      "image/png": "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W7NmTdR17do16v74xz9G3aGHHhp1QPNMmzYt6tLPeP/+/Zuznf+fH//4x1GXnj9861vfirqlS5dGXZ8+faJu9uzZUTdixIiog5bkwgsvjLo777yzyeb999+P1jrggAOi7pOu1T/sz3/+c9SNGjUq6ubPnx91AwcOjLpyuRx10JLcfPPNUXfNNdc02aT3M9LrpvT8YdKkSVH313/911EHu4NBgwZFXfo3f/HixVGX3kf57W9/G3Vnnnlm1G3evDnqqu2EE06IuvTnXbBgQdS9+OKLUXfBBRdEHRTljjvuiLpzzjkn6tJj0Lhx45psOnfuHK11+umnR92///u/R1167gV8ft58882oS+5VPPDAA9Fa559/ftStX78+6tJn1U8++WTUnXrqqVGXXmOl50rwaVx33XVRN3bs2KgbOXJkc7bzEdu2bYu62traJpv0uq5fv35R17p166hL50zq6uqibsqUKVF34IEHRl27du2iDkqlUumXv/xl1KXPEsaMGRN1s2bNirr087tu3bqqrbdx48ZorbSbPn161J100klRV+1Zt/R34O///u+j7vjjj4+6yZMnR92urlKpNPoAzTf0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIHKlUql8RfL5cZfbIHefvvtqBs5cmTULV++POrWr18fdVu3bo26KVOmRN2cOXOirk+fPk02Y8eOjdZasWJF1NXV1UVdjx49ou6dd96JulGjRkVduVyOOtgdLFiwIOo6d+4cdTt27KjqeqlNmzZF3ebNm6Nuv/32i7qlS5dGHexpLrjggqi7/fbbo65jx45RN2nSpCabE044IVordfLJJ0fdD3/4w6irra2NuhEjRkRd+/bto66mpibqnAexM6Sfy3vuuSfq0mNGeo3Vq1evJpuNGzdGazU0NERdz549o27t2rVR90nX/h+WXsfus88+Ude9e/eoW716ddRBkV566aWoGz16dNRNnz69yea9996L1kqvcw444ICo23fffaPu9ddfj7rDDjss6qBI6f2RlStXRl163/Lee++NuhtuuCHqWopXX3016j744IOo+6u/+quoc71DUf72b/826h599NGqvu8PfvCDqLv55pubbNL7D4sXL4669P6xzy18ftLzpf79+0fd3Llzm2z+53/+J1rrsssui7pq27ZtW9Sl917T5/fDhw+POiiV8vuCM2fOjLr999+/Odv5zBYuXBh1yeeoVatW0VoHH3xw1KVzMOnxMX3und5T7devX9Q98cQTUXfGGWdEHbundP6hd+/eUbds2bKoa9OmTdSlf3s3bNgQdf/4j/8YdW+99VaTzfjx46O10s/kkCFDoq5du3ZRN2HChKhLj/ODBw+Ouu3bt0ddOj/ZtWvXqNvVVSqVRi9mfUMvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFKhcqVQaf7FcbvzF3cjEiROjbtSoUVG3dOnSqNt///2jrra2Nuq2b98edS3BtGnTom7Hjh1R9+Uvf7k52/mIk08+OeqeeeaZqr4vlEr57/PUqVN37kYa0dDQUNX1lixZEnXbtm2LusGDB0ddemy+7777ou673/1u1EFL8UnnmJ/FQw89FHXnnXdeVd+3JUiPPz//+c+jrlwuN2c77GHmz58fdQMGDNjJO9n9jB8/PupOP/30qOvUqVNztvOZOWbQkmzYsCHq2rdvH3W/+c1vmmxOO+20aK1U165do+7ZZ5+NusMOOyzqHAso0sCBA6Pu97//fdR17Ngx6kaPHh1106dPj7o9zbvvvlvV9YYPHx51jlcUZfbs2VHXs2fPqHvwwQej7qKLLoq6alq0aFHUvfrqq1F3xhlnNGc7QCm/l7tw4cKou+yyy6Lu8ccfj7pd2Zw5c6Kuc+fOUbdmzZqoS59BX3rppVHH7imdH9lrr+x7/tJnvHV1dVG3ePHiqNt7772jbleW3qNN7y2ln/H0eXZ6rEqPy9dcc03UsWv54IMPom7t2rVR16dPn6ibO3du1A0aNCjqXnzxxai7+eabo27SpElRtyur9rlc//79oy49zvfr1y/q1q1bF3XpedWurlKpNHoTyjf0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIFqi95Ac9xwww1Rd/TRR0fdvHnzom7IkCFRVy6Xo46P+tKXvhR15557btT9y7/8S9R17do16saPHx91PXr0iDoolUqlfv36Rd3UqVOjbsmSJVHX0NAQdSNGjIi6urq6qFu7dm3U1dZmf6ratWsXdQsWLIi6vn37Rt0RRxwRddBSvPDCC1Vd77333ou68847r6rvuyeZOXNm1E2aNGnnboQWJf172qVLl6hbtmxZ1K1fvz7q2rdvH3XpecvKlSubbIYNGxatVW0HHnhg1KXXWH/5y1+ibt9994062B3Mnz8/6tJjy2uvvRZ1p512WtRV05o1a6Lu8MMPj7oZM2ZE3RtvvBF1rVq1irr0mAalUql01113RV16H6Cmpibqpk+fHnV8vOHDh1d1vR07dlR1Pai2Bx54IOpuvPHGqLvooouasZudKz1Xqq+v37kbgT3A//7v/0bdqlWroi593vr4449HXUvQrVu3qEvvkXXu3Dnq0md27J4GDBgQdXvtlX1/X3ovN30mm95T/fa3vx11LcETTzxR1fUmT54cdccee2zUdejQIeoWLVoUdeyePvjgg6hbunRp1PXq1SvqHn300ai79tpro46PSucT77777qj7zne+E3Xp34MVK1ZE3SOPPBJ1ewLf0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFqi16A81x7rnnRt26deuirlOnTlHXtm3bqGPn27p1a9R17Ngx6rp37x51M2bMiDr4NB544IGoe/nll6Ouffv2UTdw4MComzt3btT16dMn6nbs2BF1AwYMqOp6rVu3jrrU2LFjq7oe7OrGjBlT1fWGDh1a1fX4qJ///OdRl/4dglKpVNq0aVPU1dXVVbVr1apV1HXr1i3qUp07d67qetWU/qzpudK+++4bdenvABRpxYoVUVdTU1PV9z388MOrul4RvvGNb0Tde++9F3Unnnhi1N1yyy1RB59Gep9i27ZtUffkk082Yze8/fbbVV2vvr4+6mprd+tHIewBzj777KhLz292Zen9bc9h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qu24446LuhdffHEn74SW5Kyzzoq6m266Keq6du0aden9oB49ekRdNS1cuDDq0mdiyfVaqVQqffnLX466o446KupeeeWVqINSqVRavXp11KWf8fr6+qg755xzom7KlClRl/4czzzzTNS98847TTZf/epXo7XS5/xvvfVW1KXXiekxqHXr1lG3fv36qHvooYei7qKLLoo6Ph9vvvlm1I0aNSrq0vPwhx9+OOquv/76qOOzmzlzZtTtt99+UZc+J0rPSSdMmBB1e5pKpdLoQIVv6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIAClSuVSuMvlsuNv9gC/elPf4q6hoaGqBsxYkTUzZ8/P+oOO+ywqFu1alXUtWnTJurq6uqabBYuXBit1b9//6hbt25d1KU/Q21tbdTV1NRE3ZYtW6Iu3R8t25NPPhl1vXr1iroPPvgg6saMGRN16ee3VatWUbdkyZKoGz58eNQtX7486oYOHRp1qfRYnxwjP42XX3456tq2bRt1++23X9R17Ngx6mi5Pumc8MO2bt0adT/5yU+i7vrrr4+6IowbNy7qLrnkkqhLj4/btm2LuvQ4esopp0Td008/HXVQKuXnw5s2bYq69O9Qtf8+r1y5MuqSn6N9+/bRWt26dYu6t956K+pGjhwZdem1TnoucvTRR0cd7Ay/+c1voi69Rnjsscei7oYbboi6iRMnRl1yTDvmmGOitdLjXrlcjrr0OnHAgAFRB7uD9Lyl2vcjt2/fHnXVdtZZZ0XdP//zP0fdQQcd1JztfER6npZex1xwwQXN2Q6wB3nggQei7mtf+1rU3X333VF38803Rx3sDLNnz466YcOGRd3VV18ddc8//3yTzdSpU6O1vvnNb0bd448/HnUp91EoUvoMcObMmVGX3ntNnyel9yPTa6f0GcugQYOiLrFx48aoa9euXdXec2dI5ws6dOiwk3fCznDwwQdH3a233hp1xx57bNS98847UVdfXx91RxxxRNQ98sgjUZd+ft99992o22effZpsjj/++GituXPnRl16zZGaPn161H3xi1+Muh/84AdR51rn41UqlUZv1vuGXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAAChQuVKpNP5iudz4i3zu/vjHP0Zdly5doq5v375R1759+6hLjBs3LurOO++8qKurq2vOdj6itrY26pYuXRp1Q4cObc52aCFuuummqLviiiuibvHixVFX7c9Hemxp1apVVd932bJlUbdx48aoSz/n6bGvdevWUZf+d+vdu3fUtWvXLurS/ZXL5aij5fqkc8IPq6+vj7rvf//7Uffwww9HXTXNmTMn6gYMGBB1K1eujLq99sr+X7oOHTpE3Y4dO6Kuc+fOUQefxlFHHRV1L7/8clXfd/PmzVG3atWqqOvXr1/UJZ/zadOmRWsdeOCBUbd169aoS/9N0nPD9FiVnhsCzfPEE09E3ZgxY6KuoaEh6tLjI7Qk8+bNi7r0fkF6Ht6rV6+ou/zyy6Pusssui7pUel8h7dLj0KJFi6Ju4MCBUVfNe9xAy/aLX/wi6s4+++yoS+8L77///lEHfLz7778/6s4///yo++1vfxt1P/7xj6Ou2vfI4NN4//33o65nz55R59z6o9L70d27d4+6dB6lT58+Ubd+/fqo69SpU9TRsu23335RN3PmzKhLn2Gkz6DTeYr0PDy9D7p9+/Ymm/R5e3pvZM2aNVE3ZMiQqq7XtWvXqEt/jo4dO0bdnqZSqTQ6pOMbegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBA5Uql0viL5XLjL7LL+td//deo27BhQ9Ttt99+TTaXX355tNa6deuiLtWtW7eoW7VqVdQtX7486nr16hV15XI56qBUKpXmzJkTdZ07d4667t27R93EiROj7phjjom6adOmRV3//v2jLj1u9OjRI+refvvtqDv00EOjbt68eVGXHjeq7amnnoq6s88+eyfvhF3dm2++GXX77rtv1LVr1y7qli5dGnW9e/eOuuT8pq6uLlortWLFiqhL/01at25d1c75CLuDxx57LOpOPfXUqJsyZUrUvfLKK1F32GGHNdmk516jRo2KuiVLlkRdQ0ND1HXq1Cnq+vTpE3XA5+Oll16KutGjR0fdBRdcEHUPPPBA1EFLkl7fb9++Pepqa2ujLr0fOXDgwKjr2bNn1O3YsSPq9tor+06Qf/u3f4u6vn37Rt1XvvKVqBsyZEjUuS4CUrfddlvUXXHFFVGXHkeBj1dTUxN1mzZtiroJEyZE3U033RR1r776atTB7mDvvfeOuvTzNm7cuKi78MILo+7999+PusGDBzfZrF+/Plpr7dq1UZc+9y6K6yGKlD7jTZ9Vp7/PW7dujbr0OdG7777bZJM+u50+fXrU3XHHHVGXzsrU19dHXZs2baIuffbtGPTxKpVKo/8wriIBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQOVKpdL4i+Vy4y/CbmT27NlRt2HDhqjbf//9o65169ZRB6VSqdSzZ8+oW7ZsWdRNmTIl6tq2bRt1ffr0ibqVK1dGXatWraIu/bwVpb6+Puq2bt0adQ0NDVE3ZMiQqCuXy1EH9957b9Sdc845UdemTZuoW7NmTdSlv8tz5sxpslm4cGG01mmnnRZ11Zaej7Rv3z7qHAfg83HUUUdF3aOPPhp1/fv3j7pVq1ZFXXpc7tixY9QBzXf66ac32dxyyy3RWvvss0/UOS+Axt1///1Rl37e0uv2rl27Rt2iRYuiLtWvX7+oO+yww6Ju+vTpUXfZZZdF3fXXXx916X2t9FwIaLmef/75qBs+fHjU1dXVRV163x/4eBdffHHUXXnllVE3YMCAqHPtBLuvBQsWNNns2LEjWqt3795R90lzVx+WXr+kHKuAUqlUWrFiRdT16NEj6qZOnRp1o0aNijrHqo9XqVQa/YfxDb0AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQoNqiNwCfh27dukXdsGHDom7KlClR99RTT0XdKaecEnW0bK+//nrUbdiwIer23XffqFu+fHnU9evXL+pqamqibs2aNVFXbeVyuarrPfzww1E3ZMiQqDvggAOasx34zNJjS5s2baJuxowZUbdq1aqoa9u2bdSdccYZTTYLFy6M1qq2u+66K+pWr14ddd///vebsx2gyg466KCo69+/f9Slx6pWrVpF3XPPPRd1QPPV1ma32+6///4mm/S66bzzzos6oHG9e/eOuiOPPDLqfve730XdMcccE3XpfctU3759o27p0qVVfd8777wz6u64446oW7ZsWXO2A7QAxx13XFW7hoaGqOvevXvUAc2T3vcYMGBA1H3lK19pznaA3cDee+/dZLNo0aJorfSZ2OLFi6Mufd5e7efZQMu2du3aqEvnAUaNGhV169evjzo+Pd/QCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUqVyqVxl8slxt/EXYBZ511VtT913/9V1Xfd/369VHXsWPHqCuXy83ZDi3EeeedF3Xjx4+Puvr6+qjr0qVL1E2aNCnqRo4cGXWrV6+Ounnz5kXdN77xjagryif9vf2whQsXRt3WrVujbujQoVEH7HwzZ86Muv79+0ddep4BfD4uueSSqPvpT38adStWrIi6tWvXRt3TTz8ddZdddlnUAY1bsGBB1CWf8+XLl0dr7erXQ9CSpNf3qaVLl0bdmjVroq5Dhw5RN2jQoKirtilTpkTdEUccEXXuqwLpffC2bdtG3Xe/+92ou//++6MOaNzmzZubbFauXBmttWjRoqg77LDDog7Y9bz22mtRd9BBBzXZ1NTURGul12Fdu3aNuquvvjrqbrvttqgDKJXye1UbN26Mutra2qhr1apV1Ll38/EqlUqj/zC+oRcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAAClRb9AagOaZMmRJ1W7dujbpWrVpFXV1dXdStXr066qBUKpUefPDBqPvDH/4Qdc8991zUHX744VHXrVu3qEv3t6fZuHFjVbvNmzc3ZztAAWpqaqKuvr5+524E2CkOOeSQqq7Xs2fPqGvXrl3UPfbYY83ZDlAqla699tqo69OnT9T179+/yaZcLkdrAZ+f9HN51113Rd23v/3tqJs6dWrUnXjiiVFXlCOOOCLqVq1aFXX3339/1F1wwQVRB0W57777ou7CCy/cyTvZdaxZsybqOnfuHHXpfev0uAI0X/JcNj33euGFF5q7HaAgJ510UtQdeuihVXvPmTNnRt2WLVuirkuXLlF32223RR1AqVQqjR07tqrrtW7dOupeeeWVqDv66KObsx0+gW/oBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAKVK5VK4y+Wy42/CLuAiy++OOp+9KMfRd2KFSuibvDgwVG3ePHiqBs0aFDUAbuvT/p7+2FbtmyJupqamqirra2NOmDnmz9/ftTdddddUTdu3LjmbAeosvRvfWrt2rVR16VLl6q+L+yJ7rnnnqj71re+FXXp57dHjx5NNuVyOVoLYHfx3nvvRV16/9Vxkl1der4+e/bsqOvevXvUTZw4MerGjBkTdYlZs2ZF3YgRI6r2nqVSqTR37tyoGzZsWFXfF2jcvffeG3UXXnhh1d7TOQHsvtL7qum5Rrt27Zpsli5dGq31xS9+MequvfbaqLvzzjujDqBUKpWGDh0adePHj4+60aNHR93WrVujrnXr1lHHx6tUKo2ewPqGXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAAChQbdEbgOY4++yzo66mpibqevXqFXVz586NunK5HHXA7uu0006LuuXLl0fdmjVrou6///u/ow7Ydfzyl7+MunHjxu3knQA7w8qVK6Oubdu2UbdgwYLmbAf4FFatWhV1tbXZbbQePXpE3X/8x39EHUBLMmnSpKg7//zzd+o+4PNSX18fdW+88UbUDRo0KOpat24dde+8807UrVu3rslm/vz50Vp9+/aNup/85CdRd/PNN0cd8Pk59dRTo27y5MlNNl/4wheaux1gF/fSSy9F3dFHH12191y/fn3U/d///V/U3Xnnnc3ZDsDHSmfTli5dGnVz5syJumHDhkUdO49v6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIAClSuVSuMvlsuNvwi7gE/6/f0stm/fHnU1NTVR98QTT0TdGWecEXXA7is9Xj3//PNRd8IJJzRnOwDAp3DVVVc12dx6663RWkuXLo26t99+O+qOO+64qAMa98Ybb0Td4MGDo65Dhw5R17Zt26gDANhZRo8eHXVTp05tsmloaGjmboBdXV1dXdRNnjw56pLjxrvvvhutdeGFF0YdsPtKzkdKpVKpdevWTTYjR45s5m4Adh2HHHJI1D3yyCNRd84550Tda6+9FnV8vEqlUm7sNd/QCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUqVyqVxl8slxt/EXYBzz77bNRt2rQp6n70ox9F3Z/+9KeoAwAA9gxXX3111K1fvz7qfvGLXzRnO8BO8NRTT0XdKaecspN3AgAAsPubOHFik82xxx77OewEAAA+X5VKpdzYa76hFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApUrlQqjb9YLjf+IgAAAAAAAAAAAAAQqVQq5cZe8w29AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUKBypVIpeg8AAAAAAAAAAAAAsMfyDb0AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFCg/weF7VH3jCUwNAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 7\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACvQAAAEHCAYAAAB78TN5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAxOUlEQVR4nO3ceZiddX3//3OyTPZkyE7IQjZAjGlYE2SNiJgqiywBSumiQquVy8qlINSLVqjalEtKC5dQi+XikjVgVESgqRCMypKwJwYIJCHrhGwkM8kkmSzn+8fvj3r9YJiXzJnck+Hx+Pc8r/u+mZxzn/v+3G9OuVKplAAAAAAAAAAAAACAYnQq+gAAAAAAAAAAAAAA4MPMQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFKjL+71YLpcr++pAAAAAAAAAAAAAAKCjqlQq5eZe8wu9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUCADvQAAAAAAAAAAAABQIAO9AAAAAAAAAAAAAFAgA70AAAAAAAAAAAAAUKAuRR8AdGSnnHJK1M2ZMyfqyuVyK44G6Eh27twZdTU1NVH30EMPRd1ZZ50VdQAAAMD+7/vf/37UXXHFFVH32c9+Nup++ctfRh0AQEeSPtPZtm1bVbva2tqoAwDan0qlUtXtmU0rnl/oBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAKVK5VK8y+Wy82/CLRo7ty5UTdixIioGz16dGsOB9gPzJkzJ+pOOeWUqFu5cmXUjRw5MuoAgI7t9ttvj7ovfvGLbXwkAEBbmjlzZtSl6wXp+mZNTU3UrV27NupmzZoVdZdffnnU9e/fP+qA/c+4ceOibsaMGVH3la98Jerq6uqiDqBUKpVeeumlqBs2bFjUbdmyJerGjx8fdbA/+Pa3v91iM2bMmGhbl1xySWsPB6DNrVmzJup27twZdX369Im6gQMHRh3vrVKplJt7zS/0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIHKlUql+RfL5eZfhD/wyCOPRN20adOibtOmTVE3YMCAqKu2Aw88MOqef/75qm7v9ttvj7pLL7006oB95/2+b9tSjx49om7Hjh1tfCR0FOl7ec+ePVFXV1cXdcOHD4+6crkcdcC+Ue3vv1tuuSXqLr/88qrutyO48soro27GjBlV3a/zMjSvmufI3bt3R12XLl2qts9SyWcc2qMvfOELUZeuM65fvz7qBg0aFHXvvPNO1NXW1kbdypUro27kyJFR57wG7cfkyZOj7plnnqnqfjdu3Bh16fOpdevWRd3gwYOjbv78+VF37LHHRh3QOjU1NVG3c+fOqu532bJlUTdmzJiq7hf2BwsWLGixmTBhQrSt2bNnR93pp58edQBtob6+Puq2bt0adekMmzWU1qlUKs3+Af1CLwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUqEvRB0D7d/3117fYnHjiidG2Ghoaou6AAw6IuqLU1dVFXY8ePaJuyZIlUXfqqadGHbD/amxsjLqePXtG3Y4dO1pzOPAuO3fujLpt27ZFXVNTU2sO513mzJnTYjN16tSq7pP39tWvfjXq/v3f/72Nj4QivfDCC1E3bNiwqPvUpz7VmsP5UFu7dm3UPfHEE1E3fvz4qJswYULULVy4MOpgfzBt2rSoe/XVV1tsPvKRj0Tb6tIlW+JbtWpV1G3atCnqVq9eHXUHHXRQ1AGtd+2110bd0qVLo+61116Luvvuuy/qzjnnnKhL1z0GDBgQdZ06Zb9tcsIJJ0Tdb3/726gD3i1dl/nud78bdfX19VHXt2/fqOvatWvUpfe7Rx55ZNStXLky6tasWRN1wL5x2223Rd2iRYuiLr13Ss8Z0JEkcyulUvY5Su9zDjnkkKgDKFJ6r1OpVKJu2bJlUXfZZZdF3Q9/+MOo4//4hV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAoULlSqTT/Yrnc/Ivs9/r37x91GzdurNo+n3rqqaj7+Mc/HnXlcrk1h9Pm3u/z1Zbb69TJrD7tX48ePaJu+/btbXwk+8bu3bujrnPnzlF3++23R92ll14adZCaP39+1PXt2zfq0u/yQYMGRV1tbW3V9sl7++EPfxh11T7/+HdrX7773e9G3dVXXx1169ati7rBgwdHnffLu23ZsiXq0vN3eo32gx/8IOq+/vWvRx20hfT93NDQEHXdunWLuvTzlnjxxRej7ogjjoi6PXv2RF16//LZz3426h5++OGoq6+vj7p+/fpFHewP/uEf/iHqvvWtb0Xd3r17o65Xr15Rl+ratWvULVy4MOqGDRsWdb179466hx56KOrOOuusqIP2Lr13Ss8Ziddeey3qDjvssKhLr9H69OkTddW+P02vNdPrr/T5T7XP3+wby5cvj7qRI0dGnfWRtlftZ8GpOXPmRN0nPvGJNj4SaL1qf46S79R0PWPVqlVRN3z48KhLn+9+8YtfjLqU7wOgVMrPt01NTVGXrvGYYXtvlUql2ZOzvxgAAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUyEAvAAAAAAAAAAAAABTIQC8AAAAAAAAAAAAAFMhALwAAAAAAAAAAAAAUqEvRB0BxHnjggaibO3dui0337t2jbR188MFR11HMmTMn6kaNGhV1gwcPbs3hwD4xf/78qNu6dWvUTZ06tTWH0240NDREXW1tbdQ9/vjjrTga+OCWLFkSdUcffXTULViwIOrGjRsXdXxwTz75ZNSNHTs26tauXRt1b775ZtSxb6TXpSNGjKjqftNzy6OPPlrV/X6YHHnkkVE3c+bMqOvbt2/UbdmyJeqgLfzoRz+KuvTcMnny5Khbvnx51HXq1PL/Z59eA3Xt2jXq0vuwNWvWRF3Pnj2j7qabboq6pUuXRl2vXr2i7qCDDoq61atXRx0UKV0fqauri7of//jHrTmcD+w73/lO1A0dOjTqdu/eHXXr1q2LugcffDDqoL3r169f1KXngpUrV7bYpOuf6XXLM888E3UTJkyIutmzZ0fdVVddFXXpefnb3/521KXXN42NjVF3wQUXRN39998fdewb3bp1i7r0uv7Xv/511J188slRx7s98sgjUXfEEUdEXfoeSK+BoEivvPJK1O3atSvq0mcJyTXJscceG21r+/btUffCCy9E3UknnRR18+bNi7r0vyN9/rNhw4aoO++886IOaF9WrVoVdZ07d466IUOGtOZweB9+oRcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKZKAXAAAAAAAAAAAAAApkoBcAAAAAAAAAAAAACmSgFwAAAAAAAAAAAAAKVK5UKs2/WC43/yLt1ssvvxx1EyZMiLqGhoYWm379+kXb2rt3b9TV19dH3QEHHBB11Xb55ZdH3X/8x39Udb+PPfZY1E2bNq2q+6VjO/DAA6Pu3nvvjbqTTz456rZu3Rp1ffr0ibr27v2+bz+Icrlc1e3BX/3VX0XdjBkzoq6pqSnq0muDkSNHRp3PxrsNGjQo6t5+++2oS//G69evj7rp06dH3ZNPPhl1tM7y5cujrn///lGXvg9Gjx4ddT7jH9xnPvOZqPvRj34Udbt27Yq6z33uc1H33HPPRR2USqXS3XffHXUXXXRR1Dm3vNumTZuiLl0P6ty5c2sO51327NlT1f2m/70DBgyIOiiV8nusa6+9NurS66XFixdH3aGHHhp11ZbeK3bt2jXq0vWl3r17R939998fdRdeeGHUQbXNmjUr6k477bSoSz8bK1asaLFJ1x/S7+eampqoe/PNN6Nu/PjxUVdtL774YtRNmjQp6pJ/i1KpVJo4cWLUbdmyJerYN6r9HCHlnuiDu++++6Iu/Yyn12juYWgLP//5z6Pu9NNPj7pu3bpFXV1dXdSla809e/ZssRk3bly0rbfeeivqDj744KirtmSWp1TKn7enz+w6dcp+O/KBBx6IuvPPPz/qfF9B68yZMyfqTjnllKj7sM38VFulUmn2pOYXegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBAXYo+AEqll19+Oeq2bdsWdRMmTIi6vXv3Rt2GDRtabHbs2BFtK/1vOPXUU6OuKKeddlrUpX/jTZs2Rd20adOiDv4Yd9xxR9SNHTu2qvv9zW9+U9XtFeVzn/tc1KWf8+XLl7fmcOADGzJkSNStW7cu6hobG6Nu4MCBUffSSy9FHe/21FNPRd3atWujrnv37lH3P//zP1H35JNPRh37xsyZM6Pu+OOPj7rXX3896l555ZWo44M7//zzoy69Zxs8eHDU/du//VvUnXjiiVEHpVKptGfPnqjbunVr1DU0NETd6tWro+6YY46JuhUrVrTYrFmzJtrWlClToq6+vj7q+vfvH3V1dXVR19TUFHWbN2+OuhEjRkRdui5z4403Rh2USqXSAQccEHWXXnpp1PXo0SPq0nWUT3/601FXbb/73e+irmvXrlE3f/78qBs/fnzULVy4MOouu+yyqINqO+mkk6Lu4x//eNSln7Vly5ZFXa9evVps0muv7du3R13fvn2jLl2fLcqFF14Ydd/61rei7qijjoq6LVu2RB37xllnnRV1yT1CqZSvqc6dOzfq+OCeeeaZqJs4cWLUpefSjRs3Rl26LvO1r30t6tg/pc8e0+/obt26VXV7S5YsibpqriHffvvtUTdjxoyou/rqq6PuS1/6UtSl/2bpekvPnj2jbtKkSVGXnqvSNekHHngg6qBUyq+H0/dp+hyrI7jzzjujbsCAAVE3evTo1hwO78Mv9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBypVKpfkXy+XmX/wQO+2006Ju9uzZbXwk723VqlVRN3z48KjbsGFDi83AgQOjbX35y1+OultvvTXqivJ+n5u2VC6XC9kvHVv6fk679H3aUd7P6d+lrq4u6g488MCoS8/1t9xyS9TNmDEj6ui4tm/fHnU7d+6Muu7du0fdmjVrom706NFR1xHOLZdffnnUXXbZZVE3YcKEqNu6dWvU9ezZM+qmTp0adXPnzo069o3Vq1dHXXr9X1NTE3UrVqyIulGjRkUd75aev9N/s9RLL70UdUcccURV98v+6fnnn4+6I488so2P5L1t2rQp6vr06RN1y5Yta7E55JBDom1VW1NTU9Sl54z58+dH3THHHBN16bVrenz19fVR179//6ijY5s3b17Upe/nzZs3R90dd9wRdVdccUXUVVu6PpLed/Tu3bs1h/OBdYR7StqXb37zm1H3ve99L+rWrVsXdQ0NDVE3duzYqFu4cGGLzeGHHx5tK9WpU/abRO39c1vt50l33XVX1F1yySVV3S+ts3Tp0qhL3/fp+sif/dmfRd29994bdbxb+m92zz33RN0FF1wQdcl5uVQqlWpra6NuxIgRUUf70tjYGHU9evRo4yNpnTPOOCPqHn744TY+kvZjwYIFUXfYYYdFXZcuXaIufWY3bNiwqKu29n7dR+vs3r076jp37hx111xzTdSl92IdwcyZM6Pu/PPPr+p+fXbfW6VSafYP4xd6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEBdij6A9uRf/uVfom7q1KlRt2DBgqgbPHhw1O3atSvq9u7dG3VvvfVW1CW2bt0adbfeemvV9tkWvvGNb0Td66+/HnVjxoyJug0bNkQd/DEOPPDAqKurq4u6pqamqJs4cWLUtXfXX3991K1duzbqNm/eHHWdOmX/r82gQYOiLj2vzZgxI+rouNJzQdeuXaMuvW7Ztm1b1L388stRt27duhabL3/5y9G2HnzwwahLTZ8+PequvPLKqFuzZk3UPfnkk1F3yCGHRN2iRYuibu7cuVFH+9K5c+eoS88Z27dvj7pXX3016vjgfvOb30Rd+h545513oi59r9CxnXrqqVGXrmekFi9eHHXpd2D//v2jLj2n1dbWRl0iXeNJ95ne5xx22GFRl17zpdeQPXr0iLpU+l6hY3vhhReibuTIkVGXfi7T6+srrrgi6opy//33R90555wTdQ0NDVHXq1evqHv++eejbtasWVGX/new/7noooui7pprrom6dE01Wc8olUqlPn36RF26ZvDiiy9G3eGHH95ik65rPvHEE1HXUdYr0++XdF39n/7pn1pxNBQlvR4eMGBA1K1YsSLqzjjjjKi79957o453u+qqq6KusbEx6tJrwwkTJkTdwoULo4725dJLL4261atXR13v3r2jLn32mK4fXnjhhVH38MMPR92Hycc+9rGqbu/aa6+Nur/4i7+IuvQaN70vTtfm2D+lz3jT+/Z0PXL37t1R92EyadKkqEtn4g499NBWHA3vxy/0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIEM9AIAAAAAAAAAAABAgQz0AgAAAAAAAAAAAECBDPQCAAAAAAAAAAAAQIG6FH0A+8J3v/vdqLvqqqui7o033oi6ESNGRF1jY2PUDRkyJOp+9atfRd2oUaOi7u23326xOeGEE6JtdeqUzZAfffTRUTdv3ryoO+OMM6LuX//1X6Ou2q6++upC9sv+acKECVH37LPPRl3Pnj2j7pOf/GTU1dfXR117N2XKlKgbOnRo1O3duzfq0nN9qlu3blXdHvufm266KepGjx5d1f3u2rUr6h577LGo+/M///OoW7t2bYtN+n3/n//5n1HXv3//qEv/Jun10s6dO6Nuz549UZeep2bNmhV17J/S76HNmzdHXXrP0b1796i77rrrou7aa6+Nuo5g4sSJUXfUUUdFXZcu2TJB7969o27q1KlRx/7pG9/4RtQVda89bty4qEvXZX7/+99H3THHHBN1O3bsiLpEbW1tIV3qlFNOqer2qm3y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4YUXou6iiy5qzeEAVZReG65bty7qBg8eHHVLliyJuieeeCLqLrvssqiDtnDjjTdGXfp9v3HjxqgbMGBA1P3617+OutWrV0fdxRdfHHVFWLFiRdSNGDEi6pYuXRp1Y8aMibqHHnoo6s4666yoo3154IEHou7ss8+Ouqampqjr2bNn1G3fvj3qevToEXVFSP8mNTU1bXwkHduVV14ZdTfccEMbHwmlUn69nkqv64cMGVLV/VbbqFGjoi5dD3rkkUeq2i1fvjzqBg4cGHU7duyIut///vdR9/rrr0dde77uo3XeeeedqEufJaxfvz7qunfvHnW9evWKukWLFkVder3eu3fvqEvWSg855JBoWz/72c+iLr2GPPnkk6MuedYFf6zbbrst6k4//fSoa2xsjLq//uu/jrp58+ZFXVG2bNnSYpPer/33f/931P3t3/5t1KXSa9d0vSW95kv+dqVSqdS/f/+o84y8fUnfV+n7YO/evVGXzrd07do16ni39G937733Rt25557bmsN5l4ULF0bd1VdfHXUPP/xwaw6Hdm727NlRN3Xq1Kh74403om706NFRl96Lpe66664Wm0suuaSq+yxKOj/Zr1+/qHOd8d4qlUqzfxi/0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFMtALAAAAAAAAAAAAAAUy0AsAAAAAAAAAAAAABTLQCwAAAAAAAAAAAAAFKlcqleZfLJebf3E/8vWvfz3qzjzzzKg78cQTo+5Xv/pV1B199NFR17Nnz6hbs2ZN1DU2NkZdly5dWmwGDx4cbevpp5+OusMOOyzq3u/9+4fGjBkTdeVyOergj/HLX/4y6tJzwe7du6Nu2LBhUbd+/fqo69WrV9Q1NTVF3euvvx51nTpl/+/JwQcfHHVvvfVW1B100EFV7YB94+abb26xOeaYY6Jtde7cOerSa6o+ffpE3ZFHHhl1sD9Yvnx51L300ktRl17/n3322VHXEaxbty7q0muvoUOHRt2qVauiLr3PbmhoiDral3feeSfqamtro27r1q2tOJoPvr1+/fpFXXpvsm3btqirqalpsdmxY0e0rQEDBkRdqtrrIwsXLoy69D522bJlUXf99ddH3c9//vOoo3X69+8fdbNnz466j33s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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_guided_before_samples = {}\n",
    "for class_to_sample in classes_0497:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    samples = generate.generate_continuous_label_guided_samples(\n",
    "        label_guided_before_model, sde, class_to_sample,\n",
    "        lambda c: class_to_class_index_tensor(c, classes_0497),\n",
    "        sampler=\"pc\", t_limit=t_limit, num_samples=1000\n",
    "    ).cpu().numpy()\n",
    "    label_guided_before_samples[class_to_sample] = samples\n",
    "    fig = plot_mnist_digits(samples, grid_size=(10, 1), scale=5, title=None)\n",
    "    fig.savefig(\n",
    "        os.path.join(out_path, \"mnist_class_extension_label_guided_before_%d.svg\" % class_to_sample),\n",
    "        format=\"svg\"\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "f5d9ec71",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 4\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACvQAAAEHCAYAAAB78TN5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAiuklEQVR4nO3cfaze8+H/8euq3ulaWr1z05KVttptzGpjlK9mdyQ2DKNYiElMbIwJEYISq86QsYypEemyiobZ3AwLHToMo8xtW2vLqXZtqfa05+hBr99fv0SyHufFdR3vc04fj3+vZz7Xe7pe53Nd59WrWqvVKgAAAAAAAAAAAABAGb1KHwAAAAAAAAAAAAAAtmQGvQAAAAAAAAAAAABQkEEvAAAAAAAAAAAAABRk0AsAAAAAAAAAAAAABRn0AgAAAAAAAAAAAEBBvT/uwWq1WvusDgIAAAAAAAAAAAAAPVWtVqu295hv6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCDHoBAAAAAAAAAAAAoCCDXgAAAAAAAAAAAAAoyKAXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCDHoBAAAAAAAAAAAAoCCDXgAAAAAAAAAAAAAoyKAXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCDHoBAAAAAAAAAAAAoCCDXgAAAAAAAAAAAAAoyKAXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCDHoBAAAAAAAAAAAAoCCDXgAAAAAAAAAAAAAoyKAXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIJ6lz4AAADQfVxwwQVRd/nll3fySQAAAACArub111+Puttvv73D5vzzz6/3OAAA0K34hl4AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCqrVarf0Hq9X2HwSgRzjqqKOi7rrrrou6tWvXRt0PfvCDqHvhhReiDoD6LFiwIOrGjh0bddVqtZ7jQLezzz77RN2TTz4ZdatWrYq64cOHR93ChQujbty4cVEHAPBpfNzvIz7q2muvjbqTTz456gYNGhR1UMrKlSujbsWKFVG3xx571HOcHql///5R995773XySaDrufDCC6Pusssui7rW1taoW7ZsWYfNjjvuGF3rrLPOirobb7wx6gAAoDPVarV2f5nuG3oBAAAAAAAAAAAAoCCDXgAAAAAAAAAAAAAoyKAXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIKqtVqt/Qer1fYfpGH69u0bdZdccknUtba2Rt2JJ54YdQsWLOiwue6666JrjRgxIupuvfXWqEvNmDEj6h566KGoe/DBB+s5DnQpr732WtS1tLRE3ahRo6Kuubk56ubMmRN15513XtQB3dPH3bN+1KGHHtphc++999Z7nG7lmmuuibrTTjst6pYvXx51n//856MOPol999036p544omoe+yxx6Ju/PjxHTbpe5358+dHXfp3aNttt426hQsXRt24ceOiDiqVSuXYY4+Nuttuu62TTwJAZ9l///2jbt68eVG3bt26qFu9enXUvffee1H3hS98IeqglLfffjvq0s9UJ02a1NDn7comT54cden7v/Rzjx133DHqoDtIP3vtytra2qIuvcfYaaed6jkOUNBNN93UYXPKKadE1/rTn/4Udddee23UzZ07N+qgJxkwYEDUnXnmmVF38MEHR121Wo26Dz74IOomTpzYYfPSSy9F10o/o9i0aVPUbb/99lG3bNmyqEvfdyb/TWhfrVZr9/+kvqEXAAAAAAAAAAAAAAoy6AUAAAAAAAAAAACAggx6AQAAAAAAAAAAAKAgg14AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACioWqvV2n+wWm3/QTp0/vnnR933v//9qNtmm22ibtddd426999/P+o2bNjQYdOnT5/oWun/hqampqgbNWpU1DXa7373u6j78Y9/3Mkngfp93M+Bj0r/Xg4ePDjqZs6cGXXDhw+Pui996UtRt+eee0bdzTffHHXbbbdd1B1xxBFRB1uaG264IeqmTp0adZMmTeqwWbRoUXStnuKVV16JuoEDB0bd6NGj6zkObNYzzzwTdePHj4+6lpaWqBsxYkTUVavVqCshvZe7//77o+6QQw6p5zj0EI8++mjUff3rX4+6J598MuomT54cdevWrYu6119/vaHX22OPPaJu2223jbpevTr+d/ZvvfVWdK0VK1ZEXXq9++67L+p++9vfRl1Xfh2Fnib9bPjVV19taJd8hlypVCrvvPNO1KX3JC+++GLUpZ8bQSnp5x7pZ5b9+/ePup7wMzp9T7R27dqoS++XJk6cGHVQ0nvvvRd1/fr1a+jztra2Rl3yfuLnP/95dK3169dHXfoZaHqPMWfOnKi79NJLow62RL/+9a+j7qc//WnUJa99b7zxRnSt9Pchq1evjrq99tor6tL3TXRP6c7pueeei7r0c8G+fftG3bhx46Iu/Z3DkCFDom7vvfeOumXLlkVdej+S/t4p+f1y+meb/pntsssuUZduedLXtCVLlkTdtddeG3XXXHNN1G1parVau2/IfUMvAAAAAAAAAAAAABRk0AsAAAAAAAAAAAAABRn0AgAAAAAAAAAAAEBBBr0AAAAAAAAAAAAAUJBBLwAAAAAAAAAAAAAUZNALAAAAAAAAAAAAAAUZ9AIAAAAAAAAAAABAQQa9AAAAAAAAAAAAAFBQ79IH6EouuuiiqDvllFOirn///lG3zTbbRF1TU1PULV++POpGjRoVdf/5z386bCZOnBhdK7X11ltH3dNPPx11X/3qV6OupaUl6rbddtuog5LGjBnT0Ou9/fbbUZe+thx//PFRt27duqjbbbfdoi510kknRd38+fMb+rzQUxx00EFRd+qpp0bd3//+96hbtGhR1PUE1113XdT17ds36qZOnVrPcaAukyZNirqbb7456n70ox/Vc5xupbm5Oermzp3bySehJ0k/z5g+fXrUvfLKK1GXvhb06pX9+/Q+ffpE3YgRI6JuyJAhUTd8+PCoGzp0aIfNCy+8EF0rfS049NBDo27YsGFRt3Dhwqj7zne+E3UPPPBA1EFPMnjw4Kh79dVXoy79+/vuu+9GXfr50uc+97moS6WfB915550NfV4oZcOGDVGX3qedddZZ9RynW0nf6+y7775Rd99999VzHOhSVqxYEXWtra1Rt/vuu0fdgAEDoi5xzjnnNOxalUqlUqvVou6LX/xi1G233XZRd+mll0YdbInOPPPMhnaNdO6550bdlClTou6dd96p5zj0EG+++WZDr7dq1aqo23XXXaMuvS84+OCDoy6Vfr75wQcfRN348eOj7r///W/UJTuxZ599NrrWV77ylahL71vSz2TeeuutqEs3e3fffXfU8cn5hl4AAAAAAAAAAAAAKMigFwAAAAAAAAAAAAAKMugFAAAAAAAAAAAAgIIMegEAAAAAAAAAAACgIINeAAAAAAAAAAAAACjIoBcAAAAAAAAAAAAACjLoBQAAAAAAAAAAAICCDHoBAAAAAAAAAAAAoKDepQ/wWXj//fejbs2aNVG3cePGqBs+fHjUrVixoqHXe/TRR6Nu5cqVUdfW1tZhM3v27Ohaxx13XNTtu+++UTdlypSo22qrraJu2LBhUffggw9GHZSUvva9/vrrUTdixIh6jvM/3nnnnaj729/+FnVnnHFG1KWvkdVqNerGjRsXdddff33UnXbaaVEHpfTqlf17sLlz50bdAQccEHXz5s2Lup7glltuibr99tsv6h544IGo25L+G9P1pD93tySzZs2KukGDBkVdeg8ElUql8rWvfa3I86afLfQUq1ev7rDp169fQ5/zpZdeirrtt98+6t58882oS+9HYEuUfjacvh5cffXVUZfea8yfPz/qUv/4xz+i7tlnn426iy++uJ7jQJcxefLkhl7vqquu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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 9\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 7\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_guided_afterone_samples = {}\n",
    "for class_to_sample in classes_0497:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    samples = generate.generate_continuous_label_guided_samples(\n",
    "        label_guided_afterone_model, sde, class_to_sample,\n",
    "        lambda c: class_to_class_index_tensor(c, classes_0497),\n",
    "        sampler=\"pc\", t_limit=t_limit, num_samples=1000\n",
    "    ).cpu().numpy()\n",
    "    label_guided_afterone_samples[class_to_sample] = samples\n",
    "    fig = plot_mnist_digits(samples, grid_size=(10, 1), scale=5, title=None)\n",
    "    fig.savefig(\n",
    "        os.path.join(out_path, \"mnist_class_extension_label_guided_after7_%d.svg\" % class_to_sample),\n",
    "        format=\"svg\"\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "8db51bf0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n"
     ]
    },
    {
     "data": {
      "image/png": "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q1bVbGe78cILL0TdIYccEnX33ntv1K1bty7qTj311KiDnc2kSZOirlevXlHXvXv3qGvTpk2jTX19fbTWjBkzom7gwIE17WbOnBl17dq1i7qzzz476saNGxd1S5cujbo1a9ZEXb9+/aIOPogrr7wy6kaPHh11yfVOy5Yto7VatMj+X2379u2j7rnnnou6Qw89NOpqbcmSJVHXrVu3qCuXy9VsB7aJ888/P+pGjRrVaNOzZ89orc2bN0fdq6++GnUPP/xw1J100klRt9dee0Xdli1boi455yuVSqU//elPUXf00UdHHewI/vVf/zXqHnrooahLP3vT66xNmzZFXevWraMuNXTo0Kh79tlnoy4993Puwvauf//+UffSSy812qT3t1M33XRT1I0ZM6amx621ffbZJ+qeeOKJqLvsssui7uabb446KNL69esbbebPnx+tlf6upc9+nnnmmag76qijoq4oixcvjrp0XmHOnDlR95GPfCTq4INIz1uSZ8srV66M1urbt2/UFSWd00mfxa1du7aa7cAOKT03aNu2bRPv5MN79913oy69hzx58uSoGzJkSNSl90bSa8rbb7896saOHRt1RalUKg3+xfiGXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAAChQXdEboFR66qmnom7r1q1R94c//CHqzjzzzKhrDq6++uqo+/rXvx51++67b9Rt2rQp6urr66OOHdO0adNqut7KlSujrlu3bjU9blH69OlT0/XS398DDjgg6jZu3Bh1Z5xxRtRBUSZNmhR1n/jEJ6Kurq6Y08xDDz200eb555/fBjtpeuvWrYu6z3zmM1HXokX2f/3+9Kc/Rd3JJ58cdfBBdO/ePerOPvvsqHvnnXeirlKpNNq8/fbb0Vp9+/aNuieffDLqrrjiiqhLf3cfe+yxqPvoRz8adc3lnBRKpVJpwIABUfef//mfUZfe50ksX7486g466KCaHbNUKpVOOeWUqEvve6TdjBkzou6oo46KOtgRnHfeeVF34oknRt2bb74Zdf369Yu6c889N+quu+66qKu19H7Q/Pnzo65Lly7VbAe2G9///vejbtGiRY02PXr0iNaaPn161I0ZMybqtne33HJL1LVu3TrqevbsWc12oCpz586NuvS5zvr16xtt2rVrF631+uuvR935558fdb///e+jbnu3atWqqEvv3zz66KPVbAfe16hRo6LuRz/6UdR95StfabS56667orW2d+n1y4UXXhh1l1xySTXbge3KxIkTo27WrFlRN2jQoEab5FlSqVQqPfLII1F33HHHRd3ll18edRdffHHUfe5zn4u61IIFC6Juw4YNUXfWWWdF3dixY6Nue+QbegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBA5Uql0vCL5XLDL9Kok08+Oep+9atf1fS45XK5puvxXitXroy6XXfdNeq2bNkSdXV1dVHHtnHiiSdG3V133RV19fX1UTdr1qyoS33jG9+IulNOOSXqvv71r1eznfd4+eWXo27PPfeMui5dukTdO++8E3Vdu3aNugULFkRd7969ow5S//M//xN1Rx99dE2Pu3Hjxqh79913o+6mm26KuosvvjjqdiYXXHBB1I0ZMybqdtlll6g74YQTou7BBx+MOiiVSqXvfe97UTdu3LiaHvftt99utLn++uujta6++uoqd9O0Ro0aFXWHHHJI1A0bNizq0nM017s0hZ49e0bdm2++2cQ7+fB69eoVdUX9GR544IGo+8hHPhJ16b9Z27Zto857C03hy1/+ctT98pe/jLr0/mHLli2jbv369VG3//77R928efOirtYOPPDAqPvrX/9a0+Om94d32223mh4XUum9yA4dOkTdokWLGm1+9KMfRWvdcsstUddc/KPnsH9vxYoVUXfPPfdE3Te/+c2oo3mbPHly1O2+++5R17Fjx6hLz0e6d+/eaPOtb30rWmvChAlRx/tLz+XSZ9XpMzsolfJ7FZ07d4669F5Ac7B48eKoS87lSqVSafDgwdVsB6qSztV86UtfauKdvL8XX3yx0Wbo0KHbYCfN19q1a6OudevWUZf+rKTXWLVWqVQavCntG3oBAAAAAAAAAAAAoEAGegEAAAAAAAAAAACgQAZ6AQAAAAAAAAAAAKBABnoBAAAAAAAAAAAAoEAGegEA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db1794669F7zziS99/rCCy808U5oTi655JJCjnvWWWcVclya3ve///2oS+cn07mGnYFv6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIACGegFAAAAAAAAAAAAgAIZ6AUAAAAAAAAAAACAAhnoBQAAAAAAAAAAAIAC1RW9ge3JgAEDoq5r165R171792q2QzOwYcOGqNtll12i7sYbb4y68ePHRx3VefXVV6OuX79+UbfbbrtF3eGHHx517JgmT54cdUcddVRNj9u2bduoGzNmTE2Py3utX78+6tq0aRN1PXr0iLp33nkn6oYNGxZ1O5N58+ZF3caNG6OuW7duUdexY8eoSz311FNRd+CBB0bdunXrqtgN27vBgwfXdL3ly5dH3YIFC2p63J3Jd77znahbuHBh1A0ZMqSa7cD7+va3vx116fnN5s2bo66uLrs9Vi6Xo645mDp1atS99tprUfexj32smu3A+0p/d1NXXnll1E2bNq2mx+X9nX766VGXvtd/9atfrWY77ERmzJgRdenzpAceeCDqZs+eHXU7k5deeinq+vTpE3Xt27ePuvTz5emnn4664cOHRx07pjlz5tR0vfR54V577VXT49L0Hnrooaj7zGc+E3XpveY777wz6qBUKpUuvfTSqFu9enXU/f73v69iNzu39DnR3Llzm3YjNCvps+X0d3zXXXetZjtsx+6+++6oGzlyZE2Paxbq//iGXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAACiQgV4AAAAAAAAAAAAAKJCBXgAAAAAAAAAAAAAokIFeAAAAAAAAAAAAAChQXdEb2J7MnDkz6jZv3hx1ixcvrmY7NAODBg2KuhYtstn6448/vprtUGO77bZb1LVr166Q4/7mN7+Jui9+8YtV7IZa+8lPfhJ1e++9d9S9/PLLUffZz3426mh6b775ZtStXr066hYtWhR1//Iv/xJ1O5NvfOMbUZeeGw4YMCDq/vKXv0Tdxo0bo653795Rl56PnHnmmVG3bNmyqGPHNG/evKhr06ZN1K1fvz7qvvCFL0TdzmT58uVR17Zt26hr3bp11C1dujTqDj744KiD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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 4\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACvQAAAEHCAYAAAB78TN5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAArW0lEQVR4nO3ce5DV9X3/8XPkurgICAgiN7kZEawSRESMiBiLTTVqTWo10ahT09q0GR2TOGmmySTGEB1b05nWxCS20xlN4jRGrZeKUVSUKN7FqlxE7sidXUTu5/dvfpPgvnDP+oHl8fj3POfz/bDufs/3+z1vT7VWq1UAAAAAAAAAAAAAgDIOKb0BAAAAAAAAAAAAADiYGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUFDHD3uxWq3WPq6NAAAAAAAAAAAAAEB7VavVqnt7zTf0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACioY+kNAAAAAEB70bdv36h76aWXWmzGjh0brbVp06aoA2grCxcujLrrrrsu6u67777WbAcADkgPPfRQ1O3atSvqzj333NZshwImT54cdbfcckvULVu2LOouuuiiqIMDQXJvMnz48GitarXa2u0AwD7zDb0AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKCgaq1W2/uL1ereX2S/NX78+Kh78skno+6NN95osZkwYUK0VnuxbNmyqFu6dGnUXXPNNVH3yiuvRB0AlHbyySdH3bXXXht148aNi7qRI0dGHcDB5uqrr4665557Lurcm3AwSp+3zJ07N+qamppabA477LBorWq1GnUA++rRRx+NurPOOivqnn322ag79dRTow74eBx11FEtNitWrPgYdtL2tm3bFnVr166Nuv/4j/+Ium9961tRR/v2/vvvR926devqut7o0aOjjo8ufd6Sfube3NwcdR82C/L7evToEXVQUnqtMWDAgLod0/OWP27x4sVRN23atKhbtGhRa7YDB73NmzdH3T333BN1V111VWu2Q6hWq+31TcY39AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFdSy9Aerv2Wefjbpdu3ZFXZ8+fVqznQPK7bffHnVHHnlk1PXs2TPqXnnllaiDA8GsWbOi7uSTT466L37xi1F3zz33RB3w8finf/qnqJs+fXob7wTYFy+99FLUnXjiiVFXrVZbsx3q6NJLL426G2+8MeomTpwYdQsXLow6OBBcdtllUbdz586oO+yww1psduzYEa0FsK/OPffcqEvf89PzVf/+/aMOaJ1evXpF3WOPPRZ148aNa7F58cUXo7XGjx8fdaVs3rw56jZu3Bh1U6ZMacVuaC8mT54cdVu2bIm6rl27Rt3LL78cdbS95ubmuq7XuXPnqPu3f/u3uh4X2sKtt94adXv27Im69957r8WmS5cu0VoHm/RnvGnTpqi74447om7q1KlRB/xxTU1NUZd+TnTVVVe1ZjvUgW/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABXUsvQFyr7/+etR16tQp6jp2zP7zb9myJerag169ekVdhw4dom7p0qWt2Q7sVxYvXhx1AwYMiLrOnTtH3e233x5199xzT9QBrdOnT5+omz59ehvv5MAzbdq0qJs5c2bU/epXv4q6z3/+81FH+/bQQw9F3Yknnhh18+bNa812KGDy5MlR98orr0Tdd77znai75JJLog5K+sIXvhB1f/d3f9fGO/lDc+bM+diPCRwc7r///qhrbm6Ouu7du0fdsGHDog5onWeeeSbq+vXrV7dj3nvvvXVbqy0cf/zxUbdo0aKoO+WUU6Ju586dUUf79vTTT0fd+vXro66hoSHq3n///ajjo5s0aVLUnXnmmVGXfi7f2NgYdelnbNAWBg0aFHUXX3xx1PXv37812/n/fPvb367bWgeCZcuWRd3q1auj7l//9V+j7qabboo6KKlWq0Vd8h6dPhtJDRkyJOoGDhxY1+NSnm/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABXUsvQEqlccffzzqunTpEnXLly+Puo0bN0bdUUcdFXXtwTnnnBN1jzzySNRNnz69NduBj8XNN98cdUOHDo26NWvWRN0RRxwRdffff3/UAR+PJ598MurS64xDDz006n79619H3f7s3nvvjbqmpqaoGz9+fGu2w0FmyJAhdV0v/dul7Z166qlR9+abb0bdCSecUNfukksuiToo6ayzzoq6devWRV2fPn2ibuXKlS02v/nNb6K12ounn3466tL70y9/+ctR9+CDD0Yd7ItarRZ1//zP/xx11157bWu285Glz4bTf++WLVtasx046A0bNizq0nvAbdu2Rd3ixYtbbKZNmxatdeONN0Zdqlu3blH3y1/+Muo+8YlPRF1zc3PUXXrppVFH+5b8DVUqlcrhhx8edenv/V/91V9FnXv3j+7kk0+OuhdffDHqGhsbo+6DDz6Iuvnz50cdtIX//d//jbr+/ftH3QsvvBB1s2bNarH5zne+E621v0uvWw45JPuux7feeivqHnjggaiDkl5//fWoW716ddS9/fbbrdnOR/Luu+9G3a5du6Lu1VdfbcVu+Dj5hl4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFBQtVar7f3FanXvL9KiBx98MOrOOeecuh530aJFUTd8+PCoq1arrdnOfuHDfs9/X1NTU9QtWbIk6o4//viog7bQq1evqNuwYUPU7dixI+o6d+4cdW+++WbUjR49OuqAj8fOnTujbtWqVVG3cuXKqJs4cWLUlTBgwICoS68fOnbsGHXpNd+IESOijvYt/ZtsaGiIuh49ekTdBRdcEHX33ntv1PHRbd26NerS34FUe7if5MCVXj/MmTOnjXfyx82dO7fFZsKECR/DTvYf6fOb5ubmqPv85z8fdQ8//HDUQaWSPx9Zu3Zt1HXp0iXq+vTpE3WlpH+/GzdujLrDDz+8NduBA84tt9wSddddd13Upc8ghgwZEnVLly6t21r1tnjx4qgbOnRo1C1fvjzqBg4cGHXuiahU8vfJLVu2RN0hh2Tf2fXqq69G3aRJk6KOP5Reo7333ntRl/63HTlyZNQtXLgw6mBfXHTRRVH3q1/9KurefvvtqNu0aVPU7c+fJ9XbsmXLoq6xsbGux03nEKAtpM9ltm3bFnXpc5mf/OQnLTZf+cpXorVS6TVk6t133426o48+uq7H5Y+r1Wp7vVn0Db0AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKCgjqU30J6dc845dV3vzTffjLqdO3dG3U9/+tPWbGe/8O1vfzvqtm/fHnXpz+6GG26IOihpw4YNdV1v165dUbd58+aoGzduXGu2A9TZL3/5y6hbvnx51PXq1SvqBg8eHHX7s9/+9rdRt3Tp0qg7/PDDo+4f/uEfog4qlUrlpJNOiroFCxbU9bhTp06Nunvvvbeux+UPpT/jCy64IOrWrVvXmu1Aq9x9991Rd8opp0Tdjh07oq5z585RN2/evKibMGFC1LUHN910U13X6969e9Q9/PDDdT0u7dvXvva1qJs9e3bUnXHGGVF39dVXR93+7rbbbou6iy++uI13Agem888/P+rS6/AhQ4ZE3eLFi6Nu2LBhUVdPzzzzTNSlP5OhQ4dG3caNG6MufUYGlUqlsnLlyqjr0KFD1HXsmH3E/8lPfjLq+OgmTZoUdek5I31env4OQFv45je/Wdf1jjnmmKir9/zN/uzyyy+PuvT5SI8ePaLuN7/5TdRBWxgxYkTUpfNf6bPc5557Lurmzp0bdfW0devWqEufb/fr16812+Fj5Bt6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQR1Lb+BAdMwxx9R1vSVLlkRdY2Nj1A0aNCjqDjvssKg74YQTWmxeeeWVaK16O+uss6KuS5cuUfenf/qnUTdr1qyog7ZQq9WibvPmzXVdL+3ee++9qNu2bVvUAR+Pz33uc1G3YcOGqHv77bdbs50DyogRI6Lu9ddfj7phw4ZF3YMPPhh1UKlUKsuXL4+6O+64I+q+9KUvRd0VV1wRdVdddVXUNTQ0RN3BpG/fvlF34YUXRl167zRw4MCog32xevXqqOvXr1/U7dixo0h39tlnR117sGbNmqg75JD6fqfA4sWL67oeVCqVyowZM6IufT6ycePGqNu9e3fU7e8uueSSqOvTp08b7wQ+HitWrIi6AQMGtPFOWid9jz7vvPNabC699NJorXHjxkVd+nwktXPnzqgbO3Zs1C1cuLA12+Eg07lz56hL/ybT5yO33XZb1PHR/fznP4+69LOz1H333Rd19Z5rgEqlUhkyZEhd13v44Yfr2rUHZ555ZtQtWrQo6o488sioa25ujjpoC5/5zGeiLn0uk15/fepTn4q6EhYsWBB1xx57bNSlz98pzzf0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAgqq1Wm3vL1are3+RFj3++ONRd8YZZ0TdO++8E3V9+/aNuo4dO0bdnDlzWmw2b94crXXBBRdE3YwZM6LuL//yL6OuU6dOUTdo0KCo2717d9TBvviw8/FH8fLLL0fdhg0boq5Hjx5RN378+Kh78803o+7YY4+NunqbNWtW1N16661R98ADD7RiN/DR/fd//3fUHXfccVHXu3fvqOvQoUPUHX744VFXTw8//HDUTZs2LerWr18fdf369Yu69LqqZ8+eUQdtIblHqFQqlYkTJ0bdwoULo27RokVR9+KLL0bdN7/5zahLjBgxIurSf2uq3ved6TkovTasVqtRB5VKfk+0Z8+eqEt//954442oS9/LjzjiiKjbnz3xxBNRN2XKlKhLr5dS6Xn+7LPPrutxad9++9vfRt3UqVOjLn1+2NTUFHUl7p32RXoO37hxY9T95Cc/ibpvfOMbUQepu+66K+rSZ6Bdu3aNuoaGhqhbvXp11KWfE6V/k42NjS026TVa+jwjPa+k3apVq6Iu+bdWKvnnSb/4xS+i7oYbboi6d999N+rYv6xduzbq0r+j9J7jW9/6VtR973vfizr+0OLFi6Nu+/btUZeeW9JnZMcff3zU0b5NmDAh6mbOnBl16Xtl+hz0mGOOibqDyauvvhp1o0ePjrqlS5dG3fDhw6MO9sW4ceOi7vnnn4+6LVu2RF36fPP888+PuhLWrVsXdenn90uWLIm6oUOHRh2tU6vV9voBhm/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABVVrtdreX6xW9/4idfPWW29F3dq1a6Nu/PjxUbdx48aoO/LII1tstm3bFq21bt26qBs4cGDU7dixI+oef/zxqPvUpz4Vdffff3/UXXzxxVFH+zZhwoSoe+655+p63AULFkRd+nd5yimnRN2Hva/8vmq1GnW7du2Kuo4dO0ZdKUOHDo26JUuWtO1GOOgMGjQo6pYuXRp1W7dujbpu3bpF3TvvvBN111xzTdTdfvvtLTYNDQ3RWnv27Im6/v37R92mTZui7qmnnoq68847L+qgLWzevDnqNmzYEHVPPvlk1F122WVRl76fvv/++1HXqVOnFpuRI0dGa82YMSPqfve730Xd1772tahLr+VSW7ZsibrXX3896iZNmtSa7bCfS58/9OzZs203shfLly+PuvS6qp7Sv/ExY8ZE3fnnnx91jY2NUffee+9FXb9+/aIutXLlyqhL7xPrvT8OTOnvVXr9nz7nmThxYtSl0nusPn36RF16b7dz586o69q1a9Sl1xqHHXZY1EGpZ7Tp30Zyz1Gp5H8b6Xt5c3Nz1HXv3j3qEum1Ya9evaJu9erVUZeev5ctWxZ19b42TO+fjz/++KhbsWJFa7ZDnTU1NUVdPf/WKpX87yN9zvj888+3ZjsHlA8++CDq0mubUtLP4mjf0s9XvvKVr0TdMcccE3VPPPFE1E2dOjXqDibpZ3HpnM73v//9qLvllluiDiqV/HnGI488EnU9evSIunTG7thjj426EtLz45QpU6IunalZv3591KX3TvWWzjt26dIl6p555pnWbKfN1Wq1vV6o+YZeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQUMfSG6BS+cQnPlHkuFdddVXU/fCHP2yx6dWrV7TWunXroq53795R19DQEHVTp06Nus6dO0fd6aefHnVQqVQqzz33XNTt3r076rZs2RJ1Rx99dNR17Ji9FaxevTrq+vfvH3Xpvzfd3wcffBB1Xbt2jbr169dH3Y4dO6Ju5syZUdelS5eoa2pqirqxY8dGHe3XjBkzoi49t+zatSvqunXrFnXpuerWW2+NukMOafn/VzviiCOiteqtZ8+eUTd79uy23Qh8iBEjRkRdes5YuXJl1F144YVRl77fv/fee1HXoUOHqBs9enTUJT772c9G3Z//+Z9HXbq35cuXR116j5Xesw0aNCjqODDNnTs36mq1WtTV+54jPVcNHDgw6lJjxoyJutdee63FJv03vPPOO1HXqVOnqGtubo66fv36Rd3ChQujLn0fGjBgQNSlPz+oVPL7+/R+vG/fvlGXXt9s2rQp6tLnHul6aTd48OComz9/ftTNmzcv6iCVPqNN/d///V/Updfr6fOW9FnpU089FXWLFy+Oussuu6zFJr1+SK9H0nuYel/LpdcZ6XkqvTZcsmRJ1D322GNRd+yxx0YdrZP+3jc2Nkbdxo0bo2779u1Rl947pefI9L5j2LBhUZecg9Lnx2+//XbUpfcw6TVVem2Y/g4kz7crlfz+GSqVSuWaa66JuvRzndTdd98ddUOHDo26d99996NvZj9x5ZVXRl36jLZarUbdxIkTow72xZw5c6Ju1apVUdejR4+oS58fpueMIUOGRF1yHZTeS7zwwgtRlz4zSs8Zb7zxRtSlz27SGbv0/vm0006Luh/84AdRl95jpfeeHyff0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAqq1mq1vb9Yre79Rfg9H/Z79PteeumlqDvxxBOjbtGiRVE3cuTIqIO2kP59pFavXh11jY2Nde3S4/bv3z/qtm7dGnXdunWLutQHH3wQdbt37466dH+bN2+Ouk6dOkVd+t8t9fLLL0fdvffeG3Xf/e53W7MdCqj3uSr9W3v22Wej7sYbb4y6J554IuoSTz/9dNRNnjw56mbPnh11p512WtRBSc8880zUnXzyyVHXoUOHqFuyZEnU7dq1K+qGDx8edfX03HPPRd2KFSui7oILLoi6pqamqOvevXvUVavVunYcmOp9/VBvq1atirrevXtHXXpPtHPnzqhrbm5usTnhhBOitR599NGoS69b9uzZE3X1vi9Zvnx51A0cOLCux506dWrU1fNak/3PgAEDou7uu++OuvRep6GhIeq++tWvRl0q/X2eMmVKXY+bniM7d+5c1+NCeo+QPs9Ir4O6du0adekzwfnz50fdqFGjou7666+PuunTp7fYpO+n6TXakUceGXXLli2LusGDB0cd7ItNmzZFXfr5QPp7mp6r0uuMDRs2RF16Tkvf75P9HXJI9v1k6flx9OjRUZf+TNavXx916WfV6Xrp+1Dfvn2jjvbtrrvuirqLL764rsdNz309evSIuh/96EdRd9lll7XY/O53v4vWWrBgQdT9z//8T9Sln7Omn6On7wczZ86MuiuuuCLqaN/mzp0bdelzwUMPPTTqBg0aFHWp9ByUXi+tXLmyxWbo0KHRWgsXLoy6ESNGRF29zZo1K+rSa9f03i79b5He36efUaazjPVWq9X2+gGab+gFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFdSy9AdqHefPmRV1DQ0PULV26NOpGjhwZdVBStVotvYUPddhhh0Xdyy+/HHXNzc1R171796h75JFHom769OlRV2+f/OQno2737t1RN2PGjKg76aSTom779u1R17Fjdknw6U9/Ouq++93vRh37j7feeivq/v3f/z3qfvSjH7VmO/uFyZMnR93ChQuj7rTTTmvNdmC/cuqpp9Z1vTvvvDPqjjvuuKi76KKLou7ss8+OuilTprTYpPc6n/3sZ6Nu/fr1UTd37tyoS6/RxowZE3XpNSTt25NPPhl16bVrt27doi69xk3vOTp37hx1GzdujLqhQ4dG3fDhw6Mucdddd0Vdjx49ou7kk09uzXb+wK5du6LuqKOOirqtW7dG3dq1a6MufX954oknoo4D08qVK6Pu9NNPb+OdfDxuvPHGqEuug/bFX/zFX9R1PUj9+Mc/jrq//du/jbr0ev3555+PumnTpkVdKatWrWqxOeWUU6K1OnXqFHXp89TBgwdHHbSFt99+O+rSe5j093nNmjVRN2TIkKhLr9fTe7Z0veRziW3btkVrjR49OurSc0sqfR6UevPNN6POs2b2xSGHZN/zt3jx4qgbMGBA1HXp0iXqUn//939ft7VGjRoVdePHj4+69Hl0hw4doq5nz55R19jYGHW//vWvo472LZ3DGjRoUNTVarWoS+dlduzYEXXps9z0nHb55ZdH3auvvhp1iXPPPTfq7rvvvqhL/60333xz1KXzALQd39ALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKqtZqtb2/WK3u/UX4Pdu3b4+6zp07R92CBQuibtSoUVEHtN6HvV98FFu2bIm67t271/W4B5t169ZFXe/evaNu165dUdepU6eogxI6duwYdTt37qzrcavVal3XA9gXd955Z9RdfvnlUffQQw9F3Z/92Z9FHQemm2++Oeouu+yyqOvbt29rtvMH5s2bF3X/+Z//GXWPPfZY1N1www1R179//xab008/PVqrlNdeey3qxo4dG3Xz58+PugEDBkTdu+++G3VjxoyJOtdztCd/8zd/E3Xf+973oq5nz55R16FDh6iDevvHf/zHqPv6178edQfbM8vk2fCGDRuitdLPiRobG6PO+zMlDR48OOreeuutqGtoaIi6Bx54IOp+9rOfRV367/jqV78adTt27Ii6NWvWtNjs2bMnWiv92d1zzz1R94UvfCHqhg8fHnVdu3aNuokTJ0bdiy++GHVQqVQq06dPj7r0eV+9vfzyy1F34okn1u2YW7dujbpu3brV7ZiVSqWybNmyqBs0aFBdj+t6qX0766yzou7nP/951KWfjx566KFR19zcHHVdunSJunr/fezP0nPVtm3bou7www9vzXaos1qttteTs2/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABVVrtdreX6xW9/4iB43vf//7LTY33HBDtNacOXOibtKkSVEHtN43vvGNqLv22muj7tBDD426UaNGRd2KFSuijj+uubk56hobG6Nu1qxZUXfGGWdEHZTQ1NQUdbt27Yq69LzXpUuXqAPYF1deeWXU/fSnP426+fPnR116LVetVqMOaN8+7PljW9q9e3fUbdiwIeqOOOKI1mwH9isPPPBA1H3mM5+Juu3bt0dd165dow7YvyTvlb169YrWeuedd6Lusccei7qrr7466gD2RXqtNGXKlLoed/jw4VG3Zs2auh4X9sXkyZOjbvbs2XU9bvr39sQTT7TYPPXUU9FaQ4YMibojjzwy6tLnD/3794+6AQMGRN2qVauijgPTl770pai7/vrro+7000+PurVr10Ydf+iqq66Kujvu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\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 9\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACvQAAAEHCAYAAAB78TN5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAoGElEQVR4nO3cebDV9X3/8XvYdwHZF5GARokgOoZaFdex1hiNTmOsk2Ikjli1mpgJqU2jjdVqDTFjqxXBjjudtlpNgtE6bepGrLXGDVEqIJsiIHDZZIfz++s3Y8de7ys5Bz73Xh6Pf7/P+Z434j33e77nzbdSrVYbAAAAAAAAAAAAAIAy2pUeAAAAAAAAAAAAAAD2ZxZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABTU4bMOViqV6r4aBAAAAAAAAAAAAADaqmq1WmnqmCf0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgjqUHgAAAGBf6969e9R9/PHHe3kSAAAAAAAAAPCEXgAAAAAAAAAAAAAoykIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUFClWq02fbBSafogAAAAAAAAAAAAABCpVquVpo55Qi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAV1KD0ALd/VV1/dbHPttddG5xo8eHCt4/wvf/3Xfx11M2bMiLolS5bUMA3Q0NDQ0KFD9qtl2bJlUdevX7+oe/7556PuqKOOirrGxsao27hxY9StXbs26tI/78UXXxx1b7zxRtQBn1atVuvaXXnllVE3ffr0qAMAWqann3466p599tlmm5tvvjk61/bt26Ouc+fOUXf55ZdH3d133x11wL5zxx13RF16X6FHjx5Rl75f/dVf/VXUbdmyJeqgrUh/99511111fd1FixZF3VtvvdVss3z58uhcF110UdSl912HDx8edQAAAC3B0KFDo+6pp56KunHjxtUyDi2QJ/QCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVWq1WrTByuVpg/SYrVrl+1p33vvvVH3jW98o5Zx/pfNmzdH3bZt26KuU6dOUbd79+6o69u3b9RBW/L4449H3THHHBN1a9asibrx48dHXfp+8Fm/zz7pgw8+qOv5Pv7446hL/7xr166NuoULF0bdscceG3XQ0v3617+OukGDBjXb7NmzJzrXsGHDom7OnDlRN3HixKgD+E1ceOGFUbdz586oe/TRR2sZB/aJIUOGRN2rr74adQMHDqxlnE9Jf946duxYt9fcsWNH1L388stRl/4ZTj311KgDmjZ79uyoO+GEE6KusbEx6oYOHRp16X3Vrl27Rt3ixYujbuTIkVFXqVSiDurtgQceiLqLLroo6tavXx91W7dujbrBgwdHXT2l93HT65b33nsv6o466qioA9q2E088Mep+/vOfR116D3nevHlR594wtCzp57Czzjor6qZOnRp1t912W9QBrdNpp50Wdffdd1/Upfc8evfuHXU9e/aMOvaNarXa5F+wJ/QCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCKtVqtemDlUrTB9nn+vbtG3Xz5s2Lui5dukRd7969o64tuOeee6JuypQpe3kSaNpJJ50Udc8++2zUrVixIur69OkTdV27do26Ui699NKoGzJkSNR94xvfiLpu3bpF3aBBg6Ju8+bNUbdu3bqoGzFiRNRBvb300ktR98UvfjHqdu/e3WyT/lwMHDgw6iqVStTV25IlS6Lukksuibpf/vKXNUwD/PCHP4y6SZMmRd3nPve5qHv//fejLr0G+td//deog71h8uTJUXfvvffW9XVfeeWVqPuse2iflP78HnjggXV7zZ07d0bd1q1boy69vrntttui7i//8i+jDtqSBQsWRF2/fv2iLvms09DQ0PDQQw9F3c9+9rOoS+8vfeELX4i6Rx55JOoOPfTQqHviiSei7txzz406SK+bZ86cWdfXXbZsWdRNnz69rq/7zW9+M+r+8A//sNnm1Vdfjc6Vvk+dcMIJUXfttddG3T/90z9FHdCy3HXXXVF3+umnR1363U/6nU56rzn5/Af7qwsuuCDq7r///qhL92ASe/bsibr0+/Zhw4ZF3cUXXxx1DzzwQNQBTUvvyyTfaY8aNarWcX4r6efEK664Yi9Pwm+iWq02eRPeE3oBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBlWq12vTBSqXpg+xzc+fOjbru3btH3bBhw6Ju+fLlzTYbN26MzrVz586o6927d9T927/9W9QddNBBUffhhx9G3ZQpU6IOfhPXX3991H3zm9+Mul69ekVdly5doq5r165R953vfCfqVq9eHXWzZs2Kupbus37fftIbb7wRdUceeWTUrVmzJur69+8fdZD6m7/5m6i76KKLou6dd96JuuOOOy7qWrJzzjkn6u69996oe+qpp6Ju0qRJUQf7o4ULFzbbHHzwwdG5Ghsboy59H73pppuiDlqD9Jq53uerVCpR99prr0XdL37xi6j79re/3WzToUOH6Fzp57p6u+yyy6Ju5syZe3kSaHnS+6Bz5syJulNOOaWWcVqd0aNHR93Pf/7zqBszZkwt47AfWbVqVdRt27Yt6pYtWxZ1EydOjDo+be3atVF34IEHRl36fptep6XfY0FbcuONN0bdD37wg2ab//iP/4jOdfvtt0fd7Nmzo+69996LuvSz2JAhQ6IO2pLLL7886tKf3/R374oVK5ptOnXqVLdzNTQ0NHTr1i3q0u/bV65cGXUTJkyIOtgfpd8ZP/7441G3a9euZpv09/0TTzwRden5Ro4cGXV9+/aNOvaNarXa5BcTntALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAK6lB6ABoaNmzYEHU9evSIusbGxqhbtWpV1D377LPNNpdcckl0rpZuy5YtUTdlypS9PAltyVe+8pWou+GGG+r6uosWLYq60aNH1/V1+b9dffXVUTdt2rSo27ZtW107SK1fvz7qDjjggLq+7nHHHVfX85Vw1llnRd2DDz4YddVqNerOPvvsqIP9UfpztGDBgmab119/PTpXeu118MEHRx20Bn//938fdZs2bYq6nj17Rt2uXbuibsaMGVF31VVXRV3quuuua7Y55ZRTonM99thjUde9e/eoa9++fdTdfPPNUZfeq3rkkUeiDkqaNGlS1HXokN16nzVrVi3jtFkLFy6MukGDBkVd+h5+xx13RB2tzy233BJ1ixcvjrr0uuX000+POj4t/flOv2ObPXt21J166qlRl84HbUn6ueOggw6Kuvvvv7/ZZvLkydG5Utdcc03UjRw5MurS79uhNRg/fnzUPfPMM1HXq1evqFu3bl3Upfd5jjnmmGabdu2yZx9eeumlUXfmmWdG3bHHHht1w4cPjzpoS9K9mnSfYsCAAVFXz++00x2dM844I+rSHbb0zzB06NCo++CDD6KOvccTegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEGVarXa9MFKpemD1M1n/R180s6dO6OuQ4cOUbd27dqo69+/f9S1BVu2bIm6JUuWRN2YMWNqmIaW7rLLLou6W2+9Nep69OgRdVu3bo26nj17Rh37xjPPPBN1xx9/fNSl71cnn3xy1L3++utRR9v18ssvR93nP//5qHvuueei7pxzzom6tuCxxx6LuvPOO6+ur3v33XdH3eWXX17X14W9Yd68eVHXp0+fqEs/O91xxx3NNjfeeGN0rhkzZkTdKaecEnVf+9rXos7vekpK73s0NjZG3bZt26JuyJAhUbc/ee2116Ju/Pjxe3eQJkybNi3qvve97+3lSaBp6XtaqlKp1PV8+5sPP/ww6tq3bx91AwYMqGUcWrDly5dHXffu3aPujTfeiLr0up5Pmz59etR9+ctfjrpevXpF3Y4dO6Juf/rujLYv/f/5xRdfjLqZM2dGXXr9X0/ptdzSpUujbsSIEVHnmo/WIL33mu5AzJ8/P+o2btwYdb/zO78TdSWk/+3SzyW333571KXf/0BrsGjRoqg74IADou473/lO1D344INRl5gwYULU/dd//VfUrV+/Puref//9qBs7dmzUsW9Uq9UmLxA9oRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABTUofQArdGxxx4bdbNmzarr63bs2DHqnnjiiag7++yzaxmnTerSpUvUHX744Xt5ElqDO++8M+o2b94cde3bt4+6VatWRd2kSZOi7qGHHoq66dOnR136HtS7d++ou+KKK6Iune+8886LuhNOOCHqBgwYEHX1dsABB0TdLbfcEnVnnnlmLePQBhx99NFRl75XXX755bWM06r8/u//ftSl7z8LFiyIutdeey3q9qe/C1qvE088MeoOOeSQqNuwYUPU9e/fP+rq6Vvf+lbUpX+G119/vYZpoGXZs2dP1D3//PN7eZK266ijjoq6uXPnRt0RRxxRyzifcscdd9T1fPCbOPnkk6Nu48aNUderV68apuH3fu/3ou7NN9+Mujlz5tQyDm3AsGHD6nq+oUOH1vV8fFp6bdizZ8+oS9+Xly5dGnXQGqS/T59++umo+/GPfxx106ZNi7p6uu+++6IufW8ZMWJE1LnmozW4+uqro27Xrl1Rt2PHjqjr1q1b1LXk3YuFCxdGXXqt2blz56i7++67ow5ag6lTp0Zd+rt3zZo1Uffggw9GXT299NJLdT1fulOTdrQentALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAK6lB6gNZoxIgRUffxxx9H3erVq6Pua1/7WtQ999xzUcenffDBB1HXs2fPvTwJrcH5558fdY8//nhdX7dXr15R9+1vfzvqbrzxxrq+7te//vWo69SpU9S1a5f925ODDz446oYMGRJ1y5cvj7rU/Pnzo27gwIFR17lz56j77ne/G3Xw9ttvR93YsWOj7p//+Z+j7vjjj4+6luzOO++Muu3bt0fdli1bou6CCy6IOmgNunfvHnU7d+6MupdffrmWcfaqrVu3lh4B9rk/+qM/irqHH3446gYNGlTLOASOOOKIqNu4cWPUpdc39f4cBr+JZ599NurS+yP8344++uiou+2226Ju4sSJUbd+/fqog7feeivq0ntz6b3SWbNmRd3+5PTTT4+6jz76KOp2794ddU8++WTUQWswbdq0qEuvw6dOnVrLOHvV5MmTo+6EE06Iui5dukRd+/btow5K+upXvxp148aNi7pXXnkl6tKdivS7jvTn/Hd/93ebbdLvbf/7v/876tL72+n3RNCWpD8f77zzTtSNGjUq6hobG6PupZdeirrkPmilUonOVW/pPRRaD0/oBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABXUoPUBrNH/+/KgbO3Zs1H300UdR99xzz0Udn3bVVVdF3bBhw6Ju9erVtYxDG/HTn/406vbs2RN1u3btirquXbtG3dFHHx11CxYsiLo+ffpE3Ycffhh1W7ZsibrU8OHDo65arUZdv379om7RokVRd9hhh0Xdjh07om7hwoVRN2/evKiDcePGRd3MmTOj7sILL4y6FStWRN1DDz0UdUOGDGm2SX/fp+8ro0aNirpt27ZF3Z/92Z9FHbQlq1atirpu3bpF3Ze+9KWomzp1atQlP78//OEPo3Ol10Dr1q2LOmgNZs2aFXXTp0+PuvSzCZ+WXnulevXqFXUbNmyo6+tCSel9lP79++/lSVqWs846K+qeeOKJqEuvmdLPd+vXr4862q7vf//7UXfzzTdHXXrPt3v37lG3P0nve6Tvo717965hmk9buXJlXc8HJQ0aNCjqOnfuvJcnaTlGjx5d1/O5xqA1OPTQQ6OusbEx6kaMGBF16Xci//iP/xh16T2N999/v9lmwoQJ0bnSnZ/0+/v03he0JW+//XbUXX311VGX/ryl3RFHHBF1yf2HxYsXR+caOXJk1KW8t7Q9ntALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKqlSr1aYPVipNH9yPzZgxI+q+9KUvRV2/fv2irmvXrlG3P1m7dm3U9e3bN+qef/75qKtUKlF34oknRh1t28UXXxx1P/7xj6Nu2bJlUTdq1Kio69ixY9RdeOGFUfezn/0s6lq6NWvWRF27dtm/jenWrVvUde7cOerS9yEo5Y//+I+j7txzz426M844o4Zp/rdt27ZF3XvvvRd1Y8aMibq33nor6saOHRt1sD9Kr6//5V/+Jep69OgRdV26dGm2Sa/RDjrooKh76qmnoi793AmtwaJFi6IuvY+SXmc888wzUdeS/frXv466o48+uq6vm14vnXPOOVE3b968WsaBfSK9f3PRRRdF3bhx46Kud+/eUTds2LCoO+mkk6LuiiuuiLpVq1ZFXXr9NXz48Khzf4RSPuu7tU+aP39+1B1++OG1jNOq/OpXv4q69P1xx44dUffxxx9H3QMPPBB11113XdRBSXPnzo26gQMHRt2AAQNqGadF2L17d9Sl3/24FqEtST/rpP/fd+rUKepOPfXUqPvBD34QdYMGDWq2mT59enSu//zP/4y6I488MurSa76lS5dGHbQlTz75ZNSl9zN27txZyzifkuzVpPdGRowYEXWuR9q2arXa5F+cJ/QCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCKtVqtemDlUrTB/djS5cujbo+ffpEXc+ePaNuxYoVUTd06NCoS02ePLnZ5t57763ra7YVlUql9AjAb2n16tVRt3jx4qgbMGBA1H3ve9+LukceeSTqYH8zatSoZpsXXnghOtfgwYOjbt26dVH3la98JermzJkTdUDt0t+7t956a7PN2LFjo3PNnTs36lI+c9CWLF++POqGDRtW19fdsWNH1O3ZsyfqTj755Kh7/PHHm202btwYnatv375R165d9m/7DzzwwKhbsmRJ1I0cOTLqoC2ZN29e1I0ZMybqVq5cGXWDBg2KutTWrVujrkuXLlGXXruk95svueSSqIN6O++886JuxowZUbd27dqoO/zww6OuJfus7yU/Kb1G27BhQ9Rt2bIl6tLv7NLrJSgpve9x7bXXRl3Hjh2jbsSIEVGX3letp/Q96JVXXom6L37xi7WMA7Rw6fVIei13/fXXR90999wTdUDLMmvWrKi74IILom727NlRl34+pWWpVqtN3iTzhF4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFBQpVqtNn2wUmn6IM364IMPoq5///5R16FDh6irVCpRt2DBgqg75JBDmm22bt0anWvjxo1R16tXr6hbtWpV1HXt2jXqBg4cGHWbNm2KuvTPAew7//7v/x51I0aMiLrRo0dH3Zw5c6Ju4sSJUQf89n7yk59E3TXXXBN1c+fOjbpx48ZFHdC2PfbYY1H35S9/Oeo6depUyzjQKn3WvaxPSu9BrFixIuoOO+ywqNu2bVvUvfnmm802EyZMiM710UcfRd3y5cujbsCAAVE3efLkqEs/h8H+6O2334669D7okUceGXWbN2+OuuHDh0fd0qVLo+7pp5+OussuuyzqoKWbOnVq1J1yyilR94UvfCHqDjrooKh7//33o65v377NNt26dYvOlV6PpH+GxsbGqOvdu3fU3XPPPVE3ZcqUqANaltWrV0fdTTfdFHV/+7d/W8s4QAuX3oPavXt31PXs2TPq0v0boGVZsmRJ1KW7KH/6p38adT/60Y+ijpalWq02ueDpCb0AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKCgDqUHaMuGDh0adR9//HHUdeiQ/XVt3bo16g455JCoS3Tt2rWu3QsvvBB19913X9Tde++9Ubd58+ao27NnT9QBtTvjjDOi7uGHH466fv36RV36c75kyZKou+qqq6IO2PuuueaaqEuvR0488cRaxgH2Mx07dqxrd+aZZ0bdU089FXXQGhx++OFRd9NNN0Vdu3bZv3c/7LDDom7jxo1RN3DgwGabBx54IDrX5z73uaibOHFi1L377rtR9+qrr0Yd0LQxY8bU9XxPPvlk1KXXEFu2bIm6arUadZdddlnUQVsxbdq0unY9evSIul/96ldRN27cuKhL7oHOnDkzOtctt9wSdamzzz476p555pmo69y5cy3jAC1c//79o27Tpk17eRKgpJ/85CdRl37OWbZsWdSluzxA6zRo0KCo27BhQ9Sle4e0PZ7QCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACupQegAaGm644Yaou/XWW6Nu165dUffuu+9GXefOnZttRowYEZ2rUqlEXb0dfPDBUffnf/7nUde+ffsapgEaGhoaqtVq1G3bti3q2rXL/o1K+t7XtWvXqBs5cmTUAftG8p6xZ8+e6FyDBw+udRyAT+nVq1ddz/fUU0/V9XzQGsyfPz/qvvrVr+7lSVqOtWvX1vV8Q4YMibp169bV9XWB2jU2Nta169OnT9S5PwL7xubNm6PuyCOP3MuTtBwnnXRS1KX3gzZu3FjLOEAh119/fdQtXLgw6u67775axgFauH/4h3+IugsuuCDq+vfvX8s4QBuxdOnSqDv00EOj7lvf+lYt49CKeUIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoqEPpAWho+NGPflTXjk9buXJl1K1atSrq+vXrV8s40KYNGzasrufr0qVL1M2ePTvq/u7v/i7qnn766agDWpYPPvig2Wbw4MHRuQ455JBaxwH4lCFDhpQeAaBZt99+e+kRgN9S+nmnT58+UffWW2/VMg7AXvfoo49G3WWXXRZ1ffv2rWUcoJAbbrgh6p588sm9PAnQGvzJn/xJ1G3atCnqunXrVss4QBuxffv20iPQRnhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFBQh9IDQEsyZMiQqHv99df37iDQir355pt1PV+1Wo26F154IeqefvrpWsYBChk9enTUDR8+vNmmY8eOtY4D8Fvr3r17Xc/Xr1+/qFuzZk1dXxdoWdq3bx9177//ftR9//vfj7pXX3016h5//PGoA2qX/pw3NjZG3ZYtW2oZB2Cv+5//+Z+o69GjR9Qdc8wxtYwD1Fl63yM1e/bsup4PaJ26desWdem93BdffLGWcYBW4K677mq2GThwYHSuSy+9tNZxaOM8oRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABTUofQAsC9Mnz496v7iL/4i6saPH1/DNNA6LViwIOr69OkTdatXr466AQMGRN20adOiDmid5s2bF3UdO3ZstnnsscdqHQfgt7Z9+/ao27p1a9StWbOmlnGAFu66666LugMOOKCu3YYNG6Iuva6aPXt21J1zzjlRBzRt0qRJUZfel3nxxRdrGQegxVi5cmXUff7zn4+6WbNmRd3Xv/71qAP+b+l3U9VqNeruvvvuWsYB2ohXXnkl6s4///yomzJlSi3jAK3AhAkTmm3S3ZbFixfXOg5tnCf0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACjIQi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgjqUHgBakoEDB9b1fKeddlrU/fKXv6zr68JvolOnTlE3cuTIur7ujh07om779u11fV2gddq8eXPUvfvuu802f/AHf1DrOAC/tY0bN0Zd586d9/IkQGtw/vnnR92cOXOibsCAAVF3yCGHRN1bb71V19cFajd//vyoS++Dum8JtBWPPvpo1E2ePDnqjj/++FrGAUIrVqyIunfeeWcvTwK0JVdeeWVdz7du3bq6ng9oeYYOHVq3c40ePTrq3JPZf3lCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKKhSrVabPlipNH0Q2qDt27dHXadOnaJu5MiRUbdkyZKog5J+8YtfRN306dOjbubMmVE3ePDgqKtUKlEHtE6fdc36SRMnTmy2mTNnTq3jAPzWPvroo6jr169f1LkGAhoa8mulenv33XejbuDAgVHXu3fvGqYBGhoaGs4999you//++6Pu7bffjrrjjjsu6gBauk2bNkXdT3/606ibNGlSDdMAK1eujLrvfve7Uffwww/XMg7QRqT3URobG6MuvZe7Z8+eqANap927d0fdc889F3WnnnpqLePQwlWr1Sa/4POEXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKAgC70AAAAAAAAAAAAAUFClWq02fbBSafogAAAA0NDQ0NBw+eWXR91dd90Vde+8807UjRkzJuoAAD7p9ddfj7rTTjst6tauXVvDNAAAAPvOlVdeGXV33nln1PXr1y/qfG4C4P+rVquVpo55Qi8AAAAAAAAAAAAAFGShFwAAAAAAAAAAAAAKstALAAAAAAAAAAAAAAVZ6AUAAAAAAAAAAACAgiz0AgAAAAAAAAAAAEBBFnoBAAAAAAAAAAAAoCALvQAAAAAAAAAAAABQkIVeAAAAAAAAAAAAACioUq1Wmz5YqTR9EAAAAAAAAAAAoJV47bXXom78+PFRV6lUapgGgP1RtVpt8peHJ/QCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFCQhV4AAAAAAAAAAAAAKMhCLwAAAAAAAAAAAAAUZKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCKtVqtemDlUrTBwEAAAAAaBGOPfbYqHvppZf28iQAAAAAADSlWq1WmjrmCb0AAAAAAAAAAAAAUJCFXgAAAAAAAAAAAAAoyEIvAAAAAAAAAAAAABRkoRcAAAAAAAAAAAAACrLQCwAAAAAAAAAAAAAFWegFAAAAAAAAAAAAgIIs9AIAAAAAAAAAAABAQRZ6AQAAAAAAAAAAAKCgSrVaLT0DAAAAAAAAAAAAAOy3PKEXAAAAAAAAAAAAAAqy0AsAAAAAAAAAAAAABVnoBQAAAAAAAAAAAICCLPQCAAAAAAAAAAAAQEEWegEAAAAAAAAAAACgIAu9AAAAAAAAAAAAAFDQ/wNvFolFq1HW2AAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 7\n"
     ]
    },
    {
     "data": {
      "image/png": "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Ubd9+/aoe/3116MuvQaNGzcu6qZOnRp1v/jFL6LuhBNOiDp2jfR5wW9+85uoS/+Op3+P0vuR9Hd0+hn/vPPOi7oLL7ww6vqyNWvWRF36//hd73pXLduBmqTPZVLLly+PuptvvjnqVq1aFXVvfetbo26//faLugULFkRdva1bty7qxo8fH3VDhgypZTv0Yeln42XLlkVd+j3MHnvsEXUTJkyIulNPPTXqLr300qhLpd9NPPnkk1H3tre9rcfm7rvvjtY66qijoi69h0zvR9LPMPPmzYu6J554Iuron9JnqsOGDYu69DN+2rW3t0dd+tlpx44dUZc+L027O++8s8cmvX6fdtppUZd+B5P+PiilUqmU3gL/4uijj466K6+8MurS5yPp37Xm5uaoe+SRR6IunW1I7+lXrFgRdelnonpav3591L344otRl15burq6oq61tTXq0j8LaGpqarriiiuiLn3el35u/9nPfhZ16f1XMuvW1JTfa+y///49NnfccUe01j777BN16fV78uTJUZde09Lv2LZt2xZ1/GfVarXbGzpv6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAVVqtVq9wcrle4PDmCrV6+Our322quu512xYkXU7bPPPnU9b1/W2dkZdS0tLVG3Y8eOqBs8eHDUfeADH4i6++67L+ron77zne9E3c6dO6Mu/fn7/Oc/H3W77bZb1KW+//3vR92XvvSlqFu1alXUvfjii1F3ySWXRN2VV14ZdS+99FLUTZo0KepSlUqlruvR/zzzzDNRN3v27Kh7+eWXo27jxo1RV+p+5Prrr++xefzxx6O1vvrVr0Zdev+wffv2qNuwYUPUpX+2QO1uvPHGHpu99947Wuviiy+ua5c6/fTTo27JkiVRl34uXrZsWdSdcMIJUUffctttt0XdK6+8EnWf+MQnatkOdfRGzwv/VXrfMnHixFq2AzW57LLLou6QQw6Junnz5tWynQHvr3/9a9TNnTs36jwf6X/S++b0vnT48OFRt3Dhwqj77W9/G3Xpc5RBg7L36px66qlRd//990dd+v3U1KlTo665ubnHZuXKldFa48ePj7rRo0dHXXqvmfw3NDU1NXV0dETdnnvuGXXQGw4//PCoO/PMM6Nu6dKlUXfDDTdEXQlXX3111M2fPz/qnnvuuaibNWtW1I0cOTLqzjnnnKg7//zzo46+Jf05nTZtWtSNGDEi6tra2qIufY637777Rl36XfDf//73qGsEDz/8cNSl15bNmzdH3cyZM6MOqE36jCL9PJl+dlq3bl3U7bHHHlGX/r766Ec/GnX8Z9VqtdsfGG/oBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABVWq1Wr3ByuV7g/So/nz50fd5ZdfHnV77bVX1G3atCnqxowZE3WJZcuWRd2Xv/zlqHvggQdq2c6/+cc//hF1s2bNirrbb7896hYsWBB1QP/1Rr9He3O9QYP8m5xGddZZZ0Xdxz/+8agbMWJE1M2YMSPqGsF+++0Xddddd13UpfcPbW1tUTd+/Pioq1QqUQfQ1NTUtGbNmqhrbm6OusmTJ0fdjTfeGHWLFi2KOqA2w4YNi7rOzs6ou+OOO6LusMMOizqg8T322GNRl37Oam1trWE30P+k33UcddRRUffEE0/UsJvetXDhwqj70Y9+FHXt7e1RN3Xq1Kg7++yzo+7SSy+NOqA2b3nLW6Luz3/+c9StXbs26rZt2xZ1M2fOjDrPfKGxvfjii1GXfrf3wgsvRN2+++4bdcCusXnz5qgbMmRI1LW0tETdqlWroi59JkNtqtVqtzd+poEAAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBzaU30MjuuOOOqJs+fXpdzztkyJCo27ZtW13PW8J73vOeqJs4cWLUbdmyJeoWLFgQdUD/NXfu3KhbuXJl1M2aNSvqXnjhhaijcQ0bNizqli9fHnWLFy+uZTsN6cknn4y6cePGRV16TzV+/PioA/hvvPvd7466qVOnRt3mzZtr2c6/+fCHP1zX9YDavPbaa3Vd761vfWtd1wP6ryVLlkTdAQccEHU33XRTLduBhjV79uzSW9hlbrnllqj7yle+EnW/+tWvom7NmjVRd+mll0YdsGvcddddUbd69eqoa21tjbr169dHXaVSiTqgf/r1r38ddW1tbVGXfj91xhlnRB3Qt6QzITNmzKjredP7Jcrzhl4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFBQc+kNUH/btm0rvYVd5phjjom6SqUSdUuXLq1lO0ADuf7666Nu0qRJUffss89G3RlnnBF1NK5zzjmn9Bb4/84777you/DCC6Nu586dUdfR0RF1QGObNm1a1D3wwAN1Pe/DDz8cdfPnz6/reYFdY/DgwVHX2dkZddddd10t2wEayJlnnlnX9a6++uq6rgc0rmOPPTbq0ucyN998cy3bAQp57bXXom769OlR98wzz0Rd+tkJaGzpNSh95pteg/7whz9EHdC37L777lHX0tJS1/OuWrWqruvRe7yhFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFNRcegPwn4wZMybqTjjhhKi75557ou68886LOqDx7dixI+qGDx8edcuWLYu6a6+9NuqA3pfeZwwZMqSu573gggvquh7QP61cuTLqtm3bFnXptWr+/PlRBzS29evXR92nP/3pXt4JUNruu+9e5LyVSqXIeYH+Z88994y6oUOHRt0NN9xQw26AUsaOHRt1bW1tUTdhwoSoq/ezYaB/WrBgQdS1trZG3dy5c2vZDlDIunXroi6dMdm8eXPUpbMtXV1dUUd53tALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKai69AfhP/vjHP0bd6NGjo27RokW1bAdoIBdddFHUTZkyJeoGDcr+bUxra2vUAX3HsGHD6rres88+G3Xp9Qfon77//e9H3ZAhQ+p63h/+8Id1XQ/on9L7ka6url7eCdBffOtb34q6NWvWRN20adOi7uc//3nUAbzjHe+o63p33XVXXdcDanPyySdH3eDBg6Mu/a6ms7Mz6mbOnBl1QP+Uzpls3769ruf95Cc/Wdf1gNol9xqTJk2q6zn/8pe/RN306dOj7gc/+EENu2FX8oZeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQUHPpDTCwXHfddVE3a9asqLvqqqtq2Q4wAC1atCjqNm/eHHVdXV11PS/Qd2zatCnqNm7cGHV77LFH1L3++utRB/Qtt912W9QddthhdT3vrbfeGnWf/exn63peoG956KGHom7mzJm9vBOg0Xz0ox+Nuo6Ojqj74x//WMt2gAGkvb29ruul1zOgb/n9738fdZdccknUrV27NuomTJgQdUBjS69BS5Ysqet5f/nLX9Z1PaB2733ve3ts1q1bF601ZcqUqJszZ07UpTN29B/e0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAApqLr0BBpb3v//9Uffcc89F3XHHHVfDboBGMnfu3KgbO3Zs1I0aNSrqJk6cGHVA/zN+/PioGzduXF3Pe8YZZ9R1PaB21Wq1x6a9vT1a6x//+EfUDRqU/fvbhQsXRh3QPy1YsCDq9tlnn6h76aWXom7o0KFRBzS+v/3tb1F3yCGHRN3ixYtr2Q4wgIwcOTLqks9rTU1NTVdffXUt2wEK+djHPhZ1GzZsiLrOzs6oO+WUU6IOaGzz58+PuvT74ve+9721bAco6Gc/+1mPzaZNm6K10u+Wr7rqqqh74YUXoo7+wxt6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQc2lN0BjOO6446Ju3LhxUdfR0RF127dvjzqg8d10001Rt2HDhqhraWmp63pA/zNz5syo6+rqirphw4ZF3Y4dO6IOqF21Wq3bWq2trVG3YsWKqDv44INr2Q7QIC677LKoSz+/pNeqJ554IuqAxrf//vtHXXpfdfvtt9eyHYB/s3bt2tJbAHrRZz7zmahLvzNOPzsdcMABUQc0tgMPPDDqtm7dGnUPPPBALdsBesExxxwTdSNGjOixGTx4cLRW+p3xO9/5zqij8XhDLwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKKi59AZoDOeee27U/fWvf426DRs21LIdYACaOHFi1LW0tETdtddeW8t2gAYwbNiwqNu8eXNd1wNqd/nll0ddtVqNukql0mPT0dERrfX73/8+6gCampqapk+fXuS88+bNK3JeYNeZNWtW1KXPUW666aZatgMMIN/73veibseOHVF3zTXX1LIdoI/bsmVL1L3pTW+q63mnTJlS1/WA/unkk0+OuqlTp/byToDecvzxx0fd+PHje3kn/27nzp27/Jz0Dd7QCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKAgA70AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACmouvQEaw8yZM6Pu+eefj7r999+/lu0ADeSee+6JuqFDh9b1vA8++GBd1wP6jn333Tfq2traoq6lpSXqVq1aFXVA7RYvXhx1lUqlbue8++67o27JkiV1OyfQ+LZt2xZ1nZ2dUTdq1KhatgM0kMsuuyzqtmzZEnVLly6tZTvAAPK5z30u6tL7oC9+8Yu1bAfo43bu3Bl169evj7pJkyZF3YQJE6IO6J+q1WrUdXV1Rd2NN95Yy3aAgkaPHh11W7du7bFJn6GMHTs26hi4vKEXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKKi59Abo+6rVao/N2rVro7Vmz55d63aAAWbKlCl1XS+5pjU1NTVdeOGFdT0v0Hc8+eSTRc47a9asIueFRnLNNddEXUdHR13P29zc80fnI488sq7nBBrfwoULe2yGDBkSrZV2P/7xj6MOaHwHHXRQ1K1evTrq7r333hp2AzSCJUuWRF2972+AxpZ+R7Rz586o6+rqirp58+ZFHdA/bdq0Keo2b94cdeedd97/vhmgVxx99NFR97a3vS3qkjmT8ePHR2u1tbVF3cSJE6OOxuMNvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoKDm0hugnClTptRtrVGjRkVdtVqt2zmB/q21tTXq3vzmN9f1vMuXL6/rekDjam9vj7pXXnmll3cC/deJJ54YdV//+tejbsSIEVE3cuTIqHv66aejbs6cOVEH8N+45ZZbdvk5TznllF1+TqB/27p1a+ktAP3EaaedFnV333131B166KG1bAdoEAceeGDUPf7441FXqVSi7vnnn4+6yZMnR91LL70UdUDtkme5Y8aMidZ69NFH69oBu87ixYujLv0+afXq1T026X3Gxo0bo27BggVRR+Pxhl4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFBQc+kNUM63vvWtqFuxYkWPzb777lvrdoAB5oMf/GBd1+vs7Iy6yy+/vK7nBfqW2bNn99ik14vW1tao27hxY9TBQHT22WdH3eTJk6Ouvb096u67776o+8AHPhB1AL1h8eLFpbcADGAPP/xw1B166KG9vBOgUfz0pz+NOp/DgP/GCy+8EHWvvvpq1O3YsSPqpk+fHnWjR4+OupdeeinqgNrde++9PTbbt2+P1vrQhz5U426AUubMmRN1Tz31VN3We+SRR6K1Fi1aFHUvv/xy1NF4vKEXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUVKlWq90frFS6P0ifNXHixKhbv3593c5ZqVTqthYwMJxyyilRd8kll9T1vK5X0NjmzJnTY7NixYq6ntN1hYHo2WefjboZM2ZEXXt7e9Tt3Lkz6saMGRN1AH3dGz23+1+4bwH+W+l16NVXX4263/3ud1F30kknRR3Qd0ybNi3q1qxZ08s7ARrJgQceGHVXXHFF1E2ePDnq0u/bx40bF3VtbW1RB9QueYZ8/vnnR2ude+65tW4HKKTez1UTRxxxRNTdcsstvbwT+oNqtdrtw3pv6AUAAAAAAAAAAACAggz0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAVVqtVq9wcrle4P0u9dcMEFUXfYYYf12Oy///61bgcYYObMmRN18+fPj7qLL764lu0ADWLw4ME9Ntu3b4/WWrt2bdRNmzYt6qA/GDp0aNR1dHRE3ZNPPhl106dPj7pBg7J/k9ra2hp1AH3dGz23+1ePPPJI1B100EG1bAcYgI4//vio+8UvflHX81YqlbquBwD0T5MnT466pUuXRt31118fdVdffXXUAbvOjBkzou7CCy/ssTn66KNr3A3Q1914441Rl34f3NLS0mNz4oknRmtBU1NTU7Va7fbhlzf0AgAAAAAAAAAAAEBBBnoBAAAAAAAAAAAAoCADvQAAAAAAAAAAAABQkIFeAAAAAAAAAAAAACjIQC8AAAAAAAAAAAAAFGSgFwAAAAAAAAAAAAAKMtALAAAAAAAAAAAAAAUZ6AUAAAAAAAAAAACAgirVarX7g5VK9wcBAKCPefvb395jc9ZZZ0VrfeQjH6l1OwAANTnggAOi7vHHH+/lnQDUxyGHHBJ1f/rTn3p5JwAAQCO69dZbe2wOP/zwXbAToD9IrhlNTa4b1F+1Wq10d8wbegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFCQgV4AAAAAAAAAAAAAKMhALwAAAAAAAAAAAAAUZKAXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEGVarXa/cFKpfuDAAAAAAAAAAAAAECkWq1WujvmDb0AAAAAAAAAAAAAUJCBXgAAAAAAAAAAAAAoyEAvAAAAAAAAAAAAABRkoBcAAAAAAAAAAAAACjLQCwAAAAAAAAAAAAAFGegFAAAAAAAAAAAAgIIM9AIAAAAAAAAAAABAQQZ6AQAAAAAAAAAAAKCgSrVaLb0HAAAAAAAAAAAAABiwvKEXAAAAAAAAAAAAAAoy0AsAAAAAAAAAAAAABRnoBQAAAAAAAAAAAICCDPQCAAAAAAAAAAAAQEEGegEAAAAAAAAAAACgIAO9AAAAAAAAAAAAAFDQ/wMloAirG6WHIQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 3600x396 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_guided_afterall_samples = {}\n",
    "for class_to_sample in classes_0497:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    samples = generate.generate_continuous_label_guided_samples(\n",
    "        label_guided_afterall_model, sde, class_to_sample,\n",
    "        lambda c: class_to_class_index_tensor(c, classes_0497),\n",
    "        sampler=\"pc\", t_limit=t_limit, num_samples=1000\n",
    "    ).cpu().numpy()\n",
    "    label_guided_afterall_samples[class_to_sample] = samples\n",
    "    fig = plot_mnist_digits(samples, grid_size=(10, 1), scale=5, title=None)\n",
    "    fig.savefig(\n",
    "        os.path.join(out_path, \"mnist_class_extension_label_guided_afterall_%d.svg\" % class_to_sample),\n",
    "        format=\"svg\"\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5f431ba",
   "metadata": {},
   "source": [
    "**Compare FIDs**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "c2b292e5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling class: 0\n",
      "Sampling class: 4\n",
      "Sampling class: 9\n",
      "Sampling class: 7\n"
     ]
    }
   ],
   "source": [
    "# Sample digits from the original dataset\n",
    "true_samples = {}\n",
    "for class_to_sample in classes_0497:\n",
    "    print(\"Sampling class: %s\" % class_to_sample)\n",
    "    inds = np.where(dataset_0497.targets == class_to_sample)[0]\n",
    "    sample_inds = np.random.choice(inds, size=1000, replace=False)\n",
    "    samples = ((dataset_0497.data[sample_inds] / 256 * 2) - 1).cpu().numpy()[:, None]\n",
    "    true_samples[class_to_sample] = samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "3cf09210",
   "metadata": {},
   "outputs": [],
   "source": [
    "branched_before_fids = {}\n",
    "branched_after_fids = {}\n",
    "label_guided_before_fids = {}\n",
    "label_guided_afterone_fids = {}\n",
    "label_guided_afterall_fids = {}\n",
    "\n",
    "for c in branched_before_samples.keys():\n",
    "    branched_before_fids[c] = compute_fid(branched_before_samples[c], true_samples[c])\n",
    "for c in branched_after_samples.keys():\n",
    "    branched_after_fids[c] = compute_fid(branched_after_samples[c], true_samples[c])\n",
    "for c in label_guided_before_samples.keys():\n",
    "    label_guided_before_fids[c] = compute_fid(label_guided_before_samples[c], true_samples[c])\n",
    "for c in label_guided_afterone_samples.keys():\n",
    "    label_guided_afterone_fids[c] = compute_fid(label_guided_afterone_samples[c], true_samples[c])\n",
    "for c in label_guided_afterall_samples.keys():\n",
    "    label_guided_afterall_fids[c] = compute_fid(label_guided_afterall_samples[c], true_samples[c])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c64ee930",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0: 23.262932678901493, 4: 16.93472286346435, 9: 17.880786877050035}\n",
      "{0: 22.767332410601696, 4: 15.890384463452714, 9: 18.005306687801983, 7: 24.17460249587286}\n",
      "{0: 43.76577030853884, 4: 43.79808348434176, 9: 41.51376057896882, 7: 300.5974901426579}\n",
      "{0: 218.3260000802342, 4: 108.64616057076938, 9: 104.1053352473601, 7: 29.894016774353965}\n",
      "{0: 46.6613347468438, 4: 38.78937387955358, 9: 29.705318500117755, 7: 20.949919516716598}\n"
     ]
    }
   ],
   "source": [
    "print(branched_before_fids)\n",
    "print(branched_after_fids)\n",
    "print(label_guided_before_fids)\n",
    "print(label_guided_afterone_fids)\n",
    "print(label_guided_afterall_fids)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3663d5e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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5DgFhCIiIiI5TgGhiIiISI5TQCgiIiKS4zQOYSX4888/Wbx4MWvWrMl2UURyRp06dWjRogWNGzfOWJ6TJk06OC8v7zLnXGfAMpZxBt1+++18++232S6GiFRA7dq12XTTTWnWrBl169bNShkUEGZYYWEhCxcupEOHDtSvXx+zankMEalRnHOsWrWKefPmUbduXerVq1fhPCdNmrRl3bp17+ncufO6Bg0a/FZd6/K0adM6de/ePdvFEJFycs6xdu1ali5dypw5c9hss82yEhTqknGGLVq0iJYtW5Kfn69gUKSKmBn5+fm0aNGCRYsWZSTPTTbZ5F9t2rSxhg0brlRdFpHKYmaxKxxNmzZlyZIlWSmHAsIMKywspGHDhtkuhkhO2nTTTSksLMxIXmbWq1GjRisykpmISAoaNWrEsmXLsvLZumScYevWrWOTTbRZRbJhk002Yd26dRnJyznXJC8vLzs/1au5wt++ykg+9Zr3zEg+IjVFXl4e69evz8pn6wxhJdDlJZHsyHDdq6W6LCJVKZttjgJCERERkRyngFCqlbVr13L99dfTtWtX8vPzOfPMM7NdpEpz2223kZ+fz+677572EEXnnXce9evXp3///pVTOJEKWrt2LTff8RDb7PxXmnXclfMuvj7bRao0qstSE6izm5RL586dmT17drFpDRs2pFu3bhx99NEMGjSI/Pz8tPMdMmQIN998c+z/hQsXVrisFfXyyy9TUFBAkyZNGDRoUMbyXbJkCatWrWLhwoVp9xlZtGhRbIijmiSVyyXOuSooSe6orLp84+0PcfvQx2L/L1yU/e6YqstVR3V542P6QqB3795u4sSJGcnr22+/JdmYYH85Z05GPiNT3n9gs3Ivm+ggErX33nszduxYatVK7yR0p06dmDNnDjvttBOPP/44zZs3p3379uUuZyYMGDCAJ598kk6dOjFr1qyM5r1kyRIaN25M7dq10172t99+o1mzZjWqz2pZ69KkSRN+//33UtOUVgcjnzPJOde7tDRTpkyZ1atXr8UJZ95lO5X6AVVtcPnb8fLU5VRuKum2fT/mzpvPjr168NC919GsWWPat21dLE1V31Siulx1MlGXc1Wm2rB06ZKxVMhuu+3G3LlzmTNnDp999hn77bcfAOPHj2f8+PFp5zdnjg+aDznkEHr27FnhYNA5l7G7Tivjs5o1a1auAwhA8+bNa9QBBGDu3LklXnPmzKFLly4AnHbaaVkuYc2V6bo8d958AA7afy+226ZbiWAwXarLGxfV5Y2PAkKpkLp169KhQwc6duzIrrvuyoUXXhibF70Esm7dOm699Va23npr6tWrR8eOHRk8eDArVvhh3oYMGVKsQbzhhhswM4YPHx6b9sILL7DHHnuw6aab0rhxYw455BC++OKLYuUxM8yMyy67jD333JM6derw9NNPx+Y/8sgjbL/99uTn59O6dWtOP/30UgcyNjOefPJJAGbPno2ZMWTIkDI/a+HChZx99tmxJ9Z0796dm266idWrV8fyHjBgAGZG586dS5T/gQce4LzzzqNly5Y0bdqUo446il9//TWWrm/fvpgZffv2BWDWrFmxZV988UVOPPFEmjRpQqtWrRg4cCDLly8vtl6PPPII3bp1o27dumy33XY8//zzseXHjh2bdHuk8j2kW5aoDh06lHhNnTqVmTNnUqtWLc4999xSyybll05dvuOe/9BrtyNo0n5nuvY8kP+7+k5WrFgJwI23PUj9Fr1i6W+56xHqt+jFf//3SmzayFfeoe/BJ6suo7os1Yf6EErGzJ8/P9aI5uXlsdtuu8XmHX300bz66qux/+fNm8fdd99NQUEB7777bpl533rrrVxxxRXFpr311lu89957vPHGGxxwwAHF5t1xxx0l8rjgggu47777Yv+vWrWKxx57jE8++YQJEyaUq59Uos/6888/2WOPPfjpp59i07777juuuuoqpk6dynPPPVdmnpdddlksWAZ46aWXqF27Ni+88EKZyw4YMKDYso8//jjNmjWLlfPBBx/knHPOic3/+uuv+dvf/lZmvpD+91BWWVJx5513Av6s8eabb57yclJ+6dTln39ZyL0P/pevvv6eN0Y+XGbed9zzH6654d5i01SXE1NdlqqkM4RSIePGjYv9gmzXrh0jRoygWbNmPPXUU2y2me+j+Pzzz8cOIFdddRXff/89jz/+OLVq1eL999/n5Zdf5uKLL2bu3LmxfC+66CLmzp3Lcccdx6xZs7jmmmsA2G+//Zg8eTKjR4+mQ4cOrF27ltNPP71ER+727dvz5ptvMmPGDPr378/nn38eO4AMHDiQb7/9lpdffpkGDRowbdo0HnrooYTrN3fuXI499ljA/+KdO3cuF198camf9fTTT8cOIE899RTff/89xxxzTGxb/Pzzz2Vu18aNGzN69GimTp3KnnvuCfgO8Rs2bChz2S5duvDRRx8xYcIEunXrBsCoUaMAWLNmDVdffXVsfd555x0mTpzIQQcdVGa+5fkeSitLKr788ks++OADwAcBUnnSrcuXDz6drz57hYfvvY5atWoxdvwXvPrm+1xwzkn8+NU7sXzPP+tEfvzqHY4+4kBmz/mZG259AIB9++yqulwG1WWpSgoIJeNWrVrF9OnTY/+Hv6I7derEmWeeSX5+PgcccADbbrst4H+VNmrUiA4dOsSWCf/Pz89n1KhRrF27FoDHHnuMHXbYgQMPPJAbb7wR8Jd/JkyYUKwMp512GgcffDCbb745TZo0iZWhfv36/Otf/6Jhw4bstNNO7LPPPrEyJBKWAaB27dp06NCBRo0alfpZRx11FF9++SVTpkzhpJNOolu3bsWGz5k5c2aZ2/D000/nwAMPZNttt+Wkk04C/KW6VO5EHDx4MHvuuSe9e/fmqKOOAvwZWYAvvviC3377DYDrr7+eAw44gJ122on/+7//KzPf8nwPpZUlFeHZh6233pr9998/5eUkM5LV5c06tmPgKcdSP78+f+m7O9t07wrAO+99TKNNG9KhXVF/wfD//Pz6vPz6GNau9X3zHhx2repyGVSXpSrpkrFUyG677Ra79LFs2TJuuukmnnnmGa6++mp69+5Nv379YgeU2bNn07FjxxJ5RM8MJjJjxgwAmjZtWqyPTu/eRTdY/fjjj8Uua8Xf3RyWYdWqVWyxxRZpl6E08Z/Vtm1bZs6cyZ133smkSZOYP39+rPEF0u6sXrdu3djf0X5L6Swbjo0WXc+ddkrvRtlUv4c2bdqkVJayzJkzJ7ZvnXfeeTWu0311k05dnjP3F7bseWCJPOb9sqDUz5g5ywcQTZs0otNmRTeMqS6nvqzqslQWBYRSIWFH9NDQoUN55plnABg9ejT9+vUrs+ErLCwsdX54aSX+GdHRxris4W0qWoZ0vPvuu/Tr1y+lS0LZlO4dkZn4HtIxbNgw1q1bR6NGjTj55JMzlq8klpm6XHqAULQPFd/3VJcrRnVZMkGXjCWjouNahr+kw2EGtthiC9avX49zLvZav359mXfChZ2PFy9eXOwSRUFBQYk0yYRlaNiwIcuXLy9RhkyOSfbII4+wYcMGGjduzEsvvcRPP/3EiBEjMpZ/RXTq1Cn29+TJk9NaNhPfQ6r+/PNPHnvMD2o8YMAANt1004zkK6krrS5v3qUjK379klWLp8ReK379knde/U+peXbu5APOxb/9wbxfii6Zqi6nT3VZMk0BoVTI6tWrmTdvHvPmzWPKlCmcccYZsXnh5YcTTjgB8JcpTjrpJAoKCpg0aRJXXnklu+++O0uXLi31M4488khq1aqFc47TTjuNgoICxowZw7XXXgv4hnHnnXcuNY+wDMuXL+eoo47i888/Z+rUqdx5551su+22pXYOD/sdLVy4kHHjxpXZbyg8kG666aa0adOGP/74g9dff73UZapK7969adGiBeBv8BkzZgyTJk3i9ttvL3PZTHwPqXr44YdZtmwZZqbhKapIOnX5p5lzOe3sK5ky9TsmF0zj2pvuY59+J7F0WfJhSACOOPQvsX3orAuuUV2uANVlyTRdMpYK+eyzzxL2C+zVq1ds+INTTjmFl156iddee41nn32WZ599NpauVq1afPHFF6V2Mu7atSvXXHMNQ4YM4d1332WHHXaIzatTpw6PPvpoiUsf8fbdd1/OOeccHnjgAd555x3eeeedYvPfeecdTj311ITLhv1zCgsL6du3L6ecckqx8RHjHX/88YwcOZJ58+ax++67l5hf2thdla1OnTrcfPPNnHHGGcyZMyetzt2Z+B5SsXbtWu691w9LctBBB8XuaJTKlW5dfn7kmzw/8s1Yulq1ajFx8tf8ZZ/dSuQR2mLzzfjXJWdy4+0PMmbsZ6rLFaC6LJmW9TOEZlbHzIaY2U9mtsrMvjeza8ysXiTNkWZWYGaFZjbfzIaZWf24fPqY2SdBHr+Z2XAza171a5S76tSpw5Zbbsmll17KuHHjYh2Pa9WqxahRo2K/4OvUqUOTJk3o168fH374YUoN2bXXXstTTz3FTjvtRN26ddl000056KCDGDduXInxspK5//77efzxx+nduzf169enYcOG9OnTh1dffTXpAQT8QfDss8+mRYsWNGnSJDYERzLHHnssjz/+ON27dyc/P58dd9yRkSNHkpeXB/ixwrLp9NNP59FHH6Vr167k5eWx/fbbx84MQOl9hzLxPZTlf//7X+wsz/nnn5+RPCU9ZdXlW667mG26d6VOnTyaNN6UA/fbk3dfe7zUYDB05WVn8Z8HbmTHXj1UlytIdVkyKevPMjazV4DDg39X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zrH/z7pwCPVb9OLDjyZQv0Uv5sz9xef13Kux6aGXXnuPffqdRItOu9Gu696cOPBSZs6cGZsf9hHr2LEjN954Iy1btmSrrbYqUc6wX9rs2bNjZQz7qEX7rA0bNoyuXbtSp06dWNovv/yS/v3707x5cxo1asTOO+/MiBEjiuXfuXNnzIwBAwYU+zwz44MPPuCwww6jYcOGdOjQgcsuuywWHEPJPnTDhw/HzKhduzaTJk1in332IT8/ny5dupToZ1hYWMjgwYNp06YN9evX54ADDuCuu+5Kqd/c2rVrueWWW+jevTv16tWjbdu2DBw4kF9++SWWJp2yJPL++++z//7707hxY5o2bUqfPn2K/YCoqBdeeCHWB7NRo0b069ePiRMnprTcnnvuScOGDWnVqhUHH3wwkydPLpZmxowZnHTSSXTs2JH8/Hx69OjBkCFDWL58eSzN0qVLueqqq+jWrVtsu5x66qmxfSe0aNEizj77bDp06EC9evXYZpttePDBB4ulSTWvasc5l/OvnXbayYlI7gAmujLahYKCglnOuYmJXq9uvrmrTq9M2G677RzgTj31VHfFFVc4wLVu3dqtXbs2luaUU05xQInX6JcfSzp91eIp7tbrByec36ZNGzd//nznnHPXXnttifmdOnUqUc4PPvggYV4ffPBB0nkzZ850X3zxhatXr17C+Q8++GAs/06dOjnAnXLKKSU+r0GDBiWW/fe//x3drxzgrr32Wuecc0888USpy77++uuxZY877rgS880s9ncyGzZscAcffHDC9Wrfvr2bN29e2mWJ98orr7hatWolLN8bb7yRdP2j2+6DDz5Imv8999yTsPz169d3X375pXOu+P4Ruu+++xIuV7du3dhy8+bNc82aNUuYbo899nDr1q1zGzZscLvttlvCNC1atHBz5sxxzjm3ePFi16VLl4TphgwZEvs+UsmrNNOmTSszTSptWLovnSEUEclxX375JVOnTgXguOOO47jjjgP8DRajR4+OpRs6dCiffvpp7P/bbriEH796h1137sWPX71D+3atATjqiANj0+f+vIBrbrwXgIMP2JuJ41/krVGP0LZNSxYsWMDNN99cojznnHMO06ZN4/33S96csvvuuzN37lw6dOgAwLHHHsvcuXPZfffdi6Xr06cPn3/+OdOnT6d9+/bcfvvtFBYW0qpVK8aPH8/kyZPZeuutAbjrrrtS2k677LILEyZMYNy4cbRo0QKAUaNGpbTsX//6V6ZMmcJrr71G3bp1iy07adKk2JnKfffdl8mTJ/Puu+8WOxubzLPPPstbb70FwMUXX8w333zDww8/TJ06dfj555+5/PLL0ypLIjfccAMbNmxg6623ZtKkSYwfP55WrVrhnGPo0KEprX8yv/32W6yM++67LwUFBbz99ts0b96cVatWJdw/Qtdddx0Ae++9N19//TVvvPEG9erVY/Xq1dx///0AjBgxInaTz+OPP84PP/zAP//5TwA++eQTxo0bR0FBAZ999hkAZ599Nj/++CMPPfQQAIsXL+bRRx8F4KqrrmLmzJnUq1eP5557ju+++47zzz8fgJtuuomFCxemnFd1pJtKRERy3H//+18AmjZtyn777UdeXh7dunXjhx9+4KmnnuLQQw+NzW/Tpk1suaZNGtEhCAI7tGtN7dq1AcivXy82/ZXXx7BmjR+k/1+XnkXjxo1o3LgRhx60D489+WIsmIm67777qFUr8fmKunXr0qFDh6LPys+PBYdR1157Lbvsskvs/5tvvpkrr7ySRo0axS6JH3300dx0003FLl2X5pprrqF3794A7L///jz33HPMmzcvpWVvvfVWOnfuTM+ePdlhhx347LPPYstGt8Fjjz0WK9/JJ58cC3qSef755wHo0qULd955J2ZGjx49+PTTTxk+fDijRo1i+PDhKZclkeHDh7N27VpatGgR29YHHHAAzzzzTMrbLpnRo0fHHvc6dOhQevXqRa9evbjyyit5/vnnY99zPOcc7777LgDt2rWjVatWbLPNNuy00058/PHHsXKFgTtAt27d2HLLLbnjjjs4/vjjAejRo0exvqodO3Zkiy22oGvXrnTt2hXnHO3btweKtnX//v3Zc889ATjvvPO47777WLt2Le+99x577713SnlVRzpDKCKSw9avX8+zzz4L+ANd+Czo8Czhq6++yh9//FHu/GfMnBP7e+8D/8GWPQ9ky54H8tiTLwIwd+7cEsskCwbTEZ9H165d+eabbxgwYABt2rShVq1a3HTTTYDfBukKz6ytXr26wsuG2yDafzNVM4I7zLfffvtifQ3DwHXlypXF+hKWVZZEunXrxieffMJRRx1Fy5YtMTOeeeYZgGJ9KMsj2q8u2mf0oosu4rPPPuN///tfwuXMjK5du/L2229z4IEH0rRpU8yMjz/+uFi5TjjhhNgPmr322ovu3btz6aWXsmbNGvbff3/atGnDZpttxg033ECtWrX417/+Rbt27Tj22GOZNWtWbJnffvuN33//HYDnnnuOjh070rFjx2Jlnjt3bkp5VVcKCEVEctjo0aNZuHAhAE888UTsJoYbb7wR8Dc7xN94kY41q0t/hGd5AqryuPbaaznxxBMZP348CxcurJbPmk92Nqw0GzZsAGCTTYpf8IsGahUNsAcOHMi5557LhAkTWLx4cYXyileRgaYPOeQQrrjiCqZMmZL0R0teXh6vv/46b7/9NmeeeSZr1qzhscce49BDD+XII4+M7QdXXXUVBQUFXHHFFbRv355Ro0bxz3/+k169erFw4cKU9tPCwsKU8qquFBCKiOSw6NiDycTfbZyOzp2KLpF9N/lNVi2eEnutX7++ygKz8E7Q7bffno8++ojZs2dz0UUXVclnl6VTp06A72M2Z86cMlIXF55RLCgoKLYtCwoKAGjQoAGtW7cud9mWLl0aOxt4wAEH8MUXXzBnzhyOPfbYcucZ1aVLl9jfP/74Y+zvN954g8svvzxpH8VvvvmG8ePHA/CPf/yDgoIC5s6dy2677VYs3ZtvvslDDz3EihUreOihh5gxY0bsEvrLL7/M2LFjKSgo4KGHHuLjjz/m+uuvZ+LEiXzzzTfUr1+fH374gQceeIBWrVrRoEEDwN9tH39DxoYNGxgyZEhKeVVXCghFRHLU0qVLefXVVwF/o8GECROKvU4//XTAd76fPn16mfnl168HwNRvvmdywTQWLV7CkYftHzvz9fdTL+HDjybw7fczePypkXTr1o2vv/66XGXPz88HYMqUKUyaNKnMJ4uEwVKbNm1o1KgRs2bNigUU2XbwwQfH/j7ttNMoKChgzJgxKQXrxxxzDOCDqcsuu4xp06bxxBNPxC619u/fv8TZw3SYWWzbtW/fnoYNG/LNN9+UGNqlvA444ADq168PwODBg/nqq68YN24cZ599NrfddlvsEnC8aPDbsWNH6taty2effRa7hB4aPXo0Z599Nv/4xz8YOXIkP/30U7Gg+/fff2fmzJmcffbZnH322dx4441Mnz6d6dOnx86y/v7772yyySYcffTRgP8Rddttt/Hdd98xbtw4jjrqKM466yyAlPKqrhQQiojkqBEjRsQ69J900kn07t272OvUU0+NpU0lONmhl+8fNWXq9+y5/994+93xdN2iE9dd6e/EnDxlGgf1/yc77nkU5158PTNmzOCFF14oV9l32sk/LKagoIDevXvzxhtvlJo+vIng7bffpmfPnuyzzz7FxrmLjklX1XbYYQf+/ve/AzBmzBh22GEH9t9//5Ru2Dj55JPZb7/9ALjzzjvZZpttOO2001i9ejXt2rXj9ttvr1DZNt1001jAOnz4cHr06MHBBx8cC7wqut2aNWvGbbfdBsC7775Lr1696Nu3L3PnziU/P5+rr7464XLdu3enZ8+egL9Jpnv37hx77LGxHwZhuS655BJat25NYWEhxxxzDFtssQXXXHMN4M9OHnjggRx++OH06dMH8Hcub7nllhx22GGsXbuWunXrxsakvP322+nSpQsbNmzg8ssvp3v37vTt25eXXnqJl156iYULF6acV3WkgFBEJEeFdxfXrVuXQw45pMT83XbbjbZt28bSlnV594ZrLuTA/fakYYN82rRuSfNmTQAYfMGpvPDfe9hr951o0KA++fn12GmHbXjiiSfKvIs2mVtvvZV+/frRsGFD2rZtW+xu0kTuuusuLrvsMjp06BAb+DgcmgQo95nKTHn88ccZPHgwrVq1ol69ehxyyCGx4KG0fna1a9fm9ddf55prrmGLLbYgLy+PVq1aMWDAAL744gvatWtX4bI9/fTTnH766bRu3ZrmzZtz3HHHcf311wOwZMkS5s+fX6H8zz//fEaMGMEuu+xCvXr1aNy4MYcddhiffvopvXr1SrhM7dq1eeONNzjuuONo1qwZrVu35owzzuC8884D/BnTNWvW0LFjRyZMmMDJJ59M69atqVevHltssUXsppWGDRtSu3Zt3n77ba666iq22GIL6tSpQ/v27TnuuOP4/PPP2XHHHQFo3bo1X3zxBRdccAGbbbYZeXl5tG3bllNPPZVJkybRunXrlPOqjqw6dqytar1793apjIguIjWDmU1yzvUuLc2UKVNm9erVK7M96CvBtGnTdurRo0eVfmbhb19lJJ96zXtmJJ+aYM2aNSxdurRYYHv00UczatQoWrduzYIFC7JYOqlK3377bZl3I6fShqVLZwhFRESy7NZbb6Vv376MHj2aH374gaFDh/Lyyy8DfsxDkcqmgalFRESy7MUXX+Sbb76hX79+xaa3bNkyNgSQ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1H6JSKZV94BwbeTv6NnM2sF7YfC+LoU0xTjnHnHO9XbO9W7ZsmWFCyoiUlXUfolIplX3gHAxsD74u11ketgvMOwnuCCFNCIiIiKSQLUOCJ1zq4Evgn/PMLNaZrYHsE0wbXzc+0Azq2NmWwL7BtM+rJrSioiIiGycqnVAGLgZP4TNQGA58DF+XMJnnXM/BWnuwF9ePhD4E/geaAB8hB+zUERERESSqPYBoXPudfwTSabi+wUuBO7BB4hhmi/xYyF+jg8WfweeBI4Ixi4UERERkSSy/ui6KOdciYEIg+kjgBFlLPs+RYNYi4iIiEiKqv0ZQhERERGpXAoIRURERHKcAkIRERGRHKeAUERERCTHKSAUERERyXEKCEVERERynAJCERERkRyngFBEREQkxykgFBEREclxCghFREREcpwCQhEREZEcp4BQREREJMcpIBQRERHJcQoIRURERHKcAkIRERGRHKeAUERERCTHKSAUERERyXEKCEVERERynAJCERERkRyngFBEREQkxykgFBEREclxCghFREREcpwCQhEREZEcp4BQREREJMcpIBQRERHJcQoIRURERHKcAkIRERGRHKeAUERERCTHKSAUERERyXEKCEVERERynAJCERERkRyngFBEREQkxykgFBEREclxCghFREREcpwCQhEREZEcp4BQREREJMcpIBQRERHJcQoIRURERHKcAkIRERGRHKeAUERERCTHKSAUERERyXEKCEVERERynAJCERERkRyngFBEREQkxykgFBEREclxCghFREREcpwCQhEREZEct1EEhGZ2uJm5JK82QZojzazAzArNbL6ZDTOz+tkuu4iIiEh1t0m2C5CiDsH7KmBp3Lz1ZnYQMBKwIE0b4MLg/YSqKqSIiIjIxmijOEMItA/e73fOtYl7LQKuxAeD9wMNgL5B+uPNbMuqL66IiIjIxmNjCQjDM4Tz4meYWR1gt+Dfx5w3DpgWTNu7CsonIiIistHa2ALCv5vZYjNbZmajzKw90ALIC+b/GllmfvDepqoKKSIiIrIx2lgCwvCS8S5AHaAhcCTwYvB/aEPk73XBe3S+iIiIiMTZWALCY4GLgC2dc42AQwGHv1TcobQFkzGzM8xsoplNXLRoUeZKKiJSydR+iUimbRQBoXNuqnNumHNuevD/m8BXwez9Ikmjd03XDt4Lk+T5iHOu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\n",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(ncols=2, sharey=True, figsize=(10, 5))\n",
    "\n",
    "bar_width = 0.3\n",
    "x = np.arange(len(branched_after_fids))\n",
    "\n",
    "branched_before_vals = [branched_before_fids[c] for c in classes_049] + [0]\n",
    "branched_after_vals = [branched_after_fids[c] for c in classes_0497]\n",
    "ax[0].bar(\n",
    "    x, branched_before_vals, bar_width, label=\"Before training on 7\", color=\"royalblue\"\n",
    ")\n",
    "ax[0].bar(\n",
    "    x + bar_width, branched_after_vals, bar_width, label=\"After training on 7\", color=\"slateblue\"\n",
    ")\n",
    "ax[0].set_title(\"Branched model\")\n",
    "\n",
    "label_guided_before_vals = [label_guided_before_fids[c] for c in classes_049] + [0]\n",
    "label_guided_afterone_vals = [label_guided_afterone_fids[c] for c in classes_0497]\n",
    "label_guided_afterall_vals = [label_guided_afterall_fids[c] for c in classes_0497]\n",
    "ax[1].bar(\n",
    "    x, label_guided_before_vals, bar_width, label=\"Before training on 7\", color=\"darkorange\"\n",
    ")\n",
    "ax[1].bar(\n",
    "    x + bar_width, label_guided_afterone_vals, bar_width, label=\"After training on 7\", color=\"goldenrod\"\n",
    ")\n",
    "ax[1].bar(\n",
    "    x + (2 * bar_width), label_guided_afterall_vals, bar_width, label=\"After training on all classes\", color=\"firebrick\"\n",
    ")\n",
    "ax[1].set_title(\"Label-guided (linear) model\")\n",
    "for i in range(2):\n",
    "    ax[i].set_xticks(x + bar_width, labels=[c for c in classes_0497])\n",
    "    ax[i].set_xlabel(\"Digit class\")\n",
    "    ax[i].legend()\n",
    "ax[0].set_ylabel(\"FID\")\n",
    "fig.suptitle(\"Fréchet inception distance between true and generated letters\")\n",
    "fig.savefig(\n",
    "    os.path.join(out_path, \"digit_fid.svg\"),\n",
    "    format=\"svg\"\n",
    ")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
