{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a189e14e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from infrastructure.classes import Experiment, TrainParameters\n",
    "from pushforward_operators import FastNonLinearQuantileRegression\n",
    "import torch\n",
    "\n",
    "experiment = Experiment(\n",
    "    tensor_parameters=dict(dtype=torch.float64, device=torch.device(\"cpu\")),\n",
    "    dataset_name=\"fnlvqr_banana\",\n",
    "    dataset_number_of_points=20000,\n",
    "    dataloader_parameters=dict(batch_size=512, shuffle=True),\n",
    "    pushforward_operator_name=\"fast_non_linear_vector_quantile_regression\",\n",
    "    pushforward_operator_parameters=dict(\n",
    "        fnlvqr_mlp_arguments=dict(\n",
    "            verbose=True,\n",
    "            num_epochs=1,\n",
    "            epsilon=5e-3,\n",
    "            lr=0.4,\n",
    "            gpu=True,\n",
    "            skip=False,\n",
    "            batchnorm=False,\n",
    "            hidden_layers=(2, 10, 20),\n",
    "            batchsize_y=None,\n",
    "            batchsize_u=None,\n",
    "            inference_batch_size=100,\n",
    "            lr_factor=0.9,\n",
    "            lr_patience=300,\n",
    "            lr_threshold=0.5 * 0.01,\n",
    "        ),\n",
    "        feature_dimension=1,\n",
    "        response_dimension=2,\n",
    "        hidden_dimension=32,\n",
    "        number_of_hidden_layers=4,\n",
    "    ),\n",
    "    train_parameters=TrainParameters(\n",
    "        number_of_epochs_to_train=0,\n",
    "        verbose=True,\n",
    "        optimizer_parameters=dict(lr=0.1),\n",
    "        scheduler_parameters=dict(eta_min=0)\n",
    "    )\n",
    ")\n",
    "model = FastNonLinearQuantileRegression.load_class(\"../../experiments_full_13_09_2025_fnlvqr/fnlvqr_banana/fast_non_linear_vector_quantile_regression/weights.pth\")\n",
    "model.to(**experiment.tensor_parameters)\n",
    "_ = model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "76c15020",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGdCAYAAADaPpOnAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAagRJREFUeJztnQecE3X+/p9shV1Y2gK79C4gTVCqhaYgCLY7FSycvYCnonfCnZwg/kXv9KeeoKincJ4idkDl8EQUpCtFQBQBl86CtAV2YWv+r88ssyTZlJlkJpmZPO/Xa1gymUwmk8n3+8ynutxutxuEEEIIITYhIdYHQAghhBCiB4oXQgghhNgKihdCCCGE2AqKF0IIIYTYCooXQgghhNgKihdCCCGE2AqKF0IIIYTYCooXQgghhNiKJDiMsrIy7Nu3D9WrV4fL5Yr14RBCCCFEA1Iz98SJE2jQoAESEhLiS7yIcGncuHGsD4MQQgghYbB79240atQovsSLWFzUD5+RkRHrwyGEEEKIBo4fP64YH9R5PK7Ei+oqEuFC8UIIIYTYCy0hHwzYJYQQQoitoHghhBBCiK2geCGEEEKIraB4IYQQQoitoHghhBBCiK2geCGEEEKIraB4IYQQQoitoHghhBBCSHyIlyVLlmDYsGFKDwIpKDNnzpyK54qLi/Hoo4+iY8eOSE9PV7a55ZZblNL9wZg4caKyL8+lbdu24R4iIYQQEjVKy9xYsf0w5q7fq/yVx8Qcwq6wm5+fj86dO+O2227DNddc4/VcQUEB1q5diwkTJijbHD16FA888ACGDx+O77//Puh+zz33XCxcuPDsASY5rggwIYQQh7Fg035M+nQz9uedrliXXaMKHh/WHoM7ZMf02JxI2Mrg8ssvVxZ/1KhRA19++aXXuqlTp6J79+7YtWsXmjRpEviAkpKQlZUV7mERQgghURcu9769Fr52FhEy97y9FtNv6koBY9eYl7y8PMUNVLNmzaDbbd26VXEztWjRAjfeeKMidgghhBArIq4hsbgEcxCN+3gjXUh2FC+nT59WYmBGjBgRtFlijx49MHPmTCxYsACvvPIKcnJycNFFF+HEiRMBX1NYWKh0ovRcCCGEkGjEs6zOOeLlKvLHsYJiTF20LUpHGh+YHlAiwbvXXXcd3G63IkiC4emG6tSpkyJmmjZtivfffx+3336739dMmTIFkyZNMvy4CSGEkFDxLIUlZZr2MWN5Dsb0b4XEhNAdk0mMLS+qcNm5c6cSAxPM6uIPcTG1adMG27YFVqzjx49XXFLqsnv3bgOOnBBCCDkbz+JrXVHjWXYcKtC0H7G+iJWGWFy8qMJFYlgke6hOnTq693Hy5Els374d2dmBA51SU1MVUeS5EEIIIdGIZ3ltyXZUTdY2lR48Edy9RKIgXkRYrF+/XlkEiU+R/0uArQiX3/3ud0pa9DvvvIPS0lLk5uYqS1FRUcU+BgwYoGQhqTzyyCNYvHgxduzYgeXLl+Pqq69GYmKiEitDCCGERBMt8Sz5RaU4VazNdVSvehWDjoyEHfMiwqRfv34Vj8eOHav8HTVqlFJsbt68ecrjLl26eL3u66+/Rt++fZX/i1Xl0KFDFc/t2bNHESqHDx9G3bp1ceGFF2LlypXK/wkhhJBoYpSlRKJcsmpUQffmtQ3ZH4lAvIgAkSDcQAR7TkUsLJ7Mnj073MMhhBBCDHUZffvLb4btT4J7GaxrHCxfSwghhPgE6U6ctxm5x42xvDw4sA2L1BkMxQshhBASolpuJDTLTDNwb0SgeCGEEBLX7iEJzJX4lsz0VMXiYnQtXAbqGg/FCyGEkLgULVL1dsayHBw7VWza+0iUS7emtUzbf7xC8UIIISTORMtWvLrkVxQUlZr+fmLFWbPzKHq11F/rjASG4oUQQkjcxLNIk0SpdhtNWJzOeCheCCGEOB4zAnG1wpgXm3aVJoQQQqxc5t8ssjJSWZzOBCheCCGEIN7L/JvFiO5NWJzOBCheCCGEOJovN+fG7L2bZabH7L2dDMULIYQQR7uM5qzfF7P3Z7yLOTBglxBCiKNdRkfyi6L+vmzGaC60vBBCCHEsC01wGWmdONmM0TwoXgghhDg2PfqNZTsM3WeNqkmYOvI8PDSwTdDt7rq4OZsxmgjFCyGEEMfFuSzbdgjjPtpo+L6PnyrBfbPWYcbynIDbiK1l3g/7leMg5sCYF0IIIbZroiiBsGo8iee6o/lFmPz5ZtNSo1U5EqxKr2wj7y/HxbYA5kDxQgghxBYuICk05ylKaqYlK3+jXe5fK2wLYB4UL4QQQmxZ2t+qokWFadLmQfFCCCHEssSytH+4ME3afBiwSwghJG5L+9eokqSIDT24zris5K/va9XHTJM2F4oXQgghlsXsuJG80yW6rTqy/VNXdcArN3VVLCyeyGNZzzRpc6HbiBBCSNzFjUi359MlZWHHzUz+/CfFurL00f6VMqBocTEfihdCCCGWRcRAzarJOHYq/OBcVUo8OLANmmWmKSKjzO3Gjf9aFfY+c/NOK0HEtLLEBrqNCCGExCQQd8X2w5i7fq/yN1BBN7Fi3NqnWUTvVSs9Gbf1aaYIoSs6NVBqrxw6WRjRPtWjlWBiFqOLPrS8EEIIiXnNluwaVTBhaDvUSk+t5IJpXa+a5n177ufLzblKR2lpzChtAmSR58XdY4Q7isXoYgfFCyGEkJjXbBERIGX3KwuR9kp8SShu7d0Ul52bXSF45H1mLNtR6X1Ud8+0kecp+5fH7iDuJi02FRajiz50GxFCCLFkzRYRFvfNWqspVVqEi1g/RLgEex91nQgiEUZCoPDa+/u30nScLEYXfSheCCGEWLJmi55IEk/rR6j3Ud09tdJT/KY7i0Xm7oub4/3v9wR9T9eZbVmMLvrQbUQIISQqmOle8bR+aH0f2e7KLg1xafssn+aOhRg9a11Q8cRidLGF4oUQQkhUMMO94q8Uv9b3UbcT8aEG3IrL6cJnFoW0+tTPSMXE4ecyTTpG0G1ECCEkKojAEDdLuHYKraX4Q72PrK+TnoLcvFOV0rS1uraeu64LhUsMoXghhBASFURgiNAQ9AgYERovjzxPcyn+UO8jUuVwfhEeev8HjHh9pWJpkewkPS6nSOvEkMig24gQQkjUEKEhgsO3zkswruzSAEM6NcCgDtmaS/HreR/Parl6XU7EZpaXJUuWYNiwYWjQoAFcLhfmzJnj9bzb7cbf/vY3ZGdno2rVqhg4cCC2bt0acr/Tpk1Ds2bNUKVKFfTo0QOrV68O9xAJIYRYEBEW0hNIislpQQJqPWNTJMhWTYsO9T7yHrXTkzVXy+3WtFZIlxMzjGwsXvLz89G5c2dFbPjj73//O/75z39i+vTpWLVqFdLT0zFo0CCcPh1YAb/33nsYO3YsHn/8caxdu1bZv7zm4MGD4R4mIYQQC5b+F+Hxhz7NQ8bARCIUxBUkWUNH8kP3RVLTp9fsPBrQ5cQMI+vgcouJJNKduFz45JNPcNVVVymPZZdikXn44YfxyCOPKOvy8vJQv359zJw5EzfccIPf/Yil5YILLsDUqVOVx2VlZWjcuDHuv/9+jBs3TtOxHD9+HDVq1FDeLyMjI9KPRgghxIDS/zLh+wtwVSvuCp6TkSoNwm18qGYN6akrI7x4QxfFsqP3c5DI0TN/mxLzkpOTg9zcXMVVpCIHJOJkxYoVfsVLUVER1qxZg/Hjx1esS0hIUPYhrwlEYWGhsnh+eEIIIdYp/R+sA3Og2JSsCIWC3oJ4vrEs8r6+9V+CxdiQ6GKKeBHhIoilxRN5rD7ny6FDh1BaWur3NT///HPA95oyZQomTZpkyHETQoiTEWuEWZNxqJL88i7yvAgC3/c0QyjoLYjnr16MZ/0XYi1sn20klhqJk/G0vIiriRBCyFnMdoNoLckfqAOz0UJBTzYQY1nshyl1XrKyyiPDDxw44LVeHqvP+ZKZmYnExERdrxFSU1MV35jnQgghpLI7x1dcqO4ctcZJJOgpyR+NIOFQWUNa6sWQOLO8NG/eXBEcX331Fbp06VJhEZGso3vvvdfva1JSUtCtWzflNWrgrwTsyuMxY8aYcZiEEOJ49LhzhHBdN7GsjxLIqjS8czZeW5KjfEbfYGB5fFufZsrnZixLHImXkydPYtu2bV5BuuvXr0ft2rXRpEkTPPjgg3jyySfRunVrRcxMmDBByUBShYkwYMAAXH311RXiRNw/o0aNwvnnn4/u3bvjhRdeUFKyb7311kg/JyGExCVa3TlTF23D7O92he1WUkvyizXHrTGmxOwgYREud13cHPN+2G9oMDCxsXj5/vvv0a9fv4rHatyJiA9Jh/7zn/+sCI+77roLx44dw4UXXogFCxYoxedUtm/frgTqqlx//fX47bfflOJ2EtgrVht5jW8QLyGEEBjqpnl+4S+V1gXLEvJFLckv2/uzdJgRU6LFqiTCZfGf+in1W5g15BwMqfNiJVjnhRAS73hmFX37y2/4cO3esPelWkykIq6WCT+a9VEktkV6E4Xi3Tt7MmvIBsS8zgshhJDY4E88REKoLCFfolkfJdZBwiR2ULwQQohDCBT/YQR6BEC06qOwiWL8YkqqNCGEkOgSLP7DCKwoANQgYTZRjD8oXgghxAGEWw5fkK7LdhUAN1zQJGB2k8DCc86E4oUQQhxAOHEdqjB58soOFY99n7eqABAXmTRe9JclJbDwnLNhzAshhDgAvW4dT2GiNEdMcBneHDFWsT0PDWyNMf1bW05wEeOgeCGEEAegxn9odR35CpNYdlHW0zAyVGyPvGr2d7sV8UKcC8ULIYQ4ALVI3D1vr9W0/bO/64w+rTMr7SPa9VD01oWJtAEkcQaMeSGEEIcgk/3tfZpp2vZQfiHs2DCStV2IQPFCCCEOYuCZBotWT30OVdpfkOdlO09Y24UIFC+EEOIg7FL7RI/7x46fj5gLxQshhDgw9sXqqc/hun/s8vmIuVC8EEKIw1BSn2/qqmQUWbX2SSTuHzt8PmIuzDYihBAHEsvUZy2o7h8Jzg1UITcriPvH6p+PmAvFCyGEOJRYpD5rRXX/SFaRyA13GO4fK38+Yi50GxFCCIkJdP+QcKHlhRBCSMyg+4eEA8ULIYSQmEL3D9EL3UaEEEIIsRUUL4QQQgixFRQvhBBCCLEVFC+EEEIIsRUM2CWEEAciDQ2ZwUOcCsULIYQ4jAWb9isdmT0bH0o1Wyn6xtopxAnQbUQIIQ4TLlK11rdjs5Thl/XyfDStPyu2H8bc9XuVv/LYSTj981kZWl4IIcQhyOQpFhd/U6isE6eRPC9F4cx2ITnd+uP0z2d1aHkhhBCHIDEuvhYXXwEjz8t28WL9MQOnfz47QPFCCCEOQYJzjdzODOuPIM/b1cXi9M9nFyheCCHEIUhWkZHb2dn6YxZO/3x2gTEvhBDikDRjOU6JuxD3hb/7fteZjs2ynZOtP2bi9M9nFyheCCHEIYGYIrDkOCXuQoSKp4BRpZc8b6YQs4L1x0yc/vnsAt1GhJC4xF+aa6BATHl8z9trMX/DPlgdEViv3NRVsbB4Io9lvdkCTLX+BJJHsj7bZOuPmTj989kFUy0vzZo1w86dOyutv++++zBt2rRK62fOnIlbb73Va11qaipOn6b5jRASOUUlZfjPih1YsvUQ1u46ihOnSyqey8qogtMlpX7dLSpj3l2HqXBhSCdrW2BEoEg6dCxcX1aw/pjtThzSIQtvLNtR6Xm7fz47Yap4+e6771BaWlrxeNOmTbj00kvx+9//PuBrMjIysGXLlorHLhcvAEJI5EyZvxmvf5uDQEkgucdD3yTJa++btRbTE8y3YESKTJ69WtaJSYyPav3xdb9l2cT9ptWdKKfI83qy8+ezG6aKl7p163o9fvrpp9GyZUtccsklAV8jYiUrK8vMwyKExKFweXVJjmH7i1ahNzvH+MTS+mM0qjvRV/e6z6y4rU8z5bPa9fPZkajFvBQVFeHtt9/GbbfdFtSacvLkSTRt2hSNGzfGlVdeiR9//DHofgsLC3H8+HGvhRBCPF1FYnExEqekwppdbE21/lzZpaHy144Tu5aqxf/dlEvh4lTxMmfOHBw7dgx/+MMfAm5zzjnn4M0338TcuXMVoVNWVobevXtjz549AV8zZcoU1KhRo2IR0UMIISoS42JGvTC7p8LaqdhaLHsIsa5LnKdKv/HGG7j88svRoEGDgNv06tVLWVREuLRr1w6vvvoqJk+e7Pc148ePx9ixYysei+WFAoYQorLzSIEp+7V7KqyeSVlr7IwTU9dZ1yWOLS+ScbRw4ULccccdul6XnJyM8847D9u2bQu4jWQjSZCv50IIISpNa6fp2j49JTFgGqyTUmHtMClboYcQ67rEsXiZMWMG6tWrh6FDh+p6nWQqbdy4EdnZjNwmhITHzb2aKVkhWrnr4paYNrKr3+fCTYWNpdvDrpOyVdxarOsSp24jiVsR8TJq1CgkJXm/3S233IKGDRsqcSvCE088gZ49e6JVq1ZKfMw//vEPxWqj12JDCCEqKUkJuPOi5pqyjWqmJWNM/1aKMJF0aCNSfWPt9rByKwE7uLWcXLfGzpguXsRdtGvXLiXLyBdZn5Bw1vhz9OhR3HnnncjNzUWtWrXQrVs3LF++HO3btzf7MAkhDmb8kPIx5LVvcyrSW/3x9DUdKyYhI1J9A6XYqm6PaFS8teukbCW3lhPr1tgdl9sd7KdsPyRgV7KO8vLyGP9CCKmUNv2Xjzdi/sb9KCguNdUSIu6MC59ZFNB6oFo2lj7aP6Z37Va1DIl7bcTrK0Nu9+6dPaMWUGzXhp1OnL/ZmJEQElcupGev64xnftfJ9EnIKm4PuxaTs6JbS0/VYmIuFC+EkLgjGpOQldwedpyUre7WIrGFXaUJISQOs3nsQKw7ZBPrQssLIYTEidvDjljVrUViC8ULIYSYAN0eznZrkdhCtxEhhJgE3R6EmAMtL4QQYiJ0exBiPBQvhJCw613kHj+NIycLUTs9BVk1qnJSDgDdHoQYC8ULISTiomZWKm5GCHE+jHkhhETc5VdlfxS7/RJC4heKF0JIxF1+PXFHqdsvISR+oXghhBhS7t4Ttey9XRChJb105q7fq/yl8CLE2jDmhRBiShl7K5S9N7IxoRlN+djoj5DwoHghhJhSxt4OZe/VGB5fO4tUxZX1ai0WMzovW7WbMyF2gG4jQoiucvdayLZB2ftgMTzqOnl+/gb/Qcq5EQQnBwp8jmSfhMQTFC+EEE2IO2N459AWAZdNyt6HiuERASPPPzZ3U0iBoydGRqtoYtwNIYGheCGEaEKsAa8tyQlpcbFL2XutMTlH8otCChw9wclaRZOdAp7jBQZ2WwfGvBASB0QaGKolTbpOegoW/6kfUpLscU9kZEyOnuBkrdvaJeA5XmCMkrWgeCHE4Rgx6GpJkz6cX4Q1O4/apgy+GsMjcSb+RJlIu1rpyTiSX2yoENK6rR0CnuMFrYHdJHrY4xaJEBIWRgWGOtFaIJYnEXCCrw1KffzklR0UgRPIRuUKIzhZFU1G7pOYB2OUrAnFCyEOxchBV6sV4NCJQlvFA8jdstw1Z/lkUcljWT+kU4OQAkdvcLIW0WSHgOd4gTFK1oRuI0Icip5BN5SrJ5SLRZC5dvLnP9kuHkCO79L2WQFjglSB4+t6y4rg85mxT2IOTrQ6OgGKF0IcipGDrmotEFeTTOn+BIyvocVO8QDy+YIJuFACJxzM2CcxHsYoWROKF0IcitGDbiBrQSBEy8g0LNvLJG33STmUwLHKPkn0A7vFYsYYpejCmBdCHIoZgaEiYCYMbad5e8YDELvDGCVrQvFCiEMxY9CVIFzPuBatMB6A2JlQgd1Wd4s6EbqNCHEwRgeGaqn34g/GA1SGHaXtBWOUrAXFCyEOx8hBV68FhfEA/mG1VnvCGCXrQPFCSBxg1KCrx4LCeAD/sForIZHDmBdCiGFBwJ4wHqAyrNZKiDHQ8kII0YyWei+392mGge2zGA9gcuFAQuIZWl4IIYZkXohFZvpNXTFh2LnKxEvhUhlWayXEBuJl4sSJcLlcXkvbtm2DvuaDDz5QtqlSpQo6duyI+fPnm3mIhJAwBczSR/vj3Tt74sUbuih/5TFdRMFhtVZ7Im486ddlp75dTsd0t9G5556LhQsXnn3DpMBvuXz5cowYMQJTpkzBFVdcgVmzZuGqq67C2rVr0aFDB7MPlRCiA2Ze6IfVWu0HM8Pi1G0kYiUrK6tiyczMDLjtiy++iMGDB+NPf/oT2rVrh8mTJ6Nr166YOnWq2YdJCCGmw2qt9swM841TUjPD5HniUPGydetWNGjQAC1atMCNN96IXbt2Bdx2xYoVGDhwoNe6QYMGKesDUVhYiOPHj3sthBBiVVit1R4wMyyO3UY9evTAzJkzcc4552D//v2YNGkSLrroImzatAnVq1evtH1ubi7q16/vtU4ey/pAiItJ9ksIIXaB1VqtDzPD4li8XH755RX/79SpkyJmmjZtivfffx+33367Ie8xfvx4jB07tuKxWF4aN25syL4JIcQsGDNkbZgZZm2iWuelZs2aaNOmDbZt2+b3eYmJOXDggNc6eSzrA5GamqoshBBCiFEwM8zaRLXOy8mTJ7F9+3ZkZ/v36fbq1QtfffWV17ovv/xSWU8I0Q5TOwkxt5q0rJfnmRnmQMvLI488gmHDhimuon379uHxxx9HYmKikg4t3HLLLWjYsKEStyI88MADuOSSS/Dcc89h6NChmD17Nr7//nu89tprZh4mIY6CqZ2EmFtNmplhDre87NmzRxEqErB73XXXoU6dOli5ciXq1q2rPC+ZRxLIq9K7d2+ltouIlc6dO+PDDz/EnDlzWOOFWBIrWjeY2kmIcTAzzLq43G537EdcA5GA3Ro1aiAvLw8ZGRmxPhziUKxo3RDxdOEziwJmSKgF0KQSLu8WCdH322JmmLXmbzZmJCRM64av6letG7G6I7N6aicnAGJXmBlmPSheCDGwcJVMxfK81PCI9sRs5dROK1qqCCH2hV2lCTHJuhFtrJraafc4HCvGNhES79DyQohDrBtWbPpnZUuVFmgxIsSa0PJCiAOsG1Zt+mdlS5XTLUaEOBmKF0IcVLjKaqmdVrZUBYNN+QixNnQbEaIzS2bC0HYYPWudZQtXWanpn5UtVXbO3CLmwaw4e0DxQkgYMQ93Xdwc837Y77U+y0KxEFZJ7bRiHI6TLUYkMhjjZB8oXggJo57La0tyMG1kV9RKT+EdmgNLrNvVYkScV7+J+IcxL4SEGfMw+fPNimC5sktDxcphtQnYKlgtDscJsU3EWBjjZD9oeSHED4x5cG4cjpMtRiQ8+Hu3HxQvhPiBMQ/OjcPRazHyjYGwUmwTMQb+3u0HxQtxPOFkDzDmgdjRYkTCg793+0HxQhxNuNkDds2SIcZjN4sR0Q9/7/aDAbvEsURSIdWK1WoJIebA37v9oHghjsSI7AE15qF+hn2yZAgh8ZMVF8/QbUQcibHZA94Cx+1muiQhToQxTvaB4oU4EiOyBwIVrTpwvJBFq4gjYCn8yjDGyR5QvBBHEmn2QCi3kwzv8rzcpcX7YE/sCUvhEzvDmBfiSCKtkKrH7URIPAWzE2IFKF6II4k0e4BFq4hTYSl84gQoXohjiSR7gEWriFOhVZE4Aca8EEcTbvYAi1YRp0KrInECFC/E8YSTPcDGfMSp0KpInADdRoQEgEWr4guJ8Vix/TDmrt+r/HVqzEekweyEWAFaXogtiFU9Chatig/iKW2YVkXiBFxuh5ULPX78OGrUqIG8vDxkZGTE+nCIAQIlniYWEv3rbeHmXLyxbEel59Wp26lWNv6uiJ3nb4oXYumBdHjnbLy2JKdS0KzTJxYS/esNQQKzlz7a35GWCFbYJVaC4oXixVYEKsMfCqdPLMQ619u7d/ZkyXgbQDEWP/M3Y15ITAeYzGqpmDjvR93CRX9zRUKCF2gLBtOGrQ/dYPEFxQuxpLleD5xYiFEF2uyWNkxLQ3BrmtrugO5l50HxQizvHrLrxEKsh16ha+VihLQ0lMMmqvGJqXVepkyZggsuuADVq1dHvXr1cNVVV2HLli1BXzNz5ky4XC6vpUoVTk7xaq4PButREDOFbizShrXWmmFjxbOw3UF8YqrlZfHixRg9erQiYEpKSvCXv/wFl112GTZv3oz09PSAr5NAHU+RIwKGxKe5PhCsR0HCjbHKykjFgeOFIYV0VpStGFotKbQ0eMN2B/GJqeJlwYIFlawqYoFZs2YNLr744oCvE7GSlZVl5qGRKGP0wBHtiYWxBfbEnyComZZcMcn7FmiTx7f1aaZM/NH8jvXEbOixNPgNZC8rBXYuB04eAKrVB5r2BhISYVdi1e6AY0IcxbxI+pNQu3ZwM//JkyfRtGlTlJWVoWvXrnjqqadw7rnn+t22sLBQWTxTrYj1MHLgGNOvFR66tE1UJxbGFtiPQIIgr6BY+VsjLRnHzvw/FoI4XEuK741AEkowKnEBLkj4BfnuVHxSdiFKkYjkn/YCCe3KxYkggmXLfGDDe0DB4bM7yGgAXDYFSK8TWNBEUfDoFQWxaKLKMSH2RK3OiwiR4cOH49ixY1i6dGnA7VasWIGtW7eiU6dOith59tlnsWTJEvz4449o1KhRpe0nTpyISZMmVVrPOi/WQgakC59ZFHSAqZWejCP5ZycTK9TcCDQBskiePa63QBYKdUJ79nedcSi/MKZ3zhLbMuL1lZqve3X7BJThhaSXcEXiKgQ97MRUoFR+V2XaDyotE+h0HXDOECD/MPC/8cDxfR7P1wGG/B/Q4SoY/XubOG8zco+f/d6yMqpg4vDgokD9nSJAuwMjf6ccE6xR5yVqjRkl9mXTpk2YPXt20O169eqFW265BV26dMEll1yCjz/+GHXr1sWrr77qd/vx48crH1Rddu/ebdInIEb0UxF8x1n18ZNXdrBUw7hQd8SCPO/UBn52RqtrJSHBhSu7NFREQaxM/npjNuT6v6HaevyYeiuGJ4UQLkJpoT7hIhQcAla+DPz7CuDDUd7CRXn+cPn6/02AUYgouOfttV7CRZDH94QIQhaxMG3kecoNkJlNVDkmWIeoiJcxY8bgs88+w9dff+3XehKM5ORknHfeedi2bZvf51NTUxWF5rkQe3ZpHtKpQUiBE80AXWYx2Bc7BXHqjdlI3DwXU0r+jioIbaU0neX/BH6cE/FuZLIf9/HGoNuM/3hj0OyryZ//5GW5rZ2egglDjXXjcEyIk5gX8Ujdf//9+OSTT/DNN9+gefPmuvdRWlqKjRs3YsiQIaYcI4kuobo0qwLH158ci3gEO02AkeK04MNYBXGGg66YDREKH91aLuat8vV8/jDQblhEMTArfz3sFX/kj6MFxcp2fVplanLjHM0vwuhZa/FKQnDLi55rP57GhLgWL+IqmjVrFubOnavUesnNzVXWi0+ratWqyv/FRdSwYUOlJozwxBNPoGfPnmjVqpUSH/OPf/wDO3fuxB133GHmoZIoIgNDsJiVUAInWthpAowEJwYfxiKIM1KXqkzA/jKgKiyOP38KfDAKlkNcTBLM2/yisHchcTxat/MUL5Gmjeu99uNlTEC8u41eeeUVJQ6lb9++yM7Orljee++9im127dqF/fvP+jKPHj2KO++8E+3atVOsLRLAs3z5crRvX+5OIPElcGIZj6BOgFaJwTEDpxY70xJjZaUaQZ4uVQnE7ZmwGcMTlmNotV/w3qWFGFz2LTDnPlgWyUKKCHdY20Xixgnn2o+HMcEumO42CoW4kzx5/vnnlYUQ29wRW2QC1Itdi51pNfNbyQUZEI8U5MHV6uPSYcdRMn8cUgvKrdQoAfAtrI+kT0dArxaZmPr1dk3bGeHGCffad/qYYCfY24iQIFh1AjQiRiXiYmcxQK+Z3youSL9sngcseNQrk0eiRmxXLi6j4dlaMmFemz1b1lGKBwaLe5HnZTsj3DiRXPtWHRPiDYoXEhXsHBBqtQnQqBgVuwUfhts5OFSMVUysLUueBb55CvbHBQx+uiJYN9xrU76jp6/pqKREB0Ke9/3NhRvbFOm1b7UxIR6heCGm44SAUKtMgOFO4P6wU/BhpC6uqItn1R10Yj+Q/xuQXheonl3+//mPeFe4tSticRHh0n64IdemPDf9pq6YOO9H5B4/WzVdelFNHH5uQGEajhvHiGvfKmNCvELxQmwz2cY7Rseo2CkjJxIzf9TFsx93kKOoWhv43Yzy7KIzFpdwr01fUSnP67FoyOurV0nG4A5Z+HbrbzhZWBrUjaO+nxS+qx2iore8paRbE2tC8UJMw64BoVbF6BgVOwUfhmvmj4p49uz7c2grsPhpOJMz18GwF4GWfSO+NiMVlfJ6KWznGyeTlpKIuy9ugTH9W3tdu/7eLxhSD09LnRgSGyheiGnoHdDsHBcTDcyIUbFL8GE4Zn5DxbMIlB1LgZxvy1/YpDfgSgC2fgFseL+81onTSM0ACo97N3D0cBNFcm1GKirVVgL+KCgqxfMLt+KcrOoVVpyFm3PxxrIdCAfeYFkTihdiGnoGtEjvwuJB+JgVo2KH4EM5HmnQ59v3JpiLK2JLlWpRkU7M6/4DFJ5A3CDxLH9cD+xepamTtJ5r04j4JWneGIpHP9pQqcmjXqyYcUfKoXghpqF1QNtxqAAvLPwlorswuwcEa8HMGBWrBx9+uTkXp0vOxjNAg4srmHiWQnDdE35GPRxD6a9FQPMz1oTt3wAb3yt3//z2M1BcgPjizPkTC0tSiuaquXquzUhFpRqzEoq8UyXKYgRWybgjZ6F4IaahZUCrn5GKd1fviqi8d7wEBNspRsVIAn3HnvU/plzTsdL37CueVcFyqet7/C7pG9RwnZmQlgFFK9KQ6C5WlrgmiGvIqGszUvdnLIREZnpqXFh37QTFCzENLQPaiO5NFP90OHdh8RgQbJcYFaMI9h2rpCYlKN+xL92b1sCQ6tuQlH8QzVz7cEvS/5DpOul3HyllBVAKgjvjMtGBC+g7HqjTMqRryKhrU49F1iqp+9/tOIJHPvzB8dZdO0HxQkwl1IBWWFKmaT/+7rbsWCHWCOwQo2IUvt+xp7vnN2QgASW45tQyHHtzOuq0uwTocXe5u2PTHCTOH4uXiw8DKdrey+W806erTku0rs1QFlkVcSWfk1WtkjgIFf9kBi98VfkGy4nWXTtB8UJMJ9iAprWbrL+7La3m49y8U8r7OGmit3qMilGo33ESSjAl6VUMT1yFVJefOIY9snwJfPkYkJwWh7EqZ0iqApx/G3DOEKDh+cCaN4GjO4BazYButwF7v9cUgGvmtalaZINV01UJ1F9o4nBtrzcTo6y7dEeFB8ULiQqBBjT1LixU7YWj+Wcrbuo1H0/+/Ccc8Sg2FU/m3lgOjGG9t2T4SDryzqWAuwyd8lPxr+TP0S/hByRqPWwHC5cKz1aXkUCzi4A935dX8U2tDnS8vrz+iqcg6TXaewcaA3DNRn57Dw1sHbbLWK3G66/OS82qSYoZLa+gWHOv6nCJ1LobL8kGZuBya2n9bCOOHz+OGjVqIC8vDxkZGbE+HKKB+Rv2475Zwe+i5Ae99NH+lapzXvjMopDmZ1/UPVjR3Guk2IjlwBjwva84B4Or5XiXzU+vV+6z+WUBsPYtoMh/XEo8IqOzpzurMC0bqVf83VBXT6yYu34vHpi9PuR2//f7zsiuWdXvb0J+Lyt/PXzGgutWuk5L80bJThOXDvzE2snj2/o0Q42qyUHFkx5evKELruzS0JBAdCuPT1aav2l5ITGnVnrooAR/dzfBAoKDYdVgXiPFRiyzsHzfW41TGXRyNS75cBHgz+0TJwSKCVbOlY9QOeTOwN+KR+EIaigxPgdREyOuvB5Xtm8CJ6DVcvrwBz94Xceevwn57fZplaks4QQPSyG7QFV35X1uuKCxJoGjN4g4HpMNjIbihcScSFInAw1SofqWWC2Y10ixYcrA6FkCX+IlGvcoL2CmWlDS6ijNBsvSMjHvs1y40EJ5n9GJn+C2pAWo5cpHvFPgTsaWns/gvKqHgFUvA6eOVTxXlJaNB479HseQUSFUVpe1RRkSvPbxQEY6nGId1Bq4G0mjx1DBw57bSGycuJdrV0tVAoLVekmzv9tteG2leE02MBKKF5vhxOCuSCvH+hukJBPhofdCm6SXbTtk2rnU+l0ZLTa0Dowrtx9Gn9bed6zaGw36t3XJVPsygBOpVZCMElSJYyvLaXcidrnrYZO7BT4svQid+lyBcZd3LH/y4ke8xGBS41744R+LLd8k00jrYDQsp1oC20NtY0ZtJTNafcQbFC82wt/AUTs9BVd1aaD8iO0qZIyoHOs7AGnNYpr69TZT4kH0DPJG34VpHfCk6dzT13bE4Pb1vK0qahaKWFsW/z1Ao8HgU011tQBcnFHqBr4u7YJ/lV1RyXKSs+Eg/nS5u/w3KufXI3hWQmytXoDQDFekajn9yyebvILqQxFNy4QZtZXMavURTzfBFC8WxvMCC1RCX37wby7boSx2jVI3o3KsVpO0EYOw70AgmVGjZ63TPMgbdRemHsfWA5UDXj3ro4hL4vuyNmhbuBl73n0ThekrkVp0tGJbd0YDuDr8rryfz6mz68kZqtQqT0WWzJ60TODAj9i/awte3+TGW6WXoSTAsBpqsrVyAUIzYzTkc50qKsVD7/+g+7iiZZkwuraSma0+4iXDieLFouht3y7st3HRJKMH7nBM0uEMwv6+J3mZnkE+krswVbBIdsWc9fv83r1enrAKTya/iTqus40FS90uJLrOHKXPS9ziHlr+z/grNhsg2yc36xJkdxlUnhlVPbtyfZRW/bEybS/e/CG0mzJUYTW5LqpXSa6UPRPru2KzYzSyalQN67iiWW3XyNpKsWr1scBB7VQoXmzYyyUUdo1SN/ruJpAgCoaeQTjQ91Tm1rf/cO/CQglcsba8kPQShiWuqlQ9NiHI1eUdIuosIfJLWRbSXEVo5DoSsqruKXcyHiq+F6MuexDZIa6FIycr1yHSu52/7/OjtXstcUdsdoyGXkupVWKAIiFalrbSMzc4EpAsNa+ckuFE8WLDXi7BsHuUuu/djZyPcKvjymtrVE3BnwedU5FFsP3gCUz9ershLppIviexlKifU9ddmMSh7FiKbavn45eNuWjmbo8DaF8pK2VQwmo8mzw9YOyJk0vh+9ZGUdf9r7Qr7i55pOL8PJ78bzRAZbfYcXdV/KtkCKaVXo16NdI0TZASe6aFQNtZ/Y7Y7BgNPZZSq8QA2aHVxwIdFny7zR0ULxYjlHlWK2KetntJ/Eh8s4Fee8MFTQwZhCP9niRGSb4T9XPIAPbgwDaYsSwHx04V+78Lk6yfTx8ATh1BKwB/TAb+iDk44q6G8cV34Iuy7hUT8yvJL8Sl28dfyU1xkb1ecjmeLr2pYp2cqy8Lz1figOrjCOq4juOwOwMHUFsJtHWfEYNaJ0itbg9/29mh5kc0YjQCWSIUze7xplaIAbJDq48FYVrw7ZLhRPFiMYy6cCZ/9qNXnRMrBWRpiXQPVHU30J2od3Bzvt/CUvJaCXqumZYcsHS41kE40u/Jc0ISK4zvgF2zajJu690Yo1v+hsT8ZcDXWwNk/QC1cFIRK/8uvUxxFV2buFjZv5OtK4HYjzp4sngk7j8/HTUL9wYNohVr1cqy9n4nSL2/Fy1tLrIDXFd2qPkRrRgNf5aIbk1rYc3Oo7a+EYt2FlBpBJbhzPRU2AGKF4thVACab4G2cIudGW3O1GJNmb9hH0a/u87v6/3diWo1jaqvVQdfLYNwoHMQ6fekTkhTF23FCwu3VhpkehUuxY1L30TisrNBtoEQkSJHe2vS/xAX/P7fQJWa2Pbdf7Hkl9+wp7AKDrtrKFaT3dU6Y8LvO6Jdh2yl/LyWINox/VrhjwNaRzRBek7ugURxoMndLjU/ohWj4c8SYQc3RqTjqZFZQKsjsAzLTeNtfZpjTP9WlhaJFC8WI5wUX5VgvmK95mcz0um0+PWF+2b5Fy7+7kTzThXpMo3KdkcLijGkQ32szDniJfJ8B+Fg50DOYbjfkyevL9mGHgmbvVKYn0t6BcMTV8Sl5UShfifg6K+VexxVrQ0Me7Gir0+rln3RPMiEoFVgSmn5lKSEiCfIQJN7qN9NrGt+WClGw6mEGk+Njnk6GIHQzTtVjOcX/oIZy3Pw9DUdLft9szFjlNBjxVAv5EBNxaQb6/FTxfhk/V6vybdOegoOayj09O6dPSsFxSrR6MdPK9kQe44WYMbynZVeF0nDMLWJYrC7gawMMVe6QqaTqjx/fRf8fcHPEcWeBCryp6VpmhDsewpFedDoW2hwJvNFLXKmuXuy40gAeo8BLpvs0136TDfkZhd6pyiHQEvjTnHPTbuxK3q2MC4dWa/FMtRxqq5M38akxPrIdzt10TZFDPiifpPTRnbF5M8DW47D+f5XbD+MEa+vhBGIm92zc7eZIQh65m+KlygQjhVDy2t8B0lJhdNS6EkmfendoRa/e3f1Ls2CQRUZz/2+Cw7lF/odnP0N3vLYqB+TyoSh7ZTUPyN4eWRXDOmUrUloeQ4m/uJV5HuSY3tsrsQd+ReTalCt4Dke+cuUcSQZDYHLnizvjXR0B1CrGXDBnUCStqwdrQS6EfAl1jFhwW5YhFhnG5HwvtOJ835E7vHA6fGuMzdQ4dx0Rircw8XMa5LixULiJdgdvNqaPVBpf713cFrVdq20ZMV1YhTy43vyyg7K5B9IdA3pkIU3lu0w7D3lbuDxK9qHVZXTH3Jap444D0M6NdB8HtXBJND39MSnPypZRZ4VbiWzJdN1DGOS5qIm8h0lVGQkkWv6g9KLsaKsPWq7TuKIOwMjB/ZA94uHlDdy9G1BEAW0xERZQSQ4pfIpibxWlz9evKELruzSMKbHYLY1kOIlCuJFi7DQ4ioJNkj5unNEJEiqZaD3kkZ7EmwlPstY0K1pTazZebZTroqepmtaubxDFs5vWsswy4vK9Ju64rucI5qElu9g4ntNlJW5ceMbq/y6h+yKZOQEGquOuNMwvviuipRtK7k81N+H9HPyTEX3xArH6oSeM/GOnnFfD3osLyqS/DDm3XVBC2dG+5iMmr8ZsBsGn63fi/FzNuLE6VK/gZwySK749RB2HynQfAHLdve8vRZTb+iCWtVS8fbKnUomRX7R2ffwJ3TKfapb8ebSHOSdjm0HX3/CRVB/N2JlMEoq/3dTrrL4prhGiph5C0vKdAdQ+rtrFtfcNVXX4tky+9Zcke9rbVlLLCvriBXu9viurC0uSPgZvV0/olXKEXRtUhvvbwOWu8/FqrLKxfKskOYriABISHAFFC5WOVazan6Q6BFOpk/t9GQczY+sfIM/aqWnmiZcYp0BR/GiEakLcuuMVfhhT54SVBlIfETKmNmhUzvV9+rbJlPJmDldrG2yjTVm2PhC/TCrpSbhotaZitDRQjD/tCcSHK0OJoHMs4ePn8TE1Km2rbkilWYfLb4L/y3r4bV+RVkHrEAH4BQwpkFLTN0SecXiaGCXlGRib/RcP6owkRg5aeZqdA2dhZu1jXvhEssMuKi0MZk2bRqaNWuGKlWqoEePHli9enXQ7T/44AO0bdtW2b5jx46YP38+Yskl/1iEzk/8D2t3+xcuseKbXw7ZRriYTSBxkF9YggWbcpUYGSMZ1jlbucP6ZO0e/OWTTZWEi7iK1qbejQzXafsJl+R0/NR2DLoUvl5JuFTGZZs0XzulJBP7ovf6EWEisXYSbyVCxhN5HG4c1oJN+w2NM/T91QcquugYy8t7772HsWPHYvr06YpweeGFFzBo0CBs2bIF9erVq7T98uXLMWLECEyZMgVXXHEFZs2ahauuugpr165Fhw4dEAvhsvPwqai/LzHGqqOuLik1VuTN+2E/ZvpJJ7ddef7kakCv0YC7rHxEanqhkpZ8LOcYytaHDloWF8dHa/eYWjbeTiXuCdFaq8s3ztHIGjqlZyrshkL2XD8jVWmbMnP5Di+3qpoiHc2u13owPWBXBMsFF1yAqVOnKo/LysrQuHFj3H///Rg3blyl7a+//nrk5+fjs88+q1jXs2dPdOnSRRFA0QzYFVeRWFwI0YpkFS1N/SOyccS6Fpd2VwJ121QIFX9ZP3pqj0i6uF3SfJmSTKJBqBR9qdU1pn9r0yb/FTrqvEiSgho/6SucApWCsEKdF1MtL0VFRVizZg3Gjx9fsS4hIQEDBw7EihUr/L5G1oulxhOx1MyZM8fv9oWFhcri+eGN4taZwd1bhPgi6dBWzSoqTKmJ1KteqqhQa1Qvm2iVjTcCOx0rsS/hVluOdtzNbX2aVRyLv2BxK1dUNlW8HDp0CKWlpahfv77Xenn8888/+31Nbm6u3+1lvT/EvTRp0iSYwY7D+absl9gTLdlSUubfishxnygsxdclnTHYhIneyoOcL3Y6VmJfYnmd1dMYdyPHZ9cMONtnG4lVx9NSI5YXcUsZQUaV5EoNDkn8osXBKv2JrCq8MnECF33cA6WHH0TiJX/SVCROzwCsd5CLZU0Tqw7IxFnE6jrrHgfxXaaKl8zMTCQmJuLAgQNe6+VxVpZ/xSfr9WyfmpqqLGYwYXA73P7OGlP2TZzJ6rK22OeujSwcCVjMLZakS37z4inA6unAsH8CbYcCO5dXVL4tbdwLq3fmVRIUoQZgvUIkFtVkWQCOxAuJOty+diUqAbvdu3fHSy+9VBGw26RJE4wZMyZgwG5BQQE+/fTTinW9e/dGp06doh6wK4Nd67/ON7XID7EX1ask4USIYoCe2UaWDdpVSUkHis66Rw+gDv5WdHNFlVwtgkKvENHS9NJoAcPS+yQeWWCz695S7QEkVXrUqFF49dVXFREjqdLvv/++EvMisSy33HILGjZsqMSuqKnSl1xyCZ5++mkMHToUs2fPxlNPPaU5Vdro9gDy5RtRfC5eUCdspwk+1cw66Nz6AVOkfQXMs8mvorrLXmn26vf2fMm12OnOVtxgUlV32k3nRyxElBL9vx7G6HeiW6I/FmKJEKtQaiOLo2WyjVRLym+//Ya//e1vStCtpDwvWLCgIih3165dSgaSp5VFars89thj+Mtf/oLWrVsrmUaxqPEiyKAmqWSPffwDDhVULtVPzqL+HO68qDleW5Kj/N/qGqa8A3T7kC3pBblbqVE1RZN4EcvFV4VdsTb1LlSHfQrVyZgmtzMPJ39UsW6/uzY+/eQylJUNREL1rIqmimotCX/fsayTj/zXTzbhVFEpdh05pal7udEl+rUcozwvcT16BnQ7TQgkvkl0aHwXGzOGOVh1a1oLa3Yexf5jp7B211EcOH4KaSlJOLdBDaWB4vrdx5SB+lRRCVblHIHGdjm2xtMcqaWTb6xxedx1q9+v1DWYs34fjni0qPftJdVp4hd+e04FcyEJdp3bZITwEl8ZDYDBz2BFah/NtSTM7qAbCL0dwp1oiifELljKbeTUrtJ6cLrrSWoFyJ2r791nUUkZek75yksIRBPVBfHXy9vib5/+6JU5FmyyCXVX/fyXv+DFr7ZqPg4ndZX2RFoIDF3fs6K+jaSJi5tJgpZ9GzTGqlvt3PV78YCGfmFaxVIwF5T7TPGxZpnptMYQEgYULxYTL+qgN3He5pBmczsR6m5TT5VHo/GNZzDSzC/7avvYf1GsIbBHGkO+elM3HDpZgBb5G5C48G9o595eyY2k/grt4l5SKXK7UIpEVHWdDWI+5U7Gp6U98VjJ7eiasM1L1IQSOkbHvBhpeVGrDmu1JtIaQ4iNY16I/3oZmdVSlVs1ETPrdx9VtmlWJx31q1fBY/M2KT0lrMjlHbLQsm46erXIRM8zg71MEP5EQSy78/oWUjPS7yuuJS3CRSgqLVPOU2JCJoAmmJ/RDd++9zDuSPociR5zcykSML+0O4YnxUbshUuKS86Dd/ZVVVcxrkv6Fr9P/NZLjJ1wV0UJElHLdbJi3WF3dTxWfJvSANKMFE4j613Ib1ePG1TeU6w0DAgmxHhoebEgcoc3ddFWzFjm3SirVlqyMgBbQdjIhDC8c7bSoNBzQJd4n6u6NFCEWlmZGze+sUr3vl1nmoKlJiUg9/jZ1g+heGhgGzTLTAtpWYnECqP37lt45/Ye6NM60ytWIgkluCXxf2jiOohd7nr4Mu0KDO3SCLd+dyXquQ/bzgITdvzMmXXLytrjy5RLMbRPV3TvO0xTAb1o9zPS6oIyO3uKEKdCt5HNxUuwSVaQdWKxmfyZdxyH1ahVNRkFxSUoLNF/iU29oQtqVUvFiwt/weod5ZapUMLlgYGtTQ+2DMcVNqZfS3RoWMNvrIRKjapJeObaTrjUtRoJH4yCG+4Io0bsS2GV+sit2wspadVRr2k7JHa/E0hKiWifRgTZRuIGlWugT6u6jIMhJAgULw4RL+EGD9oBNcBRbbvuS4KOWjH1q6dg+fiBIScFLfU+QpXCD+fue3S/lvh47d6Q1pqK7KeE73Dq0z+h6qncoDExdo2T0WudkZiYhF6jgdaXAjnfKmtQpRZQvT5QPbsidTsUkcY9heq0HW9xMEwXJ0ZD8RIn4kWwQ0pysEG8rAy4b1ZkmVhqe/lgA2kod08gV5XvZBPO3fdfh7TD/5v/k6Zts1UXA8qw+ptP8dny9filIB39XOtwR9J8JCoxJuWUuBOwqywTzRMOOk7AeKKMUK6zIrMSVWsBPe4FLn6kXMSUlQI7lpYLHXlR0wuB5hcZ4ooK5ILSilZXldWFQbTTxa1+PogxULzEkXjx98M+dLIQ97+7LuD25zXKwLo9xxEraqclY+Vfyi0leuNHAgURr9tVXlfHSNERKGtJz923xCn97Yr2eOj9HzS/p2fmi7zfzGU5mPz5T5XiZN4qvQwlSEIKivDXpLcxvNEp1CrcCxzdgbgkqQqQ2Qb4bQtQ6hMrlZwOtBoI1GkFpNUGqtVTrDaBejmZecMQKg7G6nVkol2x2OrnIxwoxvxD8RJn4iWcH7w8P+7jjTEL/pUJWjArldp3IA3H3RNostFz9y3VmaUqr57P6VtzJJRgqjQZlhQBb18D7BAXS2BK3cDeskw0SDiEpDgdNw+iNv5T3B873VlK6vbe9A54rlchutctURpVBnJJeU4+Ow4V4IWFvyjr9Qym/tKzY9XKQOtkqsWCGWmAsr9z66TWDk4UY0bBVGlSKTXbd0BSn/eX1RQNzE6j9i39Lp8/kn15lqyXcyeDZrC7b9+qvPJY652677GqHWIDFTp0+6YXS3DrHz4DNs0B5o8FCg5XbJvnTsOaslZYWtapwnKTgDLcn/gR/pjyORLdsSkoGCvquo/g4eQPKx6XFgGJSzw2SKsDdPg9UKsJkF63IsYmMSHRS3ick1VNtzXG9zdgRisDLaJEz2QaKl08VHuHUMej1aoVSWuHWBJInDKtXj8ULw4mVG0Tef6BgW284kVyfsvHWyt3ml4VNxIxoRV1IJVmgELNqskRiTTPySZQ3Z5D+YVeg7I6WA/pkIU3lgV35+ipOaKJDlcB7Ydh6Vfz8P7X3wesfiuPXyz9PVoMfwJX1twJnNgP5O0Fvp4ClGlPVbcjvrFCnrV3FET4rfbpZn+mPQLaD/d7PSzbdghTv96m+zcQqTDwRYso0TuZar3p8LedFmuwngQEo/tgmY1ZfbbiFYoXUknk3D/AO/j1aH5RpcaFMuhc0SkbbyzN0d1BOisjtWKCrlE1GXkmW31um/kdCg1oLuXPIhJs0PQ3WMtk6c9RG6xAmzroBSLooJeQiMQWF2PeV6FTjetlpJcHtqrUaQm8f3PI18Udx/eVn5ee9wHnDKlwLanXg1zbH63dEzQuSr4m+V15Eokw8EWLKJHrJdhkKvzlk43o37Y+UpISdN10+G4X6nimjeyqjDHhxDDEshimHowWp/EOxQuphL9JeVAH/y6o8xrXxH2zAgcH+2Pi8HMrJtlL29XDh2v3wkwiFS7hWEQC3kWeWZGWkogCj+aOvhWBjRz0wqkyq1iMUvsgsfuLOG/940guOqbpc8cVK18uX5KrKRYutOyvxMkkut2Y3vlXTFl6LGCfJxH8o2etxSsJZy0bEt+hha0HTigB6MHiUrTc4VdPTQ7pnpE6UtKf7KmrOyjHGe61FOp4JszdhMNhWnujYcU1AiPFKaF4IRoJZGUY0qkBpie4KlsY/AQvSiry09d09Jqg+7Sua7p4MQI9Jeu1DNZicXr95vMruZnMGPTUmBkRU77fiz+Lj7fFqC4SMBWXV9uGh1ruQ6vko8DxvUDuBqDobJn/uKb4JPDDu+XLGToDmJ0C7HfXwsTiUfiirLtPtlhdbHE3xvI53+HStP74Mr9FRdBvKKZ+vV1ZPKtZe14/WsXuil8PaXo/cSF7upD0XEtajycc4WK4m9VkwrVaEf9QvBBTgoO7Na2F73YcUe4QZXhSeyH5TtBZGdb/oQ5sX09XEJ3WySMhwaWpk7ERg16gIGNfi48/i5FYDuafbIP5P7Q5GwMhtVR2LgdOHgAObwfWzix3pxAvsnAUryS/gIWlnTEg8YfKMTXSFuqt59EdGfhrUm8sLDsf35e1wfkJv4Ts0i2i4s1lO5TFM3ZE+527vrgK1TWp9Voy05JgRh8sszGyz5Yn8Zp2TfFCTLPM9GmVqSxaftBWLrL35eaDmL9hn2Jl0jJQGG0eNmrQC5WBpi+gMNE7PkYKxKliRlKM838D5v8JKNB2dx+s95Gdkc8iH+fSxB+Cfq7aOI47khbgDixAmduFBI9ihEfd1fBmyWBMK73Kr4gR5PejWke0il35vYaKzQmWcReqGrWKEsyugdrpyTiaX6wp7iWYmzUcoiEA9FpAtbAgjtOuKV5ITPH8QQtWLTr02NxNyl8pFud1t5mRihHdm6BZZnpFxpHEJBhtHr7hgiZ43o9bQe+gFyzIOKLYGl8xI7S/slzQSPaSiJqCI8CxPeUHndEIOLkP+OUL4NTZ3lV5rmpIdJeiuusUnIQeQeYpXATpwi3p3KOTPsHLJcMwtfR3fkWM+0yA7WND2itCIFDfM1Xs9mxRJ2gKfijBraVTu0yuj5/57QRCPZ4JQ9th9Kx1fid295lK2vI7M1pcRFMA6LVahTrue+M47ZpF6ogl8DeAVE1OUH6Yp4sjzxSyEupg/ezvOoeMeQlV98LIQVZrIT/fInoR4el+qlYfRQ174u2VO4BdK9AiJQ8XNkhAUvU6wPZvgA1nY0rimdPuZDxQPFqJo9GLb3E3ub70iBd/hfUCoXXfLp/jiaYlwepFAYO9/kKTiwXGAhapI7YjkBlaqKilkp6KMrcb76zeiW+2/GZbUSMD5YnTJbjxjVVesT8Th3sP0KHqXqg9nYwanGISUOhhsVEmrueWnBmQZYKsg+ztZyaua24A2g4BPv2jl6UmHklFMaYnv4DnS67Bd+62qIvj+A3lA738P1icjOcdfqgU/EjiMWTfUsFbCzXSkiv+r8cdZbW6K3oEiRarVTBWM+2a4oVYh0A/aN91F7WpqwwUUh34+YVbYUdOFkqk5lmkL5PcpUo7Ac+JJZhZdObyHYp4sXpAoXEm8OFA26HlTRd/XQwc31PufmraG6X7N2LjotmoV5aLbNexSm6akM0dbYT62cYmfxxwm8Pu6nis+DYsKOuBzLRE/F/PAtRPyEPLFi2R2KyepgnQFz3xGCu3H9bceiSvoNjLzRHpxB4LARBti9FBpl1TvBB7olYHPierut8eTekpiejXth6+33HUq2Gj1Rn/8caKO89QE8vRgmJFwMl5sGpAoRZ0Bwq3uKR88Tz21gORW/sGXP32WgxOWInJyTOQ6Tobe3QSVVAN9rkOIqWO6wReTn5R6TqeXFqMBsvzyp9YerZC8MGibpr25a/EQSi0pmHHsrqsUQIgFrEn9Zh2TfFC7I1qZpY7vfIBs/yuTYIRPcvzq6bcg8dPK8G34rYJVpMmVoggkXYG0hlcC28uywnqOtLrWzcyoDDad8Bnj70Kuud1R/eEn5V045L0ehg+/FoMdn0PzLkbKIkPESMWmqaJhypXdFYqBN+CtpdMQwIylPNUH0dQx3Uch90ZOIDaXm6naSO6ok/rTL3vrmvrSHsi6UHdlxGB9bEq+d89hlZSq0DxQmyPDAoyuPobYP2ZoK/o3KByTZqcI/jPyhx888shr1gaGSAmDG2vlC7XklJqBFIbJ1SKuUreqRJMXbQNDwxsbZgpW0tKdaQTiec+th44adidsvexd/U5vkbllXDF5SQF5Y7tAmo2ATrdABSdAL4Y78haNf4zndxo8+1YrKmSjFqoPIkfd1fBv0qG4KP0EUp9Jr3Ib05Lf6dweyIFKtAXCq2NH7UKgFjFniTGyEpqJSheSNzhtybNGfETaGJOSIDfgcIc3Mr7am0kKSnU0tXYU5DM37Af982qnOmh1ZQdKO7ACN++ngkkHBN40JgJcTu16l+++NJu2NnUbqlTI12kj+QAq15xZJCwq+w0agVwpWW4TisxNX8s+wKJP0/3akKpBbF8irtJa9yL3p5IgQr0BUNP40etAiCWsSeDY2AltRJMlSZEI+FOunp55/YeipB6caEEJGsrGS/1ZpaNG6AMtFJQb8y764I2zJSJ5aXrz0NCoktxUWmxoBiRVqq3c7Al0j4lnTvnW+D7f8G9ZQFcZT4TclJVoG4bYP8PcCzX/Ue3gNGThu3vOw6VDuz7+mDXn559CVoFkVhJR7y+0tAUc70UlZThPyt2YOeRAjStnYabezWraKTp5Pmb4oUQHXhaZqSR3r9X7FDuAo1CRMWaxy6tiNfpPOl/lTKTAiFdvmXRU7dD64BtRF0JvROIul/BMgW3RMhItpOIGTm4pheWp3qLRed/E4AVUwG3PVP4g5JaHfjTr0BS6O7kvgJm4rzNQYPmA33HWoWBlutP677G9GuluGy1uqLUazpU7IlZwnuBwyrsss4LISbh65JoUrsqHnrfuDtuyepQBzn5e935jRTTuBY+27Afi34+GPZ7ywAowuf2Ps0wMMxmf8F8+3pTcy1pAg+Q7aRw2WSg/wTgu9eBozuAWs2AbrcBy/8JLH8RKMqHbSk8AUxpBFz0cHkrCDkPGvCNn9pxKB/vrt6F3OOFhvZECnX9ad1X6/rVdFlIYhl7siDOK+xSvBASAVk1qhqzn4xUTBx+bqXBZkDb+prFi1BQVBrxsbyxbIeyqK0PmtRJx+It2kRRsElC6wQypl9LtK5f3Z5N5sQy0Wu097q+j5ZP+GcsNlty8/DB5jycm7AbPVyb/dalsSSlhcA3TwGrpgPDXtTsRvIV/JIdpyXgO5w030DXmJmpxbGIPSmNUZaTlaB4IcTElEVfJEtCerjUk27abgRtD6Ca3GOF3B3rLQIYbPDXOjH0aVU36lVBTW/M52GxObL9MP61cSVwRmdKXZonferSWJpTR5RUa1z3VoWAMaO6rN7fVrBrzOzU4mhWBhZWs8IuxQshkRDMbOyJOoQ9dXUHTXdi4QS2xhItg79Va1NEO27A9zwsKOuJ/xWW16UZ6FqD25P+a4NqwG5gwTil4vGCzQdNOX9af1tarp1ouHeiVRlYOMgKuwH6qxNCdJuNZfAMhDyn1QetpTWA1XBrGPzVCUTw3SpWtSlUkeh7F6vGDcjzRuPvPEhBuJVl7fH/Sm/GvcUPoiilJizP8b1Y/c2npp4/Lb8trddOoH3p+W1ahXqssMtsI0KMwtN0Lk0kZVTVmobsiZ4sC6tQKy0Z35/JkgrH0qHG1zTLTI9arEusO/MGtfi0r1ee0bRz6ZkghkRgzQwg/wCsxN+SHsJbJy8w/fypv62Fm3Pxyfq9OJJfHLaVx3QXYRQojXGWk2NTpXfs2IHJkydj0aJFyM3NRYMGDXDTTTfhr3/9K1JSAqfa9e3bF4sXL/Zad/fdd2P69Oma35vihdiduev34oHZ62E39NSy8E05n7VqJw6cKAwZwGwkVqjRoWsilTTtJc+WB81ahBuKHlMsRtE8f04QH0ZaDRHADWY3a5IlUqV//vlnlJWV4dVXX0WrVq2wadMm3HnnncjPz8ezzz4b9LWy3RNPPFHxOC0tzYxDJMSy2NXUq8e/rsYHyADsrxCfBAt7dtl2atyArjgJCfqVzKV67YB59wOnjyF2uFBQtT5Wn24b9fMXzdgSKzM4zivsmiJeBg8erCwqLVq0wJYtW/DKK6+EFC8iVrKyssw4LEJsQThZFlpQ78geHNgGzTLTKlxbX/10QFc6diBkf2LN0HpHLHfQ0hE8GOM+2mBauqdt4wYkw6ftUGDx34HFz8Ssreju7n9D2RcJ9jt/DmJwlLOc4jLbSMxAtWuHziJ455138PbbbysCZtiwYZgwYUJQ60thYaGyeJqdCLEznpkR4aBmU/j2lgl0RyYVRc9vWitkS4FgVEtJxMMf/OBVSdUzFsGfqV86gYfqfXPsVAn++dVWPHRpG8NdB1bNftJshek3HqjbDvhwVHTfO6MhMPhptGo7DNkrF9nz/DmIxDi1REVFvGzbtg0vvfRSSKvLyJEj0bRpUyVGZsOGDXj00UcVi83HH38c8DVTpkzBpEmTTDhqQmJvEp4470evaqT+kDnbU3SoIkXPHVmt9NSwhYtwsqhUWfxlnNx1cXPM+2F/pcDULo1raNr3i19txYnTxUrBPpkRF/10IGTQphZx44jOvB2uAhL+A/z3z+UNJVWS0oCSgkqbS4Rj0IJ4Iky6jgLqtATSMss3PnngbKPK6tlA096KeJIau7Y/f8S26ArYHTduHJ55RsyUgfnpp5/Qtu1ZP+jevXtxySWXKMG4//rXv3QdnAT8DhgwQBE/LVu21Gx5ady4MQN2iSOQSXjqom1+40LUKWHayK6olZ4SkRUi2kHCRnfn9gxSFPTUHXFEfxgJ5pWO2CI0qtUvFxg/fQr352PhKjhcsdk+dy18W9oRp5GqfAM/lLVE46pFeGBYLyTUaFAhTPTgiPNHnJ1t9Ntvv+Hw4bM/BH9IfIuaUbRv3z5FtPTs2RMzZ85EQoK+sjIS4FutWjUsWLAAgwYN0vQaZhsRJ2L2BGHH9Gx/AkZcZUeDuKKGdKiPG3s0Q8+WdbwEXjQyWGKRJbNi60G8OOPfqIdjOIiaWF3WVqkpY3RGEDOAiKWzjerWrassWhCLS79+/dCtWzfMmDFDt3AR1q8vvxPMzqZ6J/GN2YF5ZgUJRxM57mDCRZi/6YCyiMiRJpiq8DM7biBW1omD+cUhU5kjzQiicCGOiXkR4SIWF4lfkTgXsdioqJlEso24hN566y10794d27dvx6xZszBkyBDUqVNHiXl56KGHcPHFF6NTp05mHCYhtsLMCVZPKXYnIIHCnqnYkU7AwV4fy+6/ZmdU0WVEHCVevvzySyVORZZGjRp5Pad6qYqLi5Vg3IKC8qAycTUtXLgQL7zwguIukriVa6+9Fo899pgZh0gI0Vg3onZ6Mq7u0hANalbF5M9/Mvx9HxzQGv9ctDWigOFwkYDosjJg8ueVJ+AJQ9sHjCXyFCvbD5zAm8tzcLKwzOv1atB0LLv/mplRFUtRRgjbAxBCNFkRQpXT14tnCfMvNu3HfbPWwcqogkTwFXiBPt+DA1tr6sxtZBVarzYV1VKxOucwXvxqm9/jE8IRGbFureB5HHRZOYeYV9glhDjPPaW6lsTdogWJK7n+/EZ4bUmO8jhYKu2QTg0wPcGlFK0LVfslVshErfWzq593hsbif0ZVofXnxglEJJVYRTAEew/57PK8bGeWq5Muq/iGXaUJIZqRSeGhga01bTttRFeMH9JeVyffPIsKl3A5dkrb5zGiCm2gDtn+eGhgG8UqEu4kH+vWCrHoBk6sBS0vhBBdjOnfGu+u3u1VTdefy0DSkbVmSon5P1BsiN2pWTUZeaeKDY058XWXdGtaS/P5k/ec/d0ujOnfCnZsrRDsWtEbR0S3k32heCGE6EIG94nDz7Yv0FJZNVSmVCg3hJ25tU9zvLDwF8Oq0Ppzl1SvkogTp70rHJvp0ollawWjXFZ0O9kbuo0IIWFnJml1BxnlXhArhicy2dx9cXNlstR7v1w1OUFprWAmIirEwmHUuQrkLtEqXIxy6ajxT4LvKTS7NYARLiu6newPLS+EkJgXztPqXph2Y1ckuFyV3u+8JuVuEz3Wm1PFZ1ObzWLKVR2V45Nz1b9tffxnxQ7sPFKAprXTMLJHU6zffUxpzaC1C7eRrrVIXTqBUusjCQSOhsvKSLcTiR0UL4SQmBfO0+qG6NnCu6x/ICElKcKyo69+PoA56/fhSH6R176iEVtzaft6uKJLw4Auiv83/yev2jbBXBYy4c5clmOIa81Il47ZlZ/NcFlZIVOKRA7FCyEk5hjR4dmfkOrTOhN/HdpemYi+3JyLN5ftiIpwGdoxC/8c0TVoMTffonxqKvatvZvhsnOzKkSAnvTnUJjh0jG7tYLR10q0M6UYFGwOLFJHCLEMZgVRGl1gTwvlVXrbKVWJw3lfef3wztlKnRyjBmknBaSGe61obUJqROFABgVbpKu0HaB4IcTemHGnGk7XbBEemdVTMXv1Tqz49aju94xlj6i/DmmHehmpFe6zQ/mFjrzrD+daUYVsKLdTpNWBA1ncIqls7HSO65i/mW1ECLEUqhviyi4Nlb9GTLZ6XACuM3fHf+jTXDmGt+/opVQL1kss7wrfWPorUpMSlBihBAeJFSOulWhkSoUKChbkedmOhAdjXgghjkdvZo3n5CV/n76mo9+7aKty4HihEj+TnpqI/MKzadR0WUQnU4pBweZD8UIIcTyhMlRCTe7qZDfuo42aS/7HEvUzegoXnJkwtXR8jocgUzMzpWLdPiEeoHghhDieYBkqKtKzSVofBJq8ZLKrnpqMG99YFdYxxDIGxhN3iDomoYJMvbpWp6cqH+zQSW0xNdEWRaHez6xMqVi2T4gXKF4IIXHtKtDjSpF+TbK9nuyh8qyj9pj8uTHpzkYQyGURKMhUrTx718XNMe+H/QE/h7ip7rywOe4f0KaSKIl25k0sM31i2T4hXmC2ESEkroj07l8mRYkn0cr0My4az/c9dKJQSaHWgrQ/eO+7PYa7q168oYsS6KoeV27eKeWYPAv6hUt6SiKeu65zhUgIlXkzbWRX1EpPCcuaY9VMH/UYEKAWDbONKsNUaYoXQoiJzN+wD2PeXVep0JwnMt9OHdEVQzplh1V3xvP1y7YeCttdFYh37uiBE6eLDSuAF0i4iXtKy2cNdC71WktCnVujUqFDHYNaGNG3wjODpo2Zv+k2IoQQnQzp1ABT4cJ9swJbYKaOOM+vcPGNwRHcIV5/QfPaqJ2ejCP5xllf3l21C59v3G9qHI4II4kTCiWOgolA1WWl1VJhVKZPuBY6f+4q+e6u7tIQA9ufrZxMIoPihRBCwkCExfSE8GNotMbgqJOhkcJF+Gyj+Z2T5XOt+PVQRPtQdc24jzcqQkjijoJN/kZ1nQ7new3krjqaX6y0phARSuFiDBQvhBASo3TbUK8PNBnaC2Mm62MFxYrrLJSIiDTTJ1TQciALELtVRxeKF0IIiYBI020DvT7YZGgnkgyeqEOJiEgyfSIRIGYWpouHujt6oXghhBALEmoytAMiIt5dvdPQfYYSEZF0nY5EgJhVmI7NHf3D3kaEEGJBnFB9tVvTWjhwIvLU62AiIlg8kVhYPJHHwQJ/IxEgZhSmU11YvoIq94z1SZ6PV2h5IYQQC2Ln6qu10pJx3fmN8OqSHFPfJ5jY0BKP5OuOUbpwh/ndGF2YjjE0waF4IYQQC6J1MpwwtJ1SXM4KLqYmtavi4tZ1Me7ydrj0+cWmv9+OQwWa44l8hcrR/KJKVY+zMlKVDuJ5BcW6BUgk7ip/sLljcCheCCHEgmidDMXCMKhDdsXEvONQPp5fuDVgL6Vgk3Ok7DpyCm+v2oV3Vu2KSqDxv1fsUARTVo2qFYLCn6XFX9xIoG7c6nGHI0CM7FbN5o7BoXghhBCLonUy9M1YOieresAgT0EtjmcW0cqQksq1D73/Q4UoU1OqPT/z8M7ZeG1JjqZjUt0xNdKSUSUpEbnH9QsQo7pVs7ljcNgegBBCLE44qbLBXiOWiInzNntNzsSbd27vgYQEl9/zF43UZbXNQSi34VIT2xxEG/Y2onghhJCQk+PURVsVF5MvqsukRtUk5J0qQTyiNq6MZupy5bicQoyetU5Xc8dSG9eEYW8jQgghQZEJ7YGBbfy6mFQXiaf7Q7o9P/zBDzhw3L8lwGl4BgN7NlqUMv++yLmTTuO392kWdv+iQKLoroubY94P+zXF0CyIo5owtLwQQkico/VuXa07Ijhq4vBD9hmXjAgWvZ239QqGQC0J1G9g2siuqJWeEvT7WRBiH1obW8YSuo0oXgghxBS0Zu44gYcGtsYLC7fqFmp6BIMa2xLofGqJbSk1YB92m79Nq7DbrFkzuFwur+Xpp58O+prTp09j9OjRqFOnDqpVq4Zrr70WBw4cMOsQCSGE6EQmY5kE372zJwa0rRt020vb11MmTutOl8GZsWxHWBYm9TUi8pZtPYS56/dixfbDisiIpJ5LIFYbsA+7YWrMyxNPPIE777yz4nH16tWDbv/QQw/h888/xwcffKCorzFjxuCaa67BsmXLzDxMQgghOlBTs2WZMn8zXv82B57zstzc33lRc4wf0t7Wlppjp86mXetFFQzSCTuYO8mIei4H47AmjKniRcRKVlaWpm3FTPTGG29g1qxZ6N+/v7JuxowZaNeuHVauXImePXuaeaiEEELCQATKw5e1xX9W7MDOIwVoWjsNN/dqhpSkhEp1T3LzTinVgKW6rdXjFWpWTY5IvPhDDex9eeR5GNKpgWKJOXSiMOJ6LvXisCaMqeJF3ESTJ09GkyZNMHLkSMWykpTk/y3XrFmD4uJiDBw4sGJd27ZtldeuWLEioHgpLCxUFk+fGSGEkOghQuX2i1oEfN6ziF7VlETTi+QZQc8WtbHgR3PCFsa8uw637z6GzzZ4ZxEhzJ5I3Q3uq2QHTIt5+eMf/4jZs2fj66+/xt13342nnnoKf/7znwNun5ubi5SUFNSsWdNrff369ZXnAjFlyhTFxaQujRs3NvRzEEIIMb5qcO30FFgZs4SLIC42cbVpES5aeiIlnmkl4fkavftwtHgZN25cpSBc3+Xnn39Wth07diz69u2LTp064Z577sFzzz2Hl156yctKYgTjx49XXE7qsnv3bkP3TwghxHgBs3L8ANRKS9LkvolXxFqiNcV58BlRKK8Jdx+OdRs9/PDD+MMf/hB0mxYt/JsOe/TogZKSEuzYsQPnnHNOpeclNqaoqAjHjh3zsr5ItlGwuJnU1FRlIYQQYi9X05RrOikxIMG4tU9zPL/wF8QbN/dsgglXnFsRO6SFwQb1VXKceKlbt66yhMP69euRkJCAevXq+X2+W7duSE5OxldffaWkSAtbtmzBrl270KtXr7DekxBCiHWRyXb6TV0x7uONXg0VhVppyZhyTUdlMp793a6A8RxO5T8rd+HzjftxdZeGStXebk1rYc3OoyFFSaJPk06nYkqROgmwXbVqFfr166dkHMljCda9/PLL8e9//1vZZu/evRgwYADeeustdO/eXVl37733Yv78+Zg5c6ZSoOb+++9X1i9fvlzze7NIHSGE2AvJulm5/TBW/HpIidKQybdnizpejSTjpbJvIORUeKajZzuw7H/MK+yuXbsW9913nxL/IjEuzZs3x80336zEwaguHnEfyXoJ6JXYGLVInbim3n33XeV1gwYNwssvv6w53VqgeCGEEOdh53oxZvLyyK4Y0skZAibm4iWWULwQQogzKSopQ7cnv8SJ0/HZ6TqQRWbqiPK6MXbHEu0BCCGEECORmA8KF2/ElXTfrHWKZSqeoHghhBBiC5xU3t5oJn262W/vJKdC8UIIIcQWOKm8vdHsd1jjxVBQvBBCCLEFahn8QFVLZH2d9BSM7tsS8ciybb/FjfWF4oUQQogt0FIG//9d3QFjLzsnpMiR56fecJ7l2xToYerX23HB/1uI+RucH/9C8UIIIcQ2aCmDr7XXzxVdGuC7vw7EO3f0QHpqouZjsHK92iP5Rbhv1lpMmb8ZToap0oQQQmyHuEdClcH3VxsmUHG3Jz79EW8u26HpvaX6r8ycx055VwW2Gg8MaIU/Dmhjm/YArPNC8UIIIUSjyBFWbD+MEa+vDLm/33VthA/X7oFdyMqogonD7VGJl+KF4oUQQohOkXPhM4sCVvAVuVM/QyrEu5B73F4p2y7AFp2lWaSOEEII0YEaJ+MKEiczonsT2wkXQSwUf/lko1Kh2ClQvBBCCCEagoGbZabDrhzJL1ZaK0hsj7jI7J5STbcRIYQQoiFORmtcjB2onZ6MJ6/sYKmeSHrm76SoHRUhhBBiA0So9GpZJ2CRvNy804orxh/VqyTixOlS2MESc9+sdbh7zzGMH1KeVm4n6DYihBBCNBCqfowsz1zTKWiBPKvx6pIcWxa1o3ghhBBCDIqLETdMqAJ5VuPPH22wXQwMY14IIYQQg+vHBCuQt3DzQcvVivnrkHaol5GqfJZuTWthzc6jIWvjGA3rvFC8EEIIsajA+WTdXjz03npYFdeZ9OpQVYmNhgG7hBBCiEUDf6XqrZVx+zyWAOV7315rqUJ3jHkhhBBCooiataSF9BTtDSPNFDOyiBvMKrExFC+EEEJIjKr5BkOef+66zrj74uawAvvzTituMCtA8UIIIYTEKGspkAVG1qtuGqnD8tMTg1ElOfZT9pebc2EFGLBLCCGExDioV3omHTlZiNrpKciqUdVvhs/8DfuUwnKxpFpqIl696Xz0bFnH8AwkBuwSQgghNg7q9UetdOlqHVtOFpbixjdWoWbVZNzapxnG9G8dlTRqX2JvgyKEEEJISCTl2iocO1WM5xduVZo9Sk2baEPxQgghhNgAqRVjNY4VFCtp1NEWMBQvhBBCiI1SrF1BtklPTcSAdvWieFSxSaOmeCGEEEIc0hjyud93Ru8W2mJo7JxGTfFCCCGEOKQx5OAO2bi5VzPEIIY2qjE5zDYihBBCbMTgDtm4tH1WwMaQKUkJuPOi5nh1SY5jY3IoXgghhBCHpViPH1LuXnptSU6lXkVmUCc9RRFQ0YJuI0IIIcSBjB/SHluevBzXdm1o+ntNvrJDVOu9ULwQQgghDiUlKQHPXdfF1P5Isu8hnaLbbdoU8fLNN9/A5XL5Xb777ruAr+vbt2+l7e+55x4zDpEQQgiJKyvMyyPPU1KpjUL2JftUXVS2721UVFSEI0e8U6YmTJiAr776Ctu3b1dESSDx0qZNGzzxxBMV69LS0nT1KGJvI0IIIcQ/Uotl5fbDWLb9N+w7dlrJUjqWX4TVO45g95EClJQBSQlA1ZRElJSWQSRCcmIi6lVPRd2MVNSrlopGddLRu0Wm4f2NYt7bKCUlBVlZWRWPi4uLMXfuXNx///0BhYunWPF8LSGEEEKMITHBhT6tM5XFzkQl5mXevHk4fPgwbr311pDbvvPOO8jMzESHDh0wfvx4FBQUBN2+sLBQUWueCyGEEEKcS1RSpd944w0MGjQIjRo1CrrdyJEj0bRpUzRo0AAbNmzAo48+ii1btuDjjz8O+JopU6Zg0qRJJhw1IYQQQqyIrpiXcePG4Zlnngm6zU8//YS2bdtWPN6zZ48iSN5//31ce+21ug5u0aJFGDBgALZt24aWLVsGtLzIoiKWl8aNGzPmhRBCCLERpsW8PPzww/jDH/4QdJsWLVp4PZ4xYwbq1KmD4cOHQy89evRQ/gYTL6mpqcpCCCGEkPhAl3ipW7eusmhFjDoiXm655RYkJyfrPrj169crf7Ozo5s/TgghhJA4DdgVt09OTg7uuOOOSs/t3btXcS+tXr1aeSwp1JMnT8aaNWuwY8cOJchXRM/FF1+MTp06mXmYhBBCCLERSWYH6vbu3dsrBsYzfVqCcdVsIkmvXrhwIV544QXk5+crcSsSI/PYY4+ZeYiEEEIIsRmmFKmLJSxSRwghhDh7/mZvI0IIIYTYiqjUeYkmqiGJxeoIIYQQ+6DO21ocQo4TLydOnFD+SswMIYQQQuw3j4v7KK5iXsrKyrBv3z5Ur149ZB8lI1GL4+3evZuxNhrg+dIOz5V2eK70wfOlHZ4r88+XyBERLlJlPyEhIb4sL/KBQ7UhMBP5knhha4fnSzs8V9rhudIHz5d2eK7MPV+hLC4qDNglhBBCiK2geCGEEEKIraB4MQjpr/T444+zz5JGeL60w3OlHZ4rffB8aYfnylrny3EBu4QQQghxNrS8EEIIIcRWULwQQgghxFZQvBBCCCHEVlC8EEIIIcRWULzoYNq0aWjWrBmqVKmCHj16YPXq1UG3/+CDD9C2bVtl+44dO2L+/PmIJ/Scr5kzZyoVkT0XeV08sGTJEgwbNkypKimfe86cOSFf880336Br165KJH+rVq2U8xcP6D1Xcp58rytZcnNz4XSmTJmCCy64QKk2Xq9ePVx11VXYsmVLyNfF47gVzrmK5zHrlVdeQadOnSoK0PXq1Qv//e9/o3pdUbxo5L333sPYsWOV1K+1a9eic+fOGDRoEA4ePOh3++XLl2PEiBG4/fbbsW7dOuXHIMumTZsQD+g9X4L8CPbv31+x7Ny5E/FAfn6+cn5E7GkhJycHQ4cORb9+/bB+/Xo8+OCDuOOOO/DFF1/A6eg9VyoyEXleWzJBOZ3Fixdj9OjRWLlyJb788ksUFxfjsssuU85hIOJ13ArnXMXzmNWoUSM8/fTTWLNmDb7//nv0798fV155JX788cfoXVeSKk1C0717d/fo0aMrHpeWlrobNGjgnjJlit/tr7vuOvfQoUO91vXo0cN99913u+MBvedrxowZ7ho1arjjHflJfvLJJ0G3+fOf/+w+99xzvdZdf/317kGDBrnjCS3n6uuvv1a2O3r0qDveOXjwoHIuFi9eHHCbeB+39Jwrjlne1KpVy/2vf/3LHa3ripYXDRQVFSkKc+DAgV49lOTxihUr/L5G1ntuL4jlIdD28X6+hJMnT6Jp06ZKM69gKj7eiedrK1y6dOmC7OxsXHrppVi2bBnikby8POVv7dq1A27Da0v7uRI4ZgGlpaWYPXu2YqUS91G0riuKFw0cOnRI+YLq16/vtV4eB/Kdy3o928f7+TrnnHPw5ptvYu7cuXj77beV7uC9e/fGnj17onTU9iHQtSVdXE+dOhWz47IiIlimT5+Ojz76SFlkkunbt6/iyown5Pck7sU+ffqgQ4cOAbeL53FL77mK9zFr48aNqFatmhJ3d8899+CTTz5B+/bto3ZdOa6rNLEnotg9VbsMAu3atcOrr76KyZMnx/TYiH2RCUYWz+tq+/bteP755/Gf//wH8YLEc0h8wdKlS2N9KI45V/E+Zp1zzjlKzJ1YqT788EOMGjVKiR0KJGCMhpYXDWRmZiIxMREHDhzwWi+Ps7Ky/L5G1uvZPt7Ply/Jyck477zzsG3bNpOO0r4EurYkeLBq1aoxOy670L1797i6rsaMGYPPPvsMX3/9tRJoGYx4Hrf0nqt4H7NSUlKUTMdu3bop2VoSSP/iiy9G7bqieNH4JckX9NVXX1WsExOhPA7k45P1ntsLEsUeaPt4P1++iNtJzJJi9ifexPO1ZQRytxgP15XENMtkLOb8RYsWoXnz5iFfE6/XVjjnypd4H7PKyspQWFgYvesq7FDfOGP27Nnu1NRU98yZM92bN29233XXXe6aNWu6c3Nzledvvvlm97hx4yq2X7ZsmTspKcn97LPPun/66Sf3448/7k5OTnZv3LjRHQ/oPV+TJk1yf/HFF+7t27e716xZ477hhhvcVapUcf/4449up3PixAn3unXrlEV+kv/3f/+n/H/nzp3K83Ke5Hyp/Prrr+60tDT3n/70J+XamjZtmjsxMdG9YMECt9PRe66ef/5595w5c9xbt25VfnsPPPCAOyEhwb1w4UK307n33nuVbJhvvvnGvX///oqloKCgYhuOW+Gfq3ges8aNG6dkYuXk5Lg3bNigPHa5XO7//e9/UbuuKF508NJLL7mbNGniTklJUVKBV65cWfHcJZdc4h41apTX9u+//767TZs2yvaS2vr555+74wk95+vBBx+s2LZ+/fruIUOGuNeuXeuOB9R0Xt9FPT/yV86X72u6dOminK8WLVooaZvxgN5z9cwzz7hbtmypTCq1a9d29+3b171o0SJ3PODvPMniea1w3Ar/XMXzmHXbbbe5mzZtqnz2unXrugcMGFAhXKJ1Xbnkn/DtNoQQQggh0YUxL4QQQgixFRQvhBBCCLEVFC+EEEIIsRUUL4QQQgixFRQvhBBCCLEVFC+EEEIIsRUUL4QQQgixFRQvhBBCCLEVFC+EEEIIsRUUL4QQQgixFRQvhBBCCLEVFC+EEEIIgZ34/zy5FW/c3KFoAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "from datasets import FNLVQR_Banana\n",
    "\n",
    "tensor_parameters = {}\n",
    "model\n",
    "dataset = FNLVQR_Banana(tensor_parameters)\n",
    "U = torch.randn(1000, 2).to(**tensor_parameters)\n",
    "X = dataset.sample_covariates(1).repeat(1000, 1).to(**tensor_parameters)\n",
    "model.to(X)\n",
    "_, Y_gt = dataset.sample_conditional(X)\n",
    "Y = model.push_u_given_x(U, X)\n",
    "plt.scatter(Y[:, 0], Y[:, 1])\n",
    "plt.scatter(Y_gt[:, 0], Y_gt[:, 1])\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.13.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
