{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:21:09.631692Z",
     "start_time": "2024-09-28T05:20:35.961423Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "from tqdm import trange"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:23:54.005856Z",
     "start_time": "2024-09-28T05:23:54.002680Z"
    }
   },
   "outputs": [],
   "source": [
    "def generate_image(z: torch.Tensor) -> torch.Tensor:\n",
    "    \"\"\"Generate an image from a latent vector.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    z : torch.Tensor of shape (3,)\n",
    "        The latent vector.\n",
    "        z[0] in range [-1, 1] corresponds column 8 to 24\n",
    "        z[1] in range [-1, 1] corresponds row 24 to 8\n",
    "        z[2] in range [-1, 1] corresponds edge 4 to 12\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    img : torch.Tensor of shape (32, 32)\n",
    "        The generated image.\n",
    "    \"\"\"\n",
    "\n",
    "    col = int(np.round(z[0].item() * 8 + 16))\n",
    "    row = int(np.round(16 - z[1].item() * 8))\n",
    "    edge = int(np.round(z[2].item() * 4 + 8))\n",
    "    half_edge = int(edge / 2)\n",
    "\n",
    "    img = torch.zeros(32, 32)\n",
    "    img[row - half_edge : row + half_edge, col - half_edge : col + half_edge] = 1\n",
    "    return img"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:23:54.554272Z",
     "start_time": "2024-09-28T05:23:54.133649Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x15545302a750>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 480x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.matshow(generate_image(torch.tensor([-1, 1, 1])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:23:55.026800Z",
     "start_time": "2024-09-28T05:23:54.799536Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1445\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 17/17 [00:00<00:00, 114.10it/s]\n"
     ]
    }
   ],
   "source": [
    "n_xs = 17\n",
    "n_ys = 17\n",
    "n_edges = 5\n",
    "\n",
    "print(n_xs * n_ys * n_edges)\n",
    "\n",
    "z = torch.zeros(n_xs, n_ys, n_edges, 3)\n",
    "x = torch.zeros(n_xs, n_ys, n_edges, 32, 32, dtype=torch.int8)\n",
    "valid_idx = torch.ones(n_xs, n_ys, n_edges, dtype=torch.bool)\n",
    "\n",
    "z_x = torch.linspace(-1, 1, n_xs)\n",
    "for i in trange(n_xs):\n",
    "    z_y = torch.linspace(-1, 1, n_ys)\n",
    "    for j in range(n_ys):\n",
    "        z_edge = torch.linspace(-1, 1, n_edges)\n",
    "        for k in range(n_edges):\n",
    "            if z_x[i].abs() < z_y[j].abs():\n",
    "                valid_idx[i, j, k] = False\n",
    "            else:\n",
    "                z[i, j, k] = torch.tensor([z_x[i], z_y[j], z_edge[k]])\n",
    "                x[i, j, k] = generate_image(z[i, j, k])\n",
    "\n",
    "valid_idx = valid_idx.reshape(-1)\n",
    "z = z.reshape(-1, 3)\n",
    "x = x.reshape(-1, 1, 32, 32)\n",
    "z = z[valid_idx]\n",
    "x = x[valid_idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:23:55.414046Z",
     "start_time": "2024-09-28T05:23:55.247197Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x155452f53380>]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjgAAAGdCAYAAAAfTAk2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA/3klEQVR4nO3df3gU5b3//9cKIQkeskpS8qPE1HopQeLxQpRffjD8MmJFa+0RPCoSxZxDz2UVqKg5agXPpYipmh4tWpUYr1aRVqT1XColFIntSRCBhCMYkSokaUlEUthAE0KE+f7hl8V1s/lBZnYm9z4f1zXXJbP3zmvunZ173m527/FZlmUJAADAIKe5vQMAAAB2o8ABAADGocABAADGocABAADGocABAADGocABAADGocABAADGocABAADG6e/2Drjh+PHj2rt3rwYNGiSfz+f27gAAgG6wLEuHDh1SRkaGTjut889oYrLA2bt3rzIzM93eDQAAcArq6+s1dOjQTtvEZIEzaNAgSV+9QElJSS7vDQAA6I7m5mZlZmYGr+OdickC58SfpZKSkihwAADoY7rz9RK+ZAwAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIwTkxP9OSXQ0q7bSjdpb+CIMvwJKskfLf/AOLd3CwCAqPHKtdDRT3Dee+89XX311crIyJDP59Pvfve7Lp9TXl6uUaNGKSEhQd/97nf13HPPhbVZtWqVzj//fMXHx+v888/X6tWrHdj7nsktWq8LH16rLXUH1RA4oi11B3Xhw2uVW7Te7V0DACAqvHQtdLTA+cc//qELL7xQzzzzTLfa7969W9/73vc0YcIEVVVV6T//8z915513atWqVcE2lZWVmjlzpmbNmqVt27Zp1qxZmjFjht5//32nutGl3KL1qm1q7fCx2qZWihwAgPG8di30WZZlRSXI59Pq1at17bXXRmxz77336s0331RNTU1w3dy5c7Vt2zZVVlZKkmbOnKnm5ma98847wTbTpk3TmWeeqRUrVnRrX5qbm+X3+xUIBHp9L6pAS7sufHhtl+22/TSPP1cBAIwUrWthT67fnvqScWVlpfLy8kLWXXHFFdq8ebPa29s7bVNRURFxu21tbWpubg5Z7HJb6SZb2wEA0Nd48VroqQKnsbFRqampIetSU1P15Zdfav/+/Z22aWxsjLjdJUuWyO/3B5fMzEzb9nlv4Iit7QAA6Gu8eC30VIEjhd8C/cRf0L6+vqM2nd06vbCwUIFAILjU19fbtr8Z/gRb2wEA0Nd48VroqQInLS0t7JOYffv2qX///kpOTu60zTc/1fm6+Ph4JSUlhSx2KckfbWs7AAD6Gi9eCz1V4IwbN05lZWUh69auXauLL75YcXFxnbYZP3581Pbz6/wD45SVnNhpm6zkRL5gDAAwlhevhY4WOIcPH1Z1dbWqq6slffUz8OrqatXV1Un66k9Ht9xyS7D93LlzVVtbqwULFqimpkYlJSVavny57r777mCbu+66S2vXrtXSpUv18ccfa+nSpVq3bp3mzZvnZFc6Vb5wcsQDm5WcqPKFk6O8RwAARJfXroWO/kx8w4YNmjRpUtj62bNnq7S0VPn5+dqzZ482bNgQfKy8vFzz58/Xjh07lJGRoXvvvVdz584Nef7rr7+uBx54QJ999pnOOeccPfLII7ruuuu6vV92/kz867wyeyMAAG5x8lrYk+t31ObB8RKnChwAAOCcPjsPDgAAgB0ocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHH6u70DJon2rRq4NQQAoCuxem3iVg023aoht2i9aptaw9Y7dYOxaOcBAPoe065N3KohyiIdUEmqbWpVbtH6Pp0HAOh7Yv3aRIHTS4GW9ogH9ITaplYFWtr7ZB4AoO/h2kSB02u3lW6ytZ3X8gAAfQ/XJgqcXtsbOGJrO6/lAQD6Hq5NFDi9luFPsLWd1/IAAH0P1yYKnF4ryR9tazuv5QEA+h6uTRQ4veYfGKes5MRO22QlJ9o2B0C08wAAfQ/XJgocW5QvnBzxwDox10C08wAAfU+sX5uY6M+mif6k2J0tEgDgXSZdm3py/abAsbHAAQAAzmEmYwAAENMocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHEocAAAgHH6u70DJjFpOmwv5AGAadwYR2P1WhGVWzUsW7ZMRUVFamho0IgRI1RcXKwJEyZ02DY/P18vv/xy2Przzz9fO3bskCSVlpbq1ltvDWvT2tqqhISELvfHiVs15BatV21Ta9h6p24wZnoeAJjGjXHUtGuFp27VsHLlSs2bN0/333+/qqqqNGHCBF155ZWqq6vrsP3Pf/5zNTQ0BJf6+noNHjxY119/fUi7pKSkkHYNDQ3dKm6cEOmASlJtU6tyi9aTBwAxzI1xNNavFY4XOE8++aTmzJmj22+/XcOHD1dxcbEyMzP17LPPdtje7/crLS0tuGzevFkHDhwI+8TG5/OFtEtLS3O6Kx0KtLRHPKAn1Da1KtDSTh4AxCA3xlGuFQ4XOEePHtWWLVuUl5cXsj4vL08VFRXd2sby5cs1depUZWVlhaw/fPiwsrKyNHToUE2fPl1VVVURt9HW1qbm5uaQxS63lW6ytV2s5wGAadwYR7lWOFzg7N+/X8eOHVNqamrI+tTUVDU2Nnb5/IaGBr3zzju6/fbbQ9ZnZ2ertLRUb775plasWKGEhARdeuml2rVrV4fbWbJkifx+f3DJzMw89U59w97AEVvbxXoeAJjGjXGUa0WUfibu8/lC/m1ZVti6jpSWluqMM87QtddeG7J+7Nixuvnmm3XhhRdqwoQJ+s1vfqPzzjtPTz/9dIfbKSwsVCAQCC719fWn3JdvyvB373s/3W0X63kAYBo3xlGuFQ4XOCkpKerXr1/YpzX79u0L+1TnmyzLUklJiWbNmqUBAwZ02va0007TJZdcEvETnPj4eCUlJYUsdinJH21ru1jPAwDTuDGOcq1wuMAZMGCARo0apbKyspD1ZWVlGj9+fKfPLS8v11/+8hfNmTOnyxzLslRdXa309PRe7e+p8A+MU1ZyYqdtspITbZsDwPQ8ADCNG+Mo14oo/IlqwYIFevHFF1VSUqKamhrNnz9fdXV1mjt3rqSv/nx0yy23hD1v+fLlGjNmjHJycsIeW7x4sf7whz/os88+U3V1tebMmaPq6urgNqOtfOHkiAfWibkGTM8DANO4MY7G+rXC8ZmMZ86cqaamJj388MNqaGhQTk6O3n777eCvohoaGsLmxAkEAlq1apV+/vOfd7jNgwcP6t/+7d/U2Ngov9+vkSNH6r333tPo0e79maR84eSozt5oeh4AmMaNcTSWrxVRmcnYa5yYyRgAADjLUzMZAwAARBsFDgAAMA4FDgAAMA4FDgAAMA4FDgAAMA4FDgAAMA4FDgAAMA4FDgAAMA4FDgAAMI7jt2qIJdGenpo8AOidWBjXYqGPHeFWDTbdqiG3aL1qm1rD1jt1gzHyAKB3YmFcM62P3KohyiIdUEmqbWpVbtF68jycByD2xMK4Fgt97AwFTi8FWtojHtATaptaFWhpJ8+DeQBiTyyMa7HQx65Q4PTSbaWbbG1HXnTzAMSeWBjXYqGPXaHA6aW9gSO2tiMvunkAYk8sjGux0MeuUOD0UoY/wdZ25EU3D0DsiYVxLRb62BUKnF4qyR9tazvyopsHIPbEwrgWC33sCgVOL/kHxikrObHTNlnJibbNAUCevXkAYk8sjGux0MeuUODYoHzh5IgH1om5BshjHhwAvRML41os9LEzTPRn00R/kvmzRZqeByD2xMK4ZlIfe3L9psCxscABAADOYSZjAAAQ0yhwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcfq7vQMmMWk67FjMcysTwEmmjzOxMK55ZRyNyq0ali1bpqKiIjU0NGjEiBEqLi7WhAkTOmy7YcMGTZo0KWx9TU2NsrOzg/9etWqVHnzwQX366ac655xz9Mgjj+gHP/hBt/bHiVs15BatV21Ta9h6p24wRp793MgEcJLp40wsjGtO53nqVg0rV67UvHnzdP/996uqqkoTJkzQlVdeqbq6uk6ft3PnTjU0NASXc889N/hYZWWlZs6cqVmzZmnbtm2aNWuWZsyYoffff9/p7nQo0gGVpNqmVuUWrSfPw3luZQI4yfRxJhbGNa+No44XOE8++aTmzJmj22+/XcOHD1dxcbEyMzP17LPPdvq8IUOGKC0tLbj069cv+FhxcbEuv/xyFRYWKjs7W4WFhZoyZYqKi4sd7k24QEt7xAN6Qm1TqwIt7eR5MM+tTAAnmT7OxMK45sVx1NEC5+jRo9qyZYvy8vJC1ufl5amioqLT544cOVLp6emaMmWK3n333ZDHKisrw7Z5xRVXRNxmW1ubmpubQxa73Fa6ydZ25EU3z61MACeZPs7EwrjmxXHU0QJn//79OnbsmFJTU0PWp6amqrGxscPnpKen6/nnn9eqVav0xhtvaNiwYZoyZYree++9YJvGxsYebXPJkiXy+/3BJTMzs5c9O2lv4Iit7ciLbp5bmQBOMn2ciYVxzYvjaFR+Ju7z+UL+bVlW2LoThg0bpoKCAl100UUaN26cli1bpquuuko/+9nPTnmbhYWFCgQCwaW+vr4XvQmV4U+wtR150c1zKxPASaaPM7EwrnlxHHW0wElJSVG/fv3CPlnZt29f2CcwnRk7dqx27doV/HdaWlqPthkfH6+kpKSQxS4l+aNtbUdedPPcygRwkunjTCyMa14cRx0tcAYMGKBRo0aprKwsZH1ZWZnGjx/f7e1UVVUpPT09+O9x48aFbXPt2rU92qZd/APjlJWc2GmbrORE2+YAIM/ePLcyAZxk+jgTC+OaF8dRx/9EtWDBAr344osqKSlRTU2N5s+fr7q6Os2dO1fSV38+uuWWW4Lti4uL9bvf/U67du3Sjh07VFhYqFWrVumOO+4Itrnrrru0du1aLV26VB9//LGWLl2qdevWad68eU53p0PlCydHPLBOzDVAnv1zN7iRCeAk08eZWBjXvDaORm2iv8cff1wNDQ3KycnRU089pcsuu0ySlJ+frz179mjDhg2SpMcff1zPP/+8/va3vykxMVEjRoxQYWGhvve974Vs8/XXX9cDDzygzz77LDjR33XXXdet/XFioj/J/NkiTc9zKxPASaaPM7EwrjmZ15Prd1QKHK9xqsABAADO8dRMxgAAANFGgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIxDgQMAAIzT3+0dMIlJ02HHYp4bmdwaAl5n+jlhep4bmV4Z17hVg023asgtWq/aptaw9U7dYIw8+8VCH4GeMP2cMD3PjUyn87hVQ5RFOqCSVNvUqtyi9eR5OM+NTDf6CPSE6eeE6XluZHptXKPA6aVAS3vEA3pCbVOrAi3t5Hkwz41MN/oI9ITp54TpeW5kenFco8DppdtKN9najrzo5rmR6UYfgZ4w/ZwwPc+NTC+OaxQ4vbQ3cMTWduRFN8+NTDf6CPSE6eeE6XluZHpxXKPA6aUMf4Kt7ciLbp4bmW70EegJ088J0/PcyPTiuEaB00sl+aNtbUdedPPcyHSjj0BPmH5OmJ7nRqYXxzUKnF7yD4xTVnJip22ykhNtmwOAPHvz3Mh0o49AT5h+Tpie50amF8c1ChwblC+cHPHAOjHXAHn2z90QC30EesL0c8L0PDcyvTauMdGfTRP9SebPFml6nhuZXpnxE4jE9HPC9Dw3Mp3M68n1mwLHxgIHAAA4h5mMAQBATKPAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxunv9g6YxKTpsGMxz41M0/NgP9PfM+T1/UyvjDNRuVXDsmXLVFRUpIaGBo0YMULFxcWaMGFCh23feOMNPfvss6qurlZbW5tGjBihRYsW6Yorrgi2KS0t1a233hr23NbWViUkJHS5P07cqiG3aL1qm1rD1jt1gzHy7Gd6H914TWEv098z5NnPtD566lYNK1eu1Lx583T//ferqqpKEyZM0JVXXqm6uroO27/33nu6/PLL9fbbb2vLli2aNGmSrr76alVVVYW0S0pKUkNDQ8jSneLGCZEOqCTVNrUqt2g9eR7OcyPT9DzYz/T3DHmMa3ZzvMB58sknNWfOHN1+++0aPny4iouLlZmZqWeffbbD9sXFxbrnnnt0ySWX6Nxzz9Wjjz6qc889V//zP/8T0s7n8yktLS1kcUOgpT3iAT2htqlVgZZ28jyY50am6Xmwn+nvGfIY15zgaIFz9OhRbdmyRXl5eSHr8/LyVFFR0a1tHD9+XIcOHdLgwYND1h8+fFhZWVkaOnSopk+fHvYJz9e1tbWpubk5ZLHLbaWbbG1HXnTz3Mg0PQ/2M/09Q569eW5kenGccbTA2b9/v44dO6bU1NSQ9ampqWpsbOzWNp544gn94x//0IwZM4LrsrOzVVpaqjfffFMrVqxQQkKCLr30Uu3atavDbSxZskR+vz+4ZGZmnnqnvmFv4Iit7ciLbp4bmabnwX6mv2fIszfPjUwvjjNR+Zm4z+cL+bdlWWHrOrJixQotWrRIK1eu1JAhQ4Lrx44dq5tvvlkXXnihJkyYoN/85jc677zz9PTTT3e4ncLCQgUCgeBSX1/fuw59TYa/e9/76W478qKb50am6Xmwn+nvGfLszXMj04vjjKMFTkpKivr16xf2ac2+ffvCPtX5ppUrV2rOnDn6zW9+o6lTp3ba9rTTTtMll1wS8ROc+Ph4JSUlhSx2KckfbWs78qKb50am6Xmwn+nvGfLszXMj04vjjKMFzoABAzRq1CiVlZWFrC8rK9P48eMjPm/FihXKz8/Xq6++qquuuqrLHMuyVF1drfT09F7vc0/5B8YpKzmx0zZZyYm2zQFAnr15bmSangf7mf6eIY9xzQmO/4lqwYIFevHFF1VSUqKamhrNnz9fdXV1mjt3rqSv/nx0yy23BNuvWLFCt9xyi5544gmNHTtWjY2NamxsVCAQCLZZvHix/vCHP+izzz5TdXW15syZo+rq6uA2o6184eSIB9aJuQbIs3/uBtP76MZrCnuZ/p4hj3HNblGb6O/xxx9XQ0ODcnJy9NRTT+myyy6TJOXn52vPnj3asGGDJGnixIkqLy8P28bs2bNVWloqSZo/f77eeOMNNTY2yu/3a+TIkVq0aJHGjRvXrf1xYqI/yfzZIk3PcyPT9DzYz/T3DHl9P9PJvJ5cv6NS4HiNUwUOAABwjqdmMgYAAIg2ChwAAGAcChwAAGAcChwAAGAcChwAAGAcChwAAGAcChwAAGAcChwAAGAcChwAAGCc/m7vgElMmg47FvPcyCSv7zP9NSWvb+e5kemV855bNdh0q4bcovWqbWoNW+/UDcbIs5/pfTQ9zw2mv6bk9e08NzKdzuNWDVEW6YBKUm1Tq3KL1pPn4Tw3Msmz/xhGm+mvKXl9O8+NTK+d9xQ4vRRoaY94QE+obWpVoKWdPA/muZFJnv3HMNpMf03J69t5bmR68bynwOml20o32dqOvOjmuZFJnr15bjD9NSWvb+e5kenF854Cp5f2Bo7Y2o686Oa5kUmevXluMP01Ja9v57mR6cXzngKnlzL8Cba2Iy+6eW5kkmdvnhtMf03J69t5bmR68bynwOmlkvzRtrYjL7p5bmSSZ2+eG0x/Tcnr23luZHrxvKfA6SX/wDhlJSd22iYrOdG2OQDIszfPjUzy7D+G0Wb6a0pe385zI9OL5z0Fjg3KF06OeGCdmGuAPPvnbjC9j6bnucH015S8vp3nRqbXznsm+rNpoj/J/NkiTc9zI5O8vs/015S8vp3nRqaTeT25flPg2FjgAAAA5zCTMQAAiGkUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDj93d4Bk5g0HXYs5rmRSV7fznMjkzzyvJ7plVu0ROVWDcuWLVNRUZEaGho0YsQIFRcXa8KECRHbl5eXa8GCBdqxY4cyMjJ0zz33aO7cuSFtVq1apQcffFCffvqpzjnnHD3yyCP6wQ9+0K39ceJWDblF61Xb1Bq23qkbjJFnP9P7SJ79TO8jeX07z41Mp/M8dauGlStXat68ebr//vtVVVWlCRMm6Morr1RdXV2H7Xfv3q3vfe97mjBhgqqqqvSf//mfuvPOO7Vq1apgm8rKSs2cOVOzZs3Stm3bNGvWLM2YMUPvv/++093pUKQDKkm1Ta3KLVpPnofz3Mgkr2/nuZFJHnlez3Sjj51xvMB58sknNWfOHN1+++0aPny4iouLlZmZqWeffbbD9s8995zOOussFRcXa/jw4br99tt122236Wc/+1mwTXFxsS6//HIVFhYqOztbhYWFmjJlioqLi53uTphAS3vEA3pCbVOrAi3t5Hkwz41M8vp2nhuZ5JHn9Uw3+tgVRwuco0ePasuWLcrLywtZn5eXp4qKig6fU1lZGdb+iiuu0ObNm9Xe3t5pm0jbbGtrU3Nzc8hil9tKN9najrzo5rmRSV7fznMjkzzyvJ7pRh+74miBs3//fh07dkypqakh61NTU9XY2NjhcxobGzts/+WXX2r//v2dtom0zSVLlsjv9weXzMzMU+1SmL2BI7a2Iy+6eW5kkte389zIJI88r2e60ceuROVn4j6fL+TflmWFreuq/TfX92SbhYWFCgQCwaW+vr5H+9+ZDH+Cre3Ii26eG5nk9e08NzLJI8/rmW70sSuOFjgpKSnq169f2Ccr+/btC/sE5oS0tLQO2/fv31/Jycmdtom0zfj4eCUlJYUsdinJH21rO/Kim+dGJnl9O8+NTPLI83qmG33siqMFzoABAzRq1CiVlZWFrC8rK9P48eM7fM64cePC2q9du1YXX3yx4uLiOm0TaZtO8g+MU1ZyYqdtspITbZsDgDx789zIJK9v57mRSR55Xs90o49dcfxPVAsWLNCLL76okpIS1dTUaP78+aqrqwvOa1NYWKhbbrkl2H7u3Lmqra3VggULVFNTo5KSEi1fvlx33313sM1dd92ltWvXaunSpfr444+1dOlSrVu3TvPmzXO6Ox0qXzg54oF1Yq4B8uyfu8H0PpLHe4a82MpzI9ONPnYmahP9Pf7442poaFBOTo6eeuopXXbZZZKk/Px87dmzRxs2bAi2Ly8v1/z584MT/d17771hE/29/vrreuCBB/TZZ58FJ/q77rrrurU/Tkz0J5k/W6TpeW5kkte389zIJI88r2c6mdeT63dUChyvcarAAQAAzvHUTMYAAADRRoEDAACMQ4EDAACMQ4EDAACMQ4EDAACMQ4EDAACMQ4EDAACMQ4EDAACMQ4EDAACM09/tHTCJSdNhx2KeG5nk9X2mv6bk9e08NzK9ct5zqwabbtWQW7RetU2tYeudusEYefYzvY+m57nB9NeUvL6d50am03ncqiHKIh1QSaptalVu0XryPJznRiZ59h/DaDP9NSWvb+e5kem1854Cp5cCLe0RD+gJtU2tCrS0k+fBPDcyybP/GEab6a8peX07z41ML573FDi9dFvpJlvbkRfdPDcyybM3zw2mv6bk9e08NzK9eN5T4PTS3sARW9uRF908NzLJszfPDaa/puT17Tw3Mr143lPg9FKGP8HWduRFN8+NTPLszXOD6a8peX07z41ML573FDi9VJI/2tZ25EU3z41M8uzNc4Ppryl5fTvPjUwvnvcUOL3kHxinrOTETttkJSfaNgcAefbmuZFJnv3HMNpMf03J69t5bmR68bynwLFB+cLJEQ+sE3MNkGf/3A2m99H0PDeY/pqS17fz3Mj02nnPRH82TfQnmT9bpOl5bmSS1/eZ/pqS17fz3Mh0Mq8n128KHBsLHAAA4BxmMgYAADGNAgcAABiHAgcAABiHAgcAABiHAgcAABiHAgcAABiHAgcAABiHAgcAABiHAgcAABinv9s7YBKTpsOOxTw3Mk3Pg/1Mf8+Q1/czvTLOOHqrhgMHDujOO+/Um2++KUm65ppr9PTTT+uMM87osH17e7seeOABvf322/rss8/k9/s1depUPfbYY8rIyAi2mzhxosrLy0OeO3PmTL322mvd2i8nbtWQW7RetU2tYeudusEYefYzvY9uvKawl+nvGfLsZ1ofPXOrhhtvvFHV1dVas2aN1qxZo+rqas2aNSti+5aWFm3dulUPPvigtm7dqjfeeEOffPKJrrnmmrC2BQUFamhoCC6//OUvnexKpyIdUEmqbWpVbtF68jyc50am6Xmwn+nvGfIY1+zm2J+oampqtGbNGm3cuFFjxoyRJL3wwgsaN26cdu7cqWHDhoU9x+/3q6ysLGTd008/rdGjR6uurk5nnXVWcP3AgQOVlpbm1O53W6ClPeIBPaG2qVWBlnZbPqIjz948NzJNz4P9TH/PkMe45gTHPsGprKyU3+8PFjeSNHbsWPn9flVUVHR7O4FAQD6fL+zPWq+88opSUlI0YsQI3X333Tp06FDEbbS1tam5uTlkscttpZtsbUdedPPcyDQ9D/Yz/T1Dnr15bmR6cZxx7BOcxsZGDRkyJGz9kCFD1NjY2K1tHDlyRPfdd59uvPHGkL+13XTTTTr77LOVlpam7du3q7CwUNu2bQv79OeEJUuWaPHixafWkS7sDRyxtR150c1zI9P0PNjP9PcMefbmuZHpxXGmx5/gLFq0SD6fr9Nl8+bNkiSfzxf2fMuyOlz/Te3t7brhhht0/PhxLVu2LOSxgoICTZ06VTk5Obrhhhv0+uuva926ddq6dWuH2yosLFQgEAgu9fX1Pe12RBn+BFvbkRfdPDcyTc+D/Ux/z5Bnb54bmV4cZ3pc4Nxxxx2qqanpdMnJyVFaWpo+//zzsOd/8cUXSk1N7TSjvb1dM2bM0O7du1VWVtblN6UvuugixcXFadeuXR0+Hh8fr6SkpJDFLiX5o21tR15089zIND0P9jP9PUOevXluZHpxnOlxgZOSkqLs7OxOl4SEBI0bN06BQECbNp38e9v777+vQCCg8ePHR9z+ieJm165dWrdunZKTk7vcpx07dqi9vV3p6ek97U6v+QfGKSs5sdM2WcmJtn2pijx789zIND0P9jP9PUMe45oTHPuS8fDhwzVt2jQVFBRo48aN2rhxowoKCjR9+vSQX1BlZ2dr9erVkqQvv/xS//Iv/6LNmzfrlVde0bFjx9TY2KjGxkYdPXpUkvTpp5/q4Ycf1ubNm7Vnzx69/fbbuv766zVy5EhdeumlTnWnU+ULJ0c8sE7MNUCe/XM3mN5HN15T2Mv09wx5jGt2c3Siv7///e9hE/0988wzIb+I8vl8eumll5Sfn689e/bo7LPP7nBb7777riZOnKj6+nrdfPPN2r59uw4fPqzMzExdddVVeuihhzR48OBu7ZcTE/1J5s8WaXqeG5mm58F+pr9nyOv7mU7m9eT67WiB41VOFTgAAMA5npnJGAAAwA0UOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDgUOAAAwDj93d4Bk5g0HXYs5rmRya0T4HWmnxOm57mR6ZVxjVs12HSrhtyi9aptag1b79QNxsizXyz0EegJ088J0/PcyHQ6j1s1RFmkAypJtU2tyi1aT56H89zIdKOPQE+Yfk6YnudGptfGNQqcXgq0tEc8oCfUNrUq0NJOngfz3Mh0o49AT5h+Tpie50amF8c1Cpxeuq10k63tyItunhuZbvQR6AnTzwnT89zI9OK4RoHTS3sDR2xtR15089zIdKOPQE+Yfk6YnudGphfHNQqcXsrwJ9jajrzo5rmR6UYfgZ4w/ZwwPc+NTC+OaxQ4vVSSP9rWduRFN8+NTDf6CPSE6eeE6XluZHpxXKPA6SX/wDhlJSd22iYrOdG2OQDIszfPjUw3+gj0hOnnhOl5bmR6cVyjwLFB+cLJEQ+sE3MNkGf/3A2x0EegJ0w/J0zPcyPTa+MaE/3ZNNGfZP5skabnuZHplRk/gUhMPydMz3Mj08m8nly/KXBsLHAAAIBzmMkYAADENAocAABgHAocAABgHAocAABgHAocAABgHAocAABgHAocAABgHAocAABgHAocAABgnP5u74BJTJoOOxbz3MoEcJLp40wsjGteGUcdvVXDgQMHdOedd+rNN9+UJF1zzTV6+umndcYZZ0R8Tn5+vl5++eWQdWPGjNHGjRuD/25ra9Pdd9+tFStWqLW1VVOmTNGyZcs0dOjQbu2XE7dqyC1ar9qm1rD1Tt1gjDz7uZEJ4CTTx5lYGNeczvPMrRpuvPFGVVdXa82aNVqzZo2qq6s1a9asLp83bdo0NTQ0BJe333475PF58+Zp9erVeu211/TnP/9Zhw8f1vTp03Xs2DGnutKpSAdUkmqbWpVbtJ48D+e5lQngJNPHmVgY17w2jjr2J6qamhqtWbNGGzdu1JgxYyRJL7zwgsaNG6edO3dq2LBhEZ8bHx+vtLS0Dh8LBAJavny5fvWrX2nq1KmSpF//+tfKzMzUunXrdMUVV9jfmU4EWtojHtATaptaFWhpt+UjOvLszXMrE8BJpo8zsTCueXEcdewTnMrKSvn9/mBxI0ljx46V3+9XRUVFp8/dsGGDhgwZovPOO08FBQXat29f8LEtW7aovb1deXl5wXUZGRnKycmJuN22tjY1NzeHLHa5rXSTre3Ii26eW5kATjJ9nImFcc2L46hjBU5jY6OGDBkStn7IkCFqbGyM+Lwrr7xSr7zyitavX68nnnhCH3zwgSZPnqy2trbgdgcMGKAzzzwz5HmpqakRt7tkyRL5/f7gkpmZ2YuehdobOGJrO/Kim+dWJoCTTB9nYmFc8+I42uMCZ9GiRfL5fJ0umzdvliT5fL6w51uW1eH6E2bOnKmrrrpKOTk5uvrqq/XOO+/ok08+0VtvvdXpfnW23cLCQgUCgeBSX1/fgx53LsOfYGs78qKb51YmgJNMH2diYVzz4jja4wLnjjvuUE1NTadLTk6O0tLS9Pnnn4c9/4svvlBqamq389LT05WVlaVdu3ZJktLS0nT06FEdOHAgpN2+ffsibjc+Pl5JSUkhi11K8kfb2o686Oa5lQngJNPHmVgY17w4jva4wElJSVF2dnanS0JCgsaNG6dAIKBNm07+ve39999XIBDQ+PHju53X1NSk+vp6paenS5JGjRqluLg4lZWVBds0NDRo+/btPdquXfwD45SVnNhpm6zkRNu+VEWevXluZQI4yfRxJhbGNS+Oo459B2f48OGaNm2aCgoKtHHjRm3cuFEFBQWaPn16yC+osrOztXr1aknS4cOHdffdd6uyslJ79uzRhg0bdPXVVyslJUU/+MEPJEl+v19z5szRT37yE/3xj39UVVWVbr75Zl1wwQXBX1VFW/nCyREPrBNzDZBn/9wNbmQCOMn0cSYWxjWvjaOOTvT397//PWyiv2eeeSZkoj+fz6eXXnpJ+fn5am1t1bXXXquqqiodPHhQ6enpmjRpkv7rv/4r5IvBR44c0cKFC/Xqq6+GTPTX3S8POzHRn2T+bJGm57mVCeAk08eZWBjXnMzryfXb0QLHq5wqcAAAgHM8M5MxAACAGyhwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcShwAACAcfq7vQMmMWk67FjMAxB7YmFci4U+doRbNdh0q4bcovWqbWoNW+/UDcbIA4DeiYVxzbQ+cquGKIt0QCWptqlVuUXryfNwHoDYEwvjWiz0sTMUOL0UaGmPeEBPqG1qVaClnTwP5gGIPbEwrsVCH7tCgdNLt5VusrUdedHNAxB7YmFci4U+doUCp5f2Bo7Y2o686OYBiD2xMK7FQh+7QoHTSxn+BFvbkRfdPACxJxbGtVjoY1cocHqpJH+0re3Ii24egNgTC+NaLPSxKxQ4veQfGKes5MRO22QlJ9o2BwB59uYBiD2xMK7FQh+7QoFjg/KFkyMeWCfmGiCPeXAA9E4sjGux0MfOMNGfTRP9SebPFml6HoDYEwvjmkl97Mn1mwLHxgIHAAA4h5mMAQBATKPAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxqHAAQAAxunv9g6YxKTpsL2QBwCm4VYN0ePorRoOHDigO++8U2+++aYk6ZprrtHTTz+tM844I/IO+Xwdrn/88ce1cOFCSdLEiRNVXl4e8vjMmTP12muvdWu/nLhVQ27RetU2tYatd+oGY6bnAYBp3BhHTbtWeOZWDTfeeKOqq6u1Zs0arVmzRtXV1Zo1a1anz2loaAhZSkpK5PP59MMf/jCkXUFBQUi7X/7yl052pVORDqgk1Ta1KrdoPXkAEMPcGEdj/Vrh2J+oampqtGbNGm3cuFFjxoyRJL3wwgsaN26cdu7cqWHDhnX4vLS0tJB///73v9ekSZP03e9+N2T9wIEDw9q6IdDSHvGAnlDb1KpAS7stH9GZngcApnFjHOVa4eAnOJWVlfL7/cHiRpLGjh0rv9+vioqKbm3j888/11tvvaU5c+aEPfbKK68oJSVFI0aM0N13361Dhw5F3E5bW5uam5tDFrvcVrrJ1naxngcApnFjHOVa4eAnOI2NjRoyZEjY+iFDhqixsbFb23j55Zc1aNAgXXfddSHrb7rpJp199tlKS0vT9u3bVVhYqG3btqmsrKzD7SxZskSLFy/ueSe6YW/giK3tYj0PAEzjxjjKteIUPsFZtGiRfD5fp8vmzZsldfyFYcuyIn6R+JtKSkp00003KSEhIWR9QUGBpk6dqpycHN1www16/fXXtW7dOm3durXD7RQWFioQCASX+vr6HvY6sgx/QteNetAu1vMAwDRujKNcK06hwLnjjjtUU1PT6ZKTk6O0tDR9/vnnYc//4osvlJqa2mXOn/70J+3cuVO33357l20vuugixcXFadeuXR0+Hh8fr6SkpJDFLiX5o21tF+t5AGAaN8ZRrhWn8CeqlJQUpaSkdNlu3LhxCgQC2rRpk0aP/qpD77//vgKBgMaPH9/l85cvX65Ro0bpwgsv7LLtjh071N7ervT09K47YDP/wDhlJSd2+uWqrORE275UZXoeAJjGjXGUa4WDXzIePny4pk2bpoKCAm3cuFEbN25UQUGBpk+fHvILquzsbK1evTrkuc3Nzfrtb3/b4ac3n376qR5++GFt3rxZe/bs0dtvv63rr79eI0eO1KWXXupUdzpVvnCyspITO3zMibkGTM8DANO4MY7G+rXC0Yn+/v73v4dN9PfMM8+ETPTn8/n00ksvKT8/P7ju+eef17x589TQ0CC/3x+yzfr6et18883avn27Dh8+rMzMTF111VV66KGHNHjw4G7tlxMT/UnmzxbpldkpAaCvYibj3unJ9dvRAsernCpwAACAczwzkzEAAIAbKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxenyzTURm0nTYAAAzxOq1iVs12HSrhtyi9R3eRdWpG4xFOw8A0PeYdm3iVg1RFumASlJtU6tyi9b36TwAQN8T69cmCpxeCrS0RzygJ9Q2tSrQ0t4n8wAAfQ/XJgqcXrutdJOt7byWBwDoe7g2UeD02t7AEVvbeS0PAND3cG2iwOm1DH+Cre28lgcA6Hu4NlHg9FpJ/mhb23ktDwDQ93BtosDpNf/AOGUlJ3baJis50bY5AKKdBwDoe7g2UeDYonzh5IgH1om5BqKdBwDoe2L92sREfzZN9CfF7myRAADvMuna1JPrNwWOjQUOAABwDjMZAwCAmEaBAwAAjEOBAwAAjEOBAwAAjEOBAwAAjEOBAwAAjEOBAwAAjEOBAwAAjEOBAwAAjNPf7R0wCbdOAADEOq9cCx39BOeRRx7R+PHjNXDgQJ1xxhndeo5lWVq0aJEyMjKUmJioiRMnaseOHSFt2tra9OMf/1gpKSk6/fTTdc011+ivf/2rAz3ovtyi9brw4bXaUndQDYEj2lJ3UBc+vFa5Retd3S8AAKLFS9dCRwuco0eP6vrrr9ePfvSjbj/n8ccf15NPPqlnnnlGH3zwgdLS0nT55Zfr0KFDwTbz5s3T6tWr9dprr+nPf/6zDh8+rOnTp+vYsWNOdKNLuUXrVdvU2uFjtU2tFDkAAON57VroaIGzePFizZ8/XxdccEG32luWpeLiYt1///267rrrlJOTo5dfflktLS169dVXJUmBQEDLly/XE088oalTp2rkyJH69a9/rQ8//FDr1q1zsjsdCrS0RzygJ9Q2tSrQ0h6lPQIAILq8eC301JeMd+/ercbGRuXl5QXXxcfHKzc3VxUVFZKkLVu2qL29PaRNRkaGcnJygm2+qa2tTc3NzSGLXW4r3WRrOwAA+hovXgs9VeA0NjZKklJTU0PWp6amBh9rbGzUgAEDdOaZZ0Zs801LliyR3+8PLpmZmbbt897AEVvbAQDQ13jxWtjjAmfRokXy+XydLps3b+7VTvl8vpB/W5YVtu6bOmtTWFioQCAQXOrr63u1f1+X4U+wtR0AAH2NF6+FPf6Z+B133KEbbrih0zbf+c53Tmln0tLSJH31KU16enpw/b59+4Kf6qSlpeno0aM6cOBAyKc4+/bt0/jx4zvcbnx8vOLj409pn7pSkj9aFz68tlvtAAAwkRevhT0ucFJSUpSSkuLEvujss89WWlqaysrKNHLkSElf/RKrvLxcS5culSSNGjVKcXFxKisr04wZMyRJDQ0N2r59ux5//HFH9qsz/oFxykpO7PTLVVnJicyHAwAwlhevhY5+B6eurk7V1dWqq6vTsWPHVF1drerqah0+fDjYJjs7W6tXr5b01Z+m5s2bp0cffVSrV6/W9u3blZ+fr4EDB+rGG2+UJPn9fs2ZM0c/+clP9Mc//lFVVVW6+eabdcEFF2jq1KlOdiei8oWTlZWc2OFjWcmJKl84Ocp7BABAdHntWujoTMY//elP9fLLLwf/feJTmXfffVcTJ06UJO3cuVOBQCDY5p577lFra6v+4z/+QwcOHNCYMWO0du1aDRo0KNjmqaeeUv/+/TVjxgy1trZqypQpKi0tVb9+/ZzsTqfKF072zOyNAAC4wUvXQp9lWVbUU13W3Nwsv9+vQCCgpKQkt3cHAAB0Q0+u3576mTgAAIAdKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxKHAAAIBxHL1Vg1edmLy5ubnZ5T0BAADddeK63Z2bMMRkgXPo0CFJUmZmpst7AgAAeurQoUPy+/2dtonJe1EdP35ce/fu1aBBg+Tz+WzddnNzszIzM1VfX2/kfa5M759kfh/pX99neh/pX9/nVB8ty9KhQ4eUkZGh007r/Fs2MfkJzmmnnaahQ4c6mpGUlGTsG1cyv3+S+X2kf32f6X2kf32fE33s6pObE/iSMQAAMA4FDgAAMA4Fjs3i4+P10EMPKT4+3u1dcYTp/ZPM7yP96/tM7yP96/u80MeY/JIxAAAwG5/gAAAA41DgAAAA41DgAAAA41DgAAAA41Dg9NAjjzyi8ePHa+DAgTrjjDO69RzLsrRo0SJlZGQoMTFREydO1I4dO0LatLW16cc//rFSUlJ0+umn65prrtFf//pXB3rQuQMHDmjWrFny+/3y+/2aNWuWDh482OlzfD5fh0tRUVGwzcSJE8Mev+GGGxzuTcdOpY/5+flh+z927NiQNn31GLa3t+vee+/VBRdcoNNPP10ZGRm65ZZbtHfv3pB2bh7DZcuW6eyzz1ZCQoJGjRqlP/3pT522Ly8v16hRo5SQkKDvfve7eu6558LarFq1Sueff77i4+N1/vnna/Xq1U7tfpd60r833nhDl19+ub71rW8pKSlJ48aN0x/+8IeQNqWlpR2ek0eOHHG6Kx3qSf82bNjQ4b5//PHHIe28dPyknvWxo/HE5/NpxIgRwTZeOobvvfeerr76amVkZMjn8+l3v/tdl8/xxDlooUd++tOfWk8++aS1YMECy+/3d+s5jz32mDVo0CBr1apV1ocffmjNnDnTSk9Pt5qbm4Nt5s6da33729+2ysrKrK1bt1qTJk2yLrzwQuvLL790qCcdmzZtmpWTk2NVVFRYFRUVVk5OjjV9+vROn9PQ0BCylJSUWD6fz/r000+DbXJzc62CgoKQdgcPHnS6Ox06lT7Onj3bmjZtWsj+NzU1hbTpq8fw4MGD1tSpU62VK1daH3/8sVVZWWmNGTPGGjVqVEg7t47ha6+9ZsXFxVkvvPCC9dFHH1l33XWXdfrpp1u1tbUdtv/ss8+sgQMHWnfddZf10UcfWS+88IIVFxdnvf7668E2FRUVVr9+/axHH33UqqmpsR599FGrf//+1saNGx3vzzf1tH933XWXtXTpUmvTpk3WJ598YhUWFlpxcXHW1q1bg21eeuklKykpKezcdENP+/fuu+9akqydO3eG7PvXzyMvHT/L6nkfDx48GNK3+vp6a/DgwdZDDz0UbOOlY/j2229b999/v7Vq1SpLkrV69epO23vlHKTAOUUvvfRStwqc48ePW2lpadZjjz0WXHfkyBHL7/dbzz33nGVZX73Z4+LirNdeey3Y5m9/+5t12mmnWWvWrLF93yP56KOPLEkhb7DKykpLkvXxxx93ezvf//73rcmTJ4esy83Nte666y67dvWUnWofZ8+ebX3/+9+P+Lhpx3DTpk2WpJAB2q1jOHr0aGvu3Lkh67Kzs6377ruvw/b33HOPlZ2dHbLu3//9362xY8cG/z1jxgxr2rRpIW2uuOIK64YbbrBpr7uvp/3ryPnnn28tXrw4+O/ujk/R0NP+nShwDhw4EHGbXjp+ltX7Y7h69WrL5/NZe/bsCa7z0jH8uu4UOF45B/kTlcN2796txsZG5eXlBdfFx8crNzdXFRUVkqQtW7aovb09pE1GRoZycnKCbaKhsrJSfr9fY8aMCa4bO3as/H5/t/fj888/11tvvaU5c+aEPfbKK68oJSVFI0aM0N133x28q3s09aaPGzZs0JAhQ3TeeeepoKBA+/btCz5m0jGUpEAgIJ/PF/Zn2Ggfw6NHj2rLli0hr6sk5eXlRexPZWVlWPsrrrhCmzdvVnt7e6dtonmspFPr3zcdP35chw4d0uDBg0PWHz58WFlZWRo6dKimT5+uqqoq2/a7u3rTv5EjRyo9PV1TpkzRu+++G/KYV46fZM8xXL58uaZOnaqsrKyQ9V44hqfCK+dgTN5sM5oaGxslSampqSHrU1NTVVtbG2wzYMAAnXnmmWFtTjw/GhobGzVkyJCw9UOGDOn2frz88ssaNGiQrrvuupD1N910k84++2ylpaVp+/btKiws1LZt21RWVmbLvnfXqfbxyiuv1PXXX6+srCzt3r1bDz74oCZPnqwtW7YoPj7eqGN45MgR3XfffbrxxhtDbpLnxjHcv3+/jh071uH5E6k/jY2NHbb/8ssvtX//fqWnp0dsE81jJZ1a/77piSee0D/+8Q/NmDEjuC47O1ulpaW64IIL1NzcrJ///Oe69NJLtW3bNp177rm29qEzp9K/9PR0Pf/88xo1apTa2tr0q1/9SlOmTNGGDRt02WWXSYp8jKN9/KTeH8OGhga98847evXVV0PWe+UYngqvnIMUOJIWLVqkxYsXd9rmgw8+0MUXX3zKGT6fL+TflmWFrfum7rTpju72Twrfz57uR0lJiW666SYlJCSErC8oKAj+d05Ojs4991xdfPHF2rp1qy666KJubbszTvdx5syZwf/OycnRxRdfrKysLL311lthxVxPtttd0TqG7e3tuuGGG3T8+HEtW7Ys5DGnj2Fnenr+dNT+m+tP5Zx0yqnuy4oVK7Ro0SL9/ve/Dylsx44dG/Il+EsvvVQXXXSRnn76af33f/+3fTveTT3p37BhwzRs2LDgv8eNG6f6+nr97Gc/CxY4Pd1mNJzq/pSWluqMM87QtddeG7Lea8ewp7xwDlLgSLrjjju6/DXId77znVPadlpamqSvKtr09PTg+n379gWr17S0NB09elQHDhwI+QRg3759Gj9+/Cnlfl13+/d///d/+vzzz8Me++KLL8Iq7Y786U9/0s6dO7Vy5cou21500UWKi4vTrl27bLk4RquPJ6SnpysrK0u7du2SZMYxbG9v14wZM7R7926tX78+5NObjth9DDuSkpKifv36hf1f3dfPn29KS0vrsH3//v2VnJzcaZuevAfscCr9O2HlypWaM2eOfvvb32rq1Kmdtj3ttNN0ySWXBN+v0dKb/n3d2LFj9etf/zr4b68cP6l3fbQsSyUlJZo1a5YGDBjQaVu3juGp8Mw5aNu3eWJMT79kvHTp0uC6tra2Dr9kvHLlymCbvXv3uvYF1ffffz+4buPGjd3+gurs2bPDfnkTyYcffmhJssrLy095f09Fb/t4wv79+634+Hjr5Zdftiyr7x/Do0ePWtdee601YsQIa9++fd3KitYxHD16tPWjH/0oZN3w4cM7/ZLx8OHDQ9bNnTs37AuOV155ZUibadOmufYl4570z7Is69VXX7USEhK6/LLnCcePH7cuvvhi69Zbb+3Nrp6SU+nfN/3whz+0Jk2aFPy3l46fZZ16H098ofrDDz/sMsPNY/h16uaXjL1wDlLg9FBtba1VVVVlLV682Pqnf/onq6qqyqqqqrIOHToUbDNs2DDrjTfeCP77scces/x+v/XGG29YH374ofWv//qvHf5MfOjQoda6deusrVu3WpMnT3btJ8b//M//bFVWVlqVlZXWBRdcEPYT42/2z7IsKxAIWAMHDrSeffbZsG3+5S9/sRYvXmx98MEH1u7du6233nrLys7OtkaOHBn1/llWz/t46NAh6yc/+YlVUVFh7d6923r33XetcePGWd/+9reNOIbt7e3WNddcYw0dOtSqrq4O+UlqW1ubZVnuHsMTP8Fdvny59dFHH1nz5s2zTj/99OAvTu677z5r1qxZwfYnfqI6f/5866OPPrKWL18e9hPV//3f/7X69etnPfbYY1ZNTY312GOPuf4z8e7279VXX7X69+9v/eIXv4j4k/1FixZZa9assT799FOrqqrKuvXWW63+/fuHFL5e7d9TTz1lrV692vrkk0+s7du3W/fdd58lyVq1alWwjZeOn2X1vI8n3HzzzdaYMWM63KaXjuGhQ4eC1zpJ1pNPPmlVVVUFf2Xp1XOQAqeHZs+ebUkKW959991gG0nWSy+9FPz38ePHrYceeshKS0uz4uPjrcsuuyysYm9tbbXuuOMOa/DgwVZiYqI1ffp0q66uLkq9Oqmpqcm66aabrEGDBlmDBg2ybrrpprCfa36zf5ZlWb/85S+txMTEDudFqaursy677DJr8ODB1oABA6xzzjnHuvPOO8PmkYmWnvaxpaXFysvLs771rW9ZcXFx1llnnWXNnj077Pj01WO4e/fuDt/TX39fu30Mf/GLX1hZWVnWgAEDrIsuuijkU6PZs2dbubm5Ie03bNhgjRw50howYID1ne98p8PC+7e//a01bNgwKy4uzsrOzg65gEZbT/qXm5vb4bGaPXt2sM28efOss846yxowYID1rW99y8rLy7MqKiqi2KNQPenf0qVLrXPOOcdKSEiwzjzzTOv//b//Z7311lth2/TS8bOsnr9HDx48aCUmJlrPP/98h9vz0jE88UlTpPecV89Bn2X9/9/8AQAAMATz4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAONQ4AAAAOP8fzETB+Ca5aGrAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(z[:, 0], z[:, 1], \"o\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-28T05:23:55.672259Z",
     "start_time": "2024-09-28T05:23:55.649198Z"
    }
   },
   "outputs": [],
   "source": [
    "torch.save(z, \"z.pt\")\n",
    "torch.save(x, \"x.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:.conda-cli726]",
   "language": "python",
   "name": "conda-env-.conda-cli726-py"
  },
  "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
