{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 154,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "import pennylane as qml\n",
    "\n",
    "from tqdm import tqdm\n",
    "import os\n",
    "from dataclasses import dataclass\n",
    "\n",
    "from data_utils.aae_dataset import MNIST_AAE_Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "metadata": {},
   "outputs": [],
   "source": [
    "@dataclass\n",
    "class Config:\n",
    "    data_dir:str = r\"./mnist/processed/\"\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu') \n",
    "\n",
    "    n_qubits:int = 4\n",
    "    n_encoder_layers:int = 8\n",
    "\n",
    "    n_ansatz_layers:int = 5\n",
    "\n",
    "    n_epochs:int = 10\n",
    "    batch_size:int = 32\n",
    "    num_workers:int = 0\n",
    "    pin_memory:bool = False\n",
    "\n",
    "\n",
    "\n",
    "config = Config()\n",
    "\n",
    "train_path = os.path.join(config.data_dir, \"mnist_train.pt\")\n",
    "val_path = os.path.join(config.data_dir, \"mnist_valid.pt\")\n",
    "test_path = os.path.join(config.data_dir, \"mnist_test.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_ds = MNIST_AAE_Dataset(train_path)\n",
    "val_ds = MNIST_AAE_Dataset(val_path)\n",
    "test_ds = MNIST_AAE_Dataset(test_path)\n",
    "\n",
    "train_loader = DataLoader(train_ds, config.batch_size, True, num_workers=config.num_workers, pin_memory=config.pin_memory)\n",
    "val_loader = DataLoader(val_ds, config.batch_size, False, num_workers=config.num_workers, pin_memory=config.pin_memory)\n",
    "test_loader = DataLoader(test_ds, config.batch_size, False, num_workers=config.num_workers, pin_memory=config.pin_memory)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "samples = next(iter(train_loader))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, n_encoder_layers, n_qubits = samples[\"encoder_params\"][\"weights\"].shape\n",
    "\n",
    "if n_encoder_layers != config.n_encoder_layers or n_qubits != config.n_qubits:\n",
    "    raise ValueError(\"Unmatched num_encoder_layers or num_qubits!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [],
   "source": [
    "def RY_layer(weights):  # modify for batched inputs\n",
    "    # weights: (B, n_qubits)\n",
    "    for i in range(weights.shape[1]):\n",
    "        qml.RY(weights[:, i], wires=i)\n",
    "\n",
    "def EntanglingLayer(n_qubits):\n",
    "    for i in range(0, n_qubits - 1, 2):\n",
    "        qml.CNOT(wires=[i, i + 1])\n",
    "\n",
    "    for i in range(1, n_qubits - 1, 2):\n",
    "        qml.CNOT(wires=[i, i + 1])\n",
    "\n",
    "def HadamardLayer(n_qubits):\n",
    "    for i in range(n_qubits):\n",
    "        qml.Hadamard(wires=i)\n",
    "\n",
    "\n",
    "def aae_encoder_for_train(encoder_params):   # modify original aae_encoder for batched inputs\n",
    "\n",
    "    # expecting (B, n_layers*n_qubits)\n",
    "    inputs_shape = encoder_params.shape\n",
    "    for l in range(config.n_encoder_layers):\n",
    "        encoder_params = encoder_params.view(-1, config.n_encoder_layers, config.n_qubits)\n",
    "        RY_layer(weights=encoder_params[:, l])\n",
    "        EntanglingLayer(config.n_qubits)\n",
    "\n",
    "    encoder_params = encoder_params.view(inputs_shape)\n",
    "\n",
    "    # post selection to deal with negative number in AAE\n",
    "    # qml.Hadamard(wires=n_qubits-1)\n",
    "    # qml.measure(wires=n_qubits-1, postselect=1)\n",
    "\n",
    "    # return qml.state()\n",
    "\n",
    "def resize_and_norm(images):\n",
    "    images = F.avg_pool2d(images, kernel_size=(7, 7))\n",
    "    # images shape: (batchsize, 1, 4, 4)\n",
    "\n",
    "    images = images.reshape(images.size(0), -1)\n",
    "    # images shape: (batchsize, 16)\n",
    "\n",
    "    norms = torch.norm(images, p=2, dim=1, keepdim=True)\n",
    "    images = images / norms\n",
    "    return images\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x24ff51f85e0>"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "q_device = qml.device(\"default.qubit\", wires=config.n_qubits)\n",
    "\n",
    "# test\n",
    "@qml.qnode(q_device, interface=\"torch\")\n",
    "@qml.simplify\n",
    "def encoder_test(inputs):  \n",
    "    aae_encoder_for_train(inputs)\n",
    "    return qml.state()\n",
    "\n",
    "index = 0\n",
    "import matplotlib.pylab as plt\n",
    "fig, axes = plt.subplots(1, 2)\n",
    "axes[0].imshow(resize_and_norm(samples[\"images\"][index]).view(1, 4, 4).permute(1,2,0))\n",
    "axes[1].imshow(encoder_test(samples[\"encoder_params\"][\"weights\"][index].unsqueeze(0).view(1, -1)).type(torch.float32).detach().view(1, 4, 4).permute(1,2,0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.9512,  0.0245,  1.1676,  1.0524],\n",
       "        [-0.2433,  0.5660,  0.2698,  0.9469],\n",
       "        [ 0.7404, -0.2415,  0.5527, -0.3197],\n",
       "        [ 0.6531,  0.4157, -0.2951,  0.3691],\n",
       "        [ 0.8796,  0.5420,  0.9681,  0.3284],\n",
       "        [ 0.1801,  1.0079,  0.1585,  0.6012],\n",
       "        [ 0.1621,  0.6124, -0.0128,  0.6495],\n",
       "        [ 0.6086,  0.8545,  0.4455,  0.5164]])"
      ]
     },
     "execution_count": 116,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "samples[\"encoder_params\"][\"weights\"][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 5100x500 with 1 Axes>, <Axes: >)"
      ]
     },
     "execution_count": 137,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAFAAAAAIHCAYAAACvPurKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzde5xVdb0//vcMlxEvWJFgyU0BL2gKCqaE5Ck1OylkBqbdNEGxwi52vHW1nwVaJzNvoJhmlnlBE+2kKXbBwhA5owakgICXk6BggiIwMPP7Y75MDXPbM7P3Xmvt/Xw+HvtRe+09a3/2Hj6v12eNzIeKurq6ugAAAAAAAAAAAAAAAAAAAAAAAAAACqoy6QEAAAAAAAAAAAAAAAAAAAAAAAAAQDmwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIENAAEAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAABFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAQBHYABAAAAAAAAAAAAAAAAAAAAAAAAAAisAGgAAAAAAAAAAAAAAAAAAAAAAAAABQBDYABAAAAAAAAAAAAAAAAAAAAAAAAIAisAEgAAAAAAAAAAAAAAAAAAAAAAAAABSBDQABAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAAARWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAEAR2AAQAAAAAAAAAAAAAAAAAAAAAAAAAIrABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAQ2AAQAAAAAAAAAAAAAAAAAAAAAAACAIrABIAAAAAAAAAAAAAAAAAAAAAAAAAAUgQ0AAQAAAAAAAAAAAAAAAAAAAAAAAKAIbAAIAAAAAAAAAAAAAAAAAAAAAAAAAEVgA0AAAAAAAAAAAAAAAAAAAAAAAAAAKAIbAAIAAAAAAAAAAAAAAAAAAAAAAABAEdgAEAAAAAAAAAAAAAAAAAAAAAAAAACKwAaAAAAAAAAAAAAAAAAAAAAAAAAAAFAENgAEAAAAAAAAAAAAAAAAAAAAAAAAgCKwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIENAAEAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAABFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAQBHYABAAAAAAAAAAAAAAAAAAAAAAAAAAisAGgAAAAAAAAAAAAAAAAAAAAAAAAABQBDYABAAAAAAAAAAAAAAAAAAAAAAAAIAisAEgAAAAAAAAAAAAAAAAAAAAAAAAABSBDQABAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAAARWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAEAR2AAQAAAAAAAAAAAAAAAAAAAAAAAAAIrABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAQ2AAQAAAAAAAAAAAAAAAAAAAAAAACAIrABIAAAAAAAAAAAAAAAAAAAAAAAAAAUgQ0AAQAAAAAAAAAAAAAAAAAAAAAAAKAIbAAIAAAAAAAAAAAAAAAAAAAAAAAAAEVgA0AAAAAAAAAAAAAAAAAAAAAAAAAAKAIbAAIAAAAAAAAAAAAAAAAAAAAAAABAEdgAEAAAAAAAAAAAAAAAAAAAAAAAAACKwAaAAAAAAAAAAAAAAAAAAAAAAAAAAFAENgAEAAAAAAAAAAAAAAAAAAAAAAAAgCKwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIENAAEAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAABFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgCGwACAAAAAAAAAAAAAAAAAAAAAAAAQBHYABAAAAAAAAAAAAAAAAAAAAAAAAAAisAGgAAAAAAAAAAAAAAAAAAAAAAAAABQBDYABAAAAAAAAAAAAAAAAAAAAAAAAIAisAEgAAAAAAAAAAAAAAAAAAAAAAAAABSBDQABAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAAARWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoAhsAAgAAAAAAAAAAAAAAAAAAAAAAAEAR2AAQAAAAAAAAAAAAAAAAAAAAAAAAAIrABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAQ2AAQAAAAAAAAAAAAAAAAAAAAAAACAIrABIAAAAAAAAAAAAAAAAAAAAAAAAAAUgQ0AAQAAAAAAAAAAAAAAAAAAAAAAAKAIbAAIAAAAAAAAAAAAAAAAAAAAAAAAAEXQNekBQDFs3rw5nnvuuVi6dGksW7YsXn311di0aVNs3rw56aE1UlVVFTvttFO8853vjMGDB8eQIUNin332iaqqqqSHRgkzP4CskFdAVsgrICvkFZAV8grICnkFZIW8ArJCXgEA5Jf1FQAdoT8A6Aj9AQCQX9ZXAJB9+pzm2ACQkrR169b44x//GHfeeWc8+OCDsWrVqqirq0t6WB1SUVERAwYMiA996EMxfvz4eP/73x9du5q6dJz5AWSFvAKyQl4BWSGvgKyQV0BWyCsgK+QVkBXyCgAgv6yvAOgI/QFAR+gPAID8sr4CgOzT5+Sioi6rfyqgGcuWLYv//u//jlmzZsUrr7yS9HAKYo899oiTTz45vva1r8WgQYOSHg4ZYn4AWSGvgKyQV0BWyCsgK+QVkBXyCsgKeQVkhbwCAMgv6ysAOkJ/ANAR+gMAIL+srwAg+/Q57WEDQErCxo0bY9q0aXHZZZfFli1bkh5OUVRVVcX5558fF154Yey8885JD4cUMz/MD8gKeSWvICvklbyCrJBX8gqyQl7JK8gKeSWvICvklbyCrJBX8goAyC/rK+srgI7QH/oDoCP0h/4AAPLL+sr6CoDs0+f6vCNsAEjm/e53v4uzzjorVq1a1eZz+/TpE4MHD45+/frFzjvvHN27d4/KysoijLJttbW1sWXLlti4cWO88MILsWzZsli9enWbXzdw4MCYMWNGHHfccUUYJVljfpgfkBXySl5BVsgreQVZIa/kFWSFvJJXkBXySl5BVsgreQVZIa/kFQCQX9ZX1lcAHaE/9AdAR+gP/QEA5Jf1lfUVANlXan3+9NNPxz/+8Y+oqanR5wVmA0Ay7Z577okJEybE1q1bm338sMMOi/Hjx8cxxxwTQ4YMiZ49exZ5hJ2zfv36WLp0aTz88MNxxx13xMKFC5t9XteuXeOOO+6Ik046qcgjJM3Mj3rmB6SfvKonryD95FU9eQXpJ6/qyStIP3lVT15B+smrevIK0k9e1ZNXkH7yqp68AgDyxfqqnvUVQPvoj3r6A6B99Ec9/QEA5Iv1VT3rKwCyrJT6vLa2Ni6++OK47LLL4u67746TTjpJnxeYDQDJrJbCr0uXLjFlypSYMmVK7LPPPgmNrjCWL18eV199dVx11VWxbdu2Ro8JQf6d+WF+QFbIK3kFWSGv5BVkhbySV5AV8kpeQVbIK3kFWSGv5BVkhbySVwBAfllfWV8BdIT+0B8AHaE/9AcAkF/WV9ZXAGRfKfX5W2+9FZ/5zGfirrvuioiIf/zjH7Hnnns2eZ4+zy8bAJJJv/vd7+IjH/lIk/AbM2ZMXHPNNXHQQQclNLLi+Nvf/hZf+MIX4k9/+lOj4127do3f/OY3cdxxxyU0MtLA/DA/ICvklbyCrJBX8gqyQl7JK8gKeSWvICvklbyCrJBX8gqyQl7JKwAgv6yvrK8AOkJ/6A+AjtAf+gMAyC/rK+srALKvlPp89erVMXbs2Jg/f35ERAwcODBWrFjR6tfo8/ywASCZs3Hjxhg6dGisWrWq0fFJkybF9OnTo7KyMqGRFVdtbW1Mnjw5brjhhkbHBw4cGIsXL44ePXokNDKSZH7UMz8g/eRVPXkF6Sev6skrSD95VU9eQfrJq3ryCtJPXtWTV5B+8qqevIL0k1f15BUA5EdtbW3885//jIiIt73tbWWzlvh31lf1rK+A9tAf+mM7/QG0h/7QH9vpDwDID+sr66vtrK+A9tAfpE0p9fmiRYviIx/5SKP3cuqpp8Yvf/nLNr9Wn3dedv6kwP8zbdq0kgi/zqqsrIzp06fHpEmTGh1fuXJlTJs2LaFRkTTzo575Aeknr+rJK0g/eVVPXkH6yat68grST17Vk1eQfvKqnryC9JNX9eQVpJ+8qievAKB9XnvttZgzZ05cdtllMWHChBg0aFD06NEjunTpEr169YpevXpFly5dokePHjFo0KCYMGFCXH755TFnzpx47bXXkh5+QVlf1bO+ApqjP1qmP+rpD6A5+qNl+qOe/gCA9rG+apn1VT3rK6A5+oOsKJU+f/jhh2PUqFFN3suRRx6Z09fr886rqKurq0t6EJCrZcuWxUEHHRSbN29uODZmzJj4/e9/n6nwy6fa2to4+uijY+7cuQ3HqqqqYtGiRTFo0KAER0axmR9NmR+QTvKqKXkF6SSvmpJXkE7yqil5Bekkr5qSV5BO8qopeQXpJK+akleQTvKqKXkFAC175pln4rrrrov77rsvnnvuuU6da5999okTTzwxzjnnnNhvv/3yNMLkWV81ZX0F6I+26Y+m9AegP9qmP5rSHwDQMuurtllfNWV9BegPsqZU+nzmzJlxzjnnxNatW5s89vjjj8eIESNyPpc+7zgbAJIp55xzTkyfPr3hfpcuXaK6ujoOOuigBEeVvKeffjqGDx8e27Ztazg2efLkuO666xIcFcVmfjTP/ID0kVfNk1eQPvKqefIK0kdeNU9eQfrIq+bJK0gfedU8eQXpI6+aJ68gfeRV8+QVAPzL1q1bY/bs2XHttdfGnDlzGj229957x2GHHRYjRoyIww47LAYNGhR1dXUNvySwfPnyqKioiOXLl8cTTzwRCxYsiCeeeCJWrFjR6Dwf/OAH4/Of/3yMHTs2unbtWrT3VgjWV82zvoLyoz/aR380T39A+dEf7aM/mqc/AOBfrK/ax/qqedZXUH70B1mW9T6vra2Niy66KC6//PJmH+/Ro0e8/vrr0a1bt3adV593jA0AyYytW7fGu9/97njllVcajn35y1+OK664IsFRpcdXvvKV+PGPf9xwv3fv3vHSSy9ZhJQJ86N15gekh7xqnbyC9JBXrZNXkB7yqnXyCtJDXrVOXkF6yKvWyStID3nVOnkF6SGvWievACh3mzZtih/96Edx7bXXxksvvRQREZWVlXHCCSfExIkT433ve1+84x3vaPJ1b775Zuy6664REfHGG2/ELrvs0uQ569atiz//+c8xc+bMuP/++6O2tjYiIvbaa6/4whe+EF/96lejqqqqgO+uMKyvWmd9BeVBf7Sf/mid/oDyoD/aT3+0Tn8AUO6sr9rP+qp11ldQHvQHWZf1Pn/rrbfi05/+dMyaNavF5xx11FHxpz/9qUPn1+ftZwNAMmPOnDlxzDHHNDq2fPny2GeffRIaUbosX748Bg8e3OjYnDlz4gMf+EBCI6KYzI/WmR+QHvKqdfIK0kNetU5eQXrIq9bJK0gPedU6eQXpIa9aJ68gPeRV6+QVpIe8ap28AqCczZ8/P84444xYvHhxRETsscceMWnSpDjrrLNiwIABrX5tLr/g8+9WrVoV119/fdxwww0Nv4gxdOjQuPnmm2PkyJF5eDfFY33VOusrKH36o2P0R+v0B5Q+/dEx+qN1+gOAcmZ91THWV62zvoLSpz8oBVnu89WrV8fYsWNj/vz5rT7v/PPPj8suu6xDr6HP268y6QFAru68885G9w877LBMhF+xDBo0KA499NBGx3b8zChd5kfrzA9ID3nVOnkF6SGvWievID3kVevkFaSHvGqdvIL0kFetk1eQHvKqdfIK0kNetU5eAVCONm3aFBdeeGEceeSRsXjx4ujTp0/ccsst8cILL8T3vve9Nn+5pyMGDBgQ3/ve9+KFF16IW265Jfr06ROLFy+OI444Ii666KLYtGlT3l+zUKyvWmd9BaVLf3SO/mid/oDSpT86R3+0Tn8AUI6srzrH+qp11ldQuvQHpSSrfb5o0aJ473vf22Tzv8rKptvPHXnkkR1+HX3efjYAJDMefPDBRvfHjx+f0EjSa8fPZMfPjNJlfrTN/IB0kFdtk1eQDvKqbfIK0kFetU1eQTrIq7bJK0gHedU2eQXpIK/aJq8gHeRV2+QVAOVk/vz5ceihh8Zll10WtbW1cdppp8WiRYvi05/+dFRVVRX89auqquLTn/50LFq0KE477bSora2NadOmxWGHHdbkFx3SyvqqbdZXUHr0R+fpj7bpDyg9+qPz9Efb9AcA5cT6qvOsr9pmfQWlR39QarLY5w899FCMGjUqVq1a1ej47rvvHj/84Q+bPP+II47o1Ovp8/axASCZsHnz5iYhcswxxyQ0mvQ69thjG91ftWpVbN68OaHRUCzmR27MD0ievMqNvILkyavcyCtInrzKjbyC5Mmr3MgrSJ68yo28guTJq9zIK0ievMqNvAKgXNx1110xevToWLJkSfTp0yfuueee+MUvfhG9evUq+lh69eoVv/jFL+Kee+6J3r17x+LFi2P06NExa9asoo+lPayvcmN9BaVFf3Se/siN/oDSoj86T3/kRn8AUC6srzrP+io31ldQWvQHpSaLfX7DDTfEhz/84Vi/fn2j4wMHDoy//OUvsfPOOzc5vueee3bqNfV5+9gAkEx47rnnoq6urtGxfffdN6HRpNeQIUMa3a+trY0VK1YkNBqKxfzIjfkByZNXuZFXkDx5lRt5BcmTV7mRV5A8eZUbeQXJk1e5kVeQPHmVG3kFyZNXuZFXAJSDn/70p3HKKadETU1NjBs3LhYtWhQf/ehHkx5WfPSjH43FixfHuHHjoqamJiZMmBA33XRT0sNqkfVVbqyvoHToj/zQH7nRH1A69Ed+6I/c6A8AyoH1VX5YX+XG+gpKh/6gFGWpz2tra+OCCy6Is846K7Zt29bosfe+973x2GOPxdChQ2PevHmNHjvyyCM7/dr6vH1sAEgmLF26tNH9Pn36xG677ZbQaNKrZ8+e0bt370bHdvzsKD3mR27MD0ievMqNvILkyavcyCtInrzKjbyC5Mmr3MgrSJ68yo28guTJq9zIK0ievMqNvAKg1N10001x5plnRm1tbZx55pkxa9as6NWrV9LDatCrV6+YNWtWwxg/97nPpfaXfKyvcmN9BaVBf+SP/siN/oDSoD/yR3/kRn8AUOqsr/LH+io31ldQGvQHpSorfb5x48aYMGFCXH755c0+/vOf/zz69OkTEVGQDQD1efvYAJBMWLZsWaP7gwcPTmgk6bfjLqgCsPSZH7kzPyBZ8ip38gqSJa9yJ68gWfIqd/IKkiWvcievIFnyKnfyCpIlr3InryBZSefVwIEDY7/99othw4bFfvvtF9OmTWvza77zne/Epk2bijC6xuQVAKVq1qxZMXHixIiI+NKXvhQ33HBDdOnSJeFRNdWlS5e44YYb4ktf+lJEREycODHuvvvuhEfVlPVV7qyvINv0R37pj9zpD8g2/ZFf+iN3+gOAUmV9lV/WV7mzvoJs0x+UsqT7PFfr1q2Lt956q8XH99133/jwhz8cr776ajz77LONHsvHBoAR+rw9bABIJrz66quN7vfr1y+hkaRf3759G91fu3ZtQiOhWMyP3JkfkCx5lTt5BcmSV7mTV5AseZU7eQXJkle5k1eQLHmVO3kFyZJXuZNXkKw05NXtt98e1dXV8cgjj8TUqVNj/vz5rT7/kksuSeQXGOQVAKVo/vz5ceqpp0ZtbW1MnDgxrrjiiqioqEh6WC2qqKiIK664Is4888yora2NT3ziE/H4448nPaxGrK9yZ30F2aU/8k9/5E5/QHbpj/zTH7nTHwCUIuur/LO+yp31FWSX/qDUpaHPc9G3b9+4//774957742BAwc2+5wHHngg9thjj0bHevToEYccckjexvDv9HnLbABIJux4YbDzzjsnNJL02/GzSeKiiuIyP3JnfkCy5FXu5BUkS17lTl5BsuRV7uQVJEte5U5eQbLkVe7kFSRLXuVOXkGy0pRXe+21V+y///6xatWqWLZsWRxzzDFx8MEHx7Bhw+LXv/51RERMnjw5IiKOOuqoGDZsWKxZs6Zo45NXAJSaTZs2xemnnx41NTUxbty4mD59eqp/uWe7ioqKmDFjRowbNy5qamri9NNPT1UvW1/lzvoKskl/FIb+yJ3+gGzSH4WhP3KnPwAoNdZXhWF9lTvrK8gm/UE5SFOf72jbtm2xbdu2hvsVFRUxduzYWLx4cXzrW9/K6RwjRoyIbt265WU8+jx3NgAkEzZv3tzofvfu3RMaSfpVVVU1ui8AS5/5kTvzA5Ilr3InryBZ8ip38gqSJa9yJ68gWfIqd/IKkiWvcievIFnyKnfyCpKVprz6+9//HmvXro2jjz46PvnJT8b48ePjqaeeijvvvDPOPPPMWLVqVUyfPj0iIubOnRvV1dXRu3fvoo1PXgFQai655JJYsmRJ9OnTJ2688cbo0qVL0kPKWZcuXWLmzJnRu3fvWLx4cXz3u99NekgNrK9yZ30F2aQ/CkN/5E5/QDbpj8LQH7nTHwCUGuurwrC+yp31FWST/qAcJN3nW7ZsiccffzxmzpwZU6ZMiTFjxkSvXr2ie/fu0bVr1+jatWt07949evXqFWPGjIkpU6bEL37xi+jfv39O5z/yyCPzNlZ9njsbAJJJlZX+6LbEZ4M/Ay3z2UC6mJMt89lAupiTLfPZQLqYky3z2UC6mJMt89lAupiTLfPZQLqYky3z2UC6JDEnTznllDjggANi6NChMWXKlNhpp51i4cKFceaZZ0ZExJAhQ2L06NExd+7coo/t38krAErJ/Pnz4/LLL4+IiOnTp0evXr0SHlH7vfOd72z45cbLLrssHn/88YRH1Dzrq5ZZX0H26I/i0R8t0x+QPfqjePRHy/QHAKXE+qp4rK9aZn0F2aM/KFfF6qzq6uo499xz413velccfvjhMWnSpLj66qtj7ty5sW7duqipqWl4bk1NTaxbty7mzp0bV199dUyaNCkmTpyY0+vkcwNAfZ47nxQAAAAAAAAAAAAl5/bbb48lS5bE7373u7jwwgtj5cqVTZ5TUVFR/IEBQInatGlTnHHGGVFbWxunnXZafPSjH016SB120kknxamnnhq1tbVx+umnx+bNm5MeUipYXwGFoD9Kn/4ACkF/lD79AQDFZX1V+qyvgELQH1AYW7dujRkzZsTw4cNj+PDhcdVVV8W6devydv6PfOQjUVVV1ejYEUcckbfzkzsbAAIAAAAAAAAAAFCyjjnmmDjnnHPiG9/4Rhx66KFx0003RUTEsmXL4tFHH40xY8ZERMRuu+0Wr7/+epJDBYBMu+KKK2Lx4sXRp0+f+MlPfpL0cDrtqquuij59+sTixYvjRz/6UdLDSRXrKyCf9Ef50B9APumP8qE/AKA4rK/Kh/UVkE/6A/Jv3rx5MWLEiJg8eXJUV1cX5DV+85vfxN577x1HHnlkREQMHDgw9txzz4K8Fq2zASAAAAAAAAAAAAAl7Zvf/GY8+uij8ZOf/CRuv/32OOSQQ+LjH/94zJw5M/r37x8REeedd14ce+yxMWzYsFizZk3CIwaAbNm6dWtcc801ERHxgx/8IHr16pXwiDqvV69ecfnll0dExLXXXhtbt25NeETpYn0F5IP+KD/6A8gH/VF+9AcAFJb1VfmxvgLyQX9Afq1duzYmTZoUo0aNiieffLLF5+27774xfvz4uPTSS+O+++6LhQsXxqJFi2LRokWxcOHCuO++++LSSy+NqqqqVl/v73//e8ybNy+OPfbYOOmkk/L9dshR16QHAJAvNTU1sWHDhoio31G+W7duCY8IoHnyCsgKeQVkhbwCskJeAVkhr4CskFdAVsirZKxcubLR/be//e2xdu3aiIh4+OGHm/2ab3/72/Htb3+70EOD1JJXQGfMnj07Xnrppejdu3dMmDAh6eHkzSmnnBJf+9rX4sUXX4z77ruvrH/xwfoqG/Q5WaM/Sp/+gPbT523TH6VPf0D76Q+gM6yvSp/1VTboc7JGf0D+VFdXxwknnBAvvfRSs4/369cvTj/99PjsZz8bgwYNavVcw4cPj169esU3vvGNnF77oYceisWLF8dnPvOZGDZsWHuHTidVJj0AgM6orq6Oc889N0aOHBm77rpr9OrVK3r16hW77rprjBw5Ms4999xWd7UFKBZ5BWSFvAKyQl4BWSGvgKyQV0BWyCsgK+QVkBXyCsiXa6+9NiIiJk6cGFVVVQmPJn+qqqpi4sSJEfGv9whpo8/JMv0BUE+ft4/+AKinP4B8sb6C5Ohzskx/QH488MADMXr06GY3/zvooIPit7/9baxYsSK++93vtrn5X0REXV1djBo1qsnxK664In7729/GQQcd1OSxl156KUaPHh0PPPBAx94EHWYDQCCTnnrqqRgzZkwMHz48rrrqqliwYEFs2bKl4fEtW7bEggUL4qqrrophw4bFmDFj4qmnnkpwxEC5kldAVsgrICvkFZAV8grICnkFZIW8ArJCXgFZIa+AfPr73/8ec+bMicrKyjjrrLOSHk7enX322VFRUREPP/xwPPPMM0kPBxroc7JOfwDo847QHwD6A8gv6ytIhj4n6/QH5Md9990XY8eOjTfffLPR8V122SV++MMfxsKFC+P444+PLl265HzOr3/9680e//KXvxzHH398LFy4MH74wx/GLrvs0ujxN998M8aNGxf33Xdf+98IHWYDQCBT6urqYtq0aTFixIiYO3duzl83d+7cGDFiREybNi3q6uoKOEKAevIKyAp5BWSFvAKyQl4BWSGvgKyQV0BWyCsgK+QVUAjTp0+PiIgTTjghBgwYkPBo8m/AgAFxwgknRETEddddl/BoQJ9TOvQHUM70ecfpD6Cc6Q+gEKyvoLj0OaVCf0Dn/fnPf46TTz45ampqGh0/6qijYsmSJXHeeedFt27d2nXODRs2xNSpU5scX7JkScP/79atW5x33nmxZMmSGD16dKPnbdmyJU4++eT485//3K7XpeNsAAhkRl1dXUyZMiUuuuiiJuWVi5qamrjoootiypQpLmqAgpJXQFbIKyAr5BWQFfIKyAp5BWSFvAKyQl4la/z48TFv3ryIiKitrY0pU6bEoEGDYvDgwXH11Ve3+HVLly6NUaNGxb777hsjR46MRYsWNTz2P//zP3HooYfGsGHD4qCDDoqf/exnBX8fUAzyCiiU++67LyIiJk6cmPBICmf7e7v//vsTHknh/Pu6akf5Wmdt3rw5vvjFL8aQIUPiPe95T3zqU5/K+/sodfqcUqI/SkMx+qO1xyCL9Hnn6I/SkK/+OPfcc2PgwIFRUVER1dXVjR7TH5Qa/QEUivVVaSnEfz/3c9380eeUEv0BnfPaa6/Faaed1qQPTj311HjooYeiX79+HTrvoEGDmhwbPnx47L///k2O9+vXLx5++OE49dRTGx2vqamJ0047Lf75z392aAy0T1lsAPj444/Hf/7nf8bb3va22GWXXeKII46IO+64I+lhkQErV66MioqKRrdu3brFXnvtFRMmTIgFCxZERMSPf/zjqKioiDPOOKPFc/3hD3+IysrKGDlyZGzdurVYb6GkXHbZZXHNNdd0+jzXXHNNXHbZZXkYUXkzP6Bl8ipd5BW0TF6li7yClsmrdJFX0DJ5lS7yClomr9JFXkHL5FW6yCtombxKzvz582PdunVx5JFHRkTErbfeGosXL45nn3025s+fHz/4wQ9a/KXOs88+O84666x49tln44ILLojTTz89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x9577x1PP/10od9eSdDnlBr9URqK0R+tPQZZo887T3+Uhnz1R2v0B6VEfwCFZH1VWgrx38/9XDc/9DmlRn9Ax2zbti1+9KMfNTr24Q9/OMaOHdup8w4aNKjJseHDh8f+++/f7nONGzcuPvzhDzc69qMf/Si2bdvW4fHRupLeAHDp0qURETFkyJAmj+25556x6667NjwH2mvmzJkRETF69OhGx6+//vp45zvfGV/4whfi9NNPjxdffDF+/OMfx4ABA5IYZkmYN29eJs9dzswPypW8yh55RbmSV9kjryhX8ip75BXlSl5lj7yiXMmr7JFXlCt5lT3yinIlr5J38MEHxzPPPNNwf/z48XHDDTfEtm3bYt26dXH77bfHKaec0uTrevfuHYceemjceuutERExa9as6Nu3bwwePLjhlxu2/wvIy5Yti+XLl8d+++0XEREXXXRRXH311UV4d5A/8goopP/7v/+LiOZ/qaDUDB48OCL+9Z5Lyb+vq972trdFdXV1VFdXxz333BMR+VlnvfOd74wPfvCD8eCDD0ZExIoVK2LFihVxwAEHRETEZz7zmYbXoyl9TqnRH6WhGP3R2mMR+oNs0eedpz9KQ776ozX6g1KiP4BCsr4qLYX47+d+rpsf+pxSoz+gY+69995Yvnx5o2Nf+9rXOnXOefPmxSuvvNLk+GOPPdbhc5533nmN7i9btixmz57d4fPRuq5tPyW7Xn/99YiI2H333Zt9vGfPng3PyYq6urrYuHFj0sMoupqamkRff9myZfGd73wnIiLefPPNeOKJJ+L3v/999OnTJ37wgx80em6fPn1ixowZcfLJJ8e9994bY8eOjTPOOCOBUderqamJN998M7HX76yampp46qmnCnb+p556Kl5//fXo2jW7cWh+dFzW5wfpIq/aJq86Tl6RT/KqbfKq4+QV+SSv2iavOk5ekU/yqm3yquPkFfkkr9omrzpOXpFP8qpt8qrj5BX5JK/aVoy8+vjHPx4PPvhgHHPMMRER8elPfzoef/zxGDJkSFRUVMRXv/rVeM973hMREbNnz47Zs2c3bFo6Y8aMOP300+P73/9+9OzZM2666aaIqM+u66+/PiZMmBCVlZVRW1sbV199dfTv3z8iIp588smC/wvm8op8kldAIdXW1samTZsiov7vOBerv/79dYrZmXV1dRER8dZbb8WGDRui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OPnkk+OFF16IZcuWNXreO97xjhg9enTssssuTc7x5JNPxjHHHBPdu3ePioqK+PCHPxw///nPGx4/9dRTY8aMGYV9IwBQAqqqquKmm26KysrK+OUvfxm//vWvkx5Sh91zzz1x2223RZcuXeLmm2+OqqqqpIdUNPlYX7XF+gr4d/qjdOTaIRERd911V4wdOzb23HPPqKioiMmTJ8dtt90WERHDhw+PffbZJyIidtpppxg2bFisXLmy4Wv1CBChP0pFrt2hNwCg8KyvSke+rs9/+ctfxhFHHBGjR4+OiIguXbrEHnvs0fC11llAhP6AQhg0aFCTY8OHD4/9998/gdFQaDYAJJNqa2uTHkJq+WzwZ6BlPhtIF3OyZT4bSBdzsmU+G0gXc7JlPhtIF3OyZT4bSBdzsmU+G0gXc7JlPhtIl0LNyRdeeCHe9a53RdeuXSMioqKiIvr37x/PP/98zuc47LDDYvbs2bF+/fqoqamJO+64o9EviB522GHx1FNPxfr16/M9/IiQVwCUlsMPPzzOP//8iIiYPHlyrF27NuERtd+rr74akydPjoiI888/P0aOHJnwiJqX5vVVRMTy5cvj0EMPjZEjR8a1117b6LEjjzwy5syZk7cx78j6CrJHfxRPITOyPR3y/PPPx4ABAxruDxw4sNnnvfzyy3HXXXfFCSec0HCsUNfp+gOyR38UT9LXH2nsje30BwClxPqqeLJwfb548eKoqqqKE044IYYNGxaf+cxn4pVXXml4bqF+zmt9BdmjPyhXheisv//97436drvHHnss769VSPo8dzYAJBN23BV3y5YtCY0k/TZv3tzo/k477ZTQSCgW8yN35gckS17lTl5BsuRV7uQVJEte5U5eQbLkVe7kFSRLXuVOXkGy5FXu5BUkK0t5dfrpp8fxxx8f73//++P9739/7Lvvvg2/DBER0bVr13j7298e//d//1eQ15dXAJSab3/72zF06NBYvXp1nHnmmbFt27akh5Szbdu2xcSJE2PNmjUxdOjQ+Pa3v530kBpkaX116KGHxosvvhgLFy6Me+65J6ZPnx533HFHw+N77rlnrF27NjZt2lSQ17e+gmzSH4WRpf7Y0fr16+PEE0+M888/P0aMGNFwvFDX6foDskl/FEYW+6PYvbGd/gCg1FhfFUYW11dbt26Nhx9+OGbMmBH/+7//G3vttVecc845DY8X6ue81leQTfqDclDoPq+rq4svf/nLTY5feeWV0b1797y+VqHp89zZAJBM2HESb9y4MaGRpN+On40ALH3mR+7MD0iWvMqdvIJkyavcyStIlrzKnbyCZMmr3MkrSJa8yp28gmTJq9zJK0hWsfKqX79+8Y9//CO2bt0aEfV/EfL555+P/v3753yOioqK+M53vhP/+7//G3/5y19i6NChceCBBzZ6zqZNm6JHjx55Hft28gqAUrPTTjvFTTfdFN26dYt77703zj777Kirq0t6WG2qq6uLs88+O+69997o3r173HzzzU1+iSNJWVpf9ezZM3bfffeIiOjbt2+ceuqpMXfu3IbHN23aFF26dCnYL6pYX0E26Y/CKHR/3HLLLTFs2LAYNmxYPPzwwzl3SP/+/WPVqlUN91euXNnoeRs2bIjjjz8+xo0bF1/96lebfH0hrtP1B2ST/iiMtF1/pLE3ttMfAJQa66vCyOL1ef/+/eM//uM/Yq+99oqKior41Kc+FY899ljDcwv1c17rK8gm/UE5KHSfr1mzJp555plGx97+9rfHueeem9fXKQZ9njsbAJIJ73znOxvdf+GFFxIaSfq9+OKLje736tUroZFQLOZH7swPSJa8yp28gmTJq9zJK0iWvMqdvIJkyavcyStIlrzKnbyCZMmr3MkrSFax8qp3795x6KGHxq233hoREbNmzYq+ffvG4MGDcz7Hpk2b4rXXXouIiFdffTWmTZsW559/fsPjq1evjoqKiujXr19+B///yCsAStHhhx8et912W1RWVsaNN94YX/nKV1L9Sz51dXXxla98JW688caorKyM2267LUaOHJn0sBrJ0vrqH//4R9TW1kZE/UYc999/fwwfPrzh8SVLlsRBBx0UlZWF+XUG6yvILv2Rf4Xuj8985jNRXV0d1dXVccEFF+TcISeffHLMnj07Xn755airq4vp06fHJz7xiYiIeOONN+L444+P448/Pr7xjW80+dpCXafrD8gu/ZF/abv+SGNvbKc/AChF1lf5l8Xr8wkTJsTjjz8e69evj4iI//mf/4lDDjmk4WsL9XNe6yvILv1BqSt0n/fp0ycWL14c3/rWt6Kqqip22WWXeOqpp/L6GsWiz3NnA0AyYceLiWXLliU0kvRbunRpo/tDhgxJaCQUi/mRO/MDkiWvcievIFnyKnfyCpIlr3InryBZ8ip38gqSJa9yJ68gWfIqd/IKklXMvJoxY0bMmDEj9t1335g2bVrcdNNNERExceLEmD17dkTU/6vCffv2jfHjx8fixYujb9++cdFFF0VExOuvvx6jRo2KAw88MI466qiYPHlynHjiiQ3nf+CBB+Kkk04q2AY18gqAUnXyySfHzJkzIyLiyiuvjEmTJsW2bdsSHlVT27Zti4kTJ8aVV14ZERE33nhjfOxjH0t4VE1laX01a9aseM973hOHHHJIHHHEEXHsscfGGWec0XD+Bx54ID7+8Y8XbPzWV5Bt+iO/iv3zxJY6JKJxj+yzzz5xySWXxPve974YPHhw7LHHHnH22WdHRP33ff78+XH33XfHsGHDYtiwYfG9732v4TyFuk7XH5Bt+iO/0nb9kcbe2E5/AFCqrK/yK4vX5/3794+LL744Ro0aFQcffHA88sgjMX369IbzFOrnvNZXkG36g1JWjD7v0aNHXHLJJbFo0aK45ZZbom/fvnl/jWLQ57mrqEvzVqnw/yxZsiSGDh3a6Njrr78ePXv2TGhE6bR+/frYfffdGx1bsmRJ7L///gmNqLjefPPN2HXXXSOi/l/u2WWXXRIeUXGYH7kp9/lBusirf5FXTckr0kRe/Yu8akpekSby6l/kVVPyijSRV/8ir5qSV6SJvPoXedWUvCJN5NW/yKum5BVpIq/+Jat5ddRRR8X1118fBxxwQN7PLa9Ik3LNK6Dwbrrpppg4cWLU1tbGuHHj4sYbb4xevXp1+Hz5zKtXX301Jk6cGPfee29UVlbGjTfeGKeffnqHz1dIpbK+2rJlS4wYMSIeeeSReOc735n385f7+kqfU0r0R36USn/8u0Jcp5d7f5Au+rxz9Ed+lFJ/+Pku5UJ/AIVifZUfpbS+iijcz3nLfX2lzykl+oNSVGp9Xijl3uftVZh/sgLybJ999omKiopGx3bc6ZOmn0llZWXsvffeCY2GYjE/cmN+QPLkVW7kFSRPXuVGXkHy5FVu5BUkT17lRl5B8uRVbuQVJE9e5UZeQfJKJa9Wr14d55xzTkF+OTRCXgFQHs4444y44447olu3bnHvvffG0KFD45577kl6WHHPPffEgQceGPfee29069Yt7rzzzlT/ck+prK9WrFgR06ZNK8jmfxHWV1BK9Ed+lEp/bFeo63T9AaVDf+RHqfSHn+8CQOdZX+VHqayvtivUz3mtr6B06A9KUan1eaHo8/axASCZUFVVFQMGDGh07OGHH05oNOn10EMPNbo/YMCAqKqqSmg0FIv5kRvzA5Inr3IjryB58io38gqSJ69yI68gefIqN/IKkievciOvIHnyKjfyCpJXKnnVp0+fOO200wp2fnkFQLk4+eST49FHH40DDjgg1qxZEx/72Mfik5/8ZKxdu7boY1m7dm2cdtpp8bGPfSzWrFkTQ4cOjT//+c/xsY99rOhjaY9SWV/tt99+8Z//+Z8FO7/1FZQW/dF5pdIf2xXqOl1/QGnRH51XKv3h57sAkB/WV51XKuur7Qr1c17rKygt+oNSU2p9Xij6vH1sAEhmfOhDH2p0/84770xoJOm142ey42dG6TI/2mZ+QDrIq7bJK0gHedU2eQXpIK/aJq8gHeRV2+QVpIO8apu8gnSQV22TV5AO8qpt8gqAcnL44YfHwoUL48ILL4zKysr45S9/GQceeGDccsstsXnz5oK//ubNm+OWW26JAw88MG677baorKyMiy66KJ544okYOXJkwV8/H6yv2mZ9BaVHf3Se/mib/oDSoz86T3+0TX8AUE6srzrP+qpt1ldQevQHpUaft02ft48NAMmM8ePHN7r/xBNPxHPPPZfQaNJn+fLlsXDhwkbHdvzMKF3mR+vMD0gPedU6eQXpIa9aJ68gPeRV6+QVpIe8ap28gvSQV62TV5Ae8qp18grSQ161Tl4BUI522mmnmDp1ajz22GMxdOjQWL16dXz2s5+Nfv36xcUXXxyrVq3K+2uuWrUqLr744ujXr1989rOfjdWrV8fQoUPjsccei+9///ux00475f01C8X6qnXWV1C69Efn6I/W6Q8oXfqjc/RH6/QHAOXI+qpzrK9aZ30FpUt/UEr0eev0efvZAJDMeP/73x977LFHo2NXXXVVQqNJn6uvvrrR/d69e8eYMWMSGg3FZn60zvyA9JBXrZNXkB7yqnXyCtJDXrVOXkF6yKvWyStID3nVOnkF6SGvWievID3kVevkFQDlbOTIkfHEE0/E97///dhrr73ilVdeialTp8Y+++wTY8eOjdmzZ8e6des6fP5169bF7NmzY+zYsbH33nvH1KlT45VXXom+ffvG97///Vi4cGGMHDkyj++oOKyvWmd9BaVPf3SM/mid/oDSpz86Rn+0Tn8AUM6srzrG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NaXP9fl25ge0zPwg7fS5Pt9OXqWL7wdppz/0x3byCsgKedWUPtfn25kf0DLzg7QrtT5/+umn4x//+EfU1NTo8wKzASCZds8998SECRNi69atzT5+2GGHxfjx4+OYY46JIUOGRM+ePYs8ws5Zv359LF26NB5++OG44447YuHChc0+r2vXrnHHHXfESSedVOQRposFG2kmr+rJq3ryijSTV/XkVT15RZrJq3ryqp68Is3kVT15VU9ekWbyqp68qievSDN5VU9e1ZNXpJm8qiev6skr0kxe1ZNX9eQVkBXyqjF9Xk+f1zM/oGXmB2mmz+vp83ryKl18P0gz/VFPf9STV0BWyKvG9Hk9fV7P/ICWmR+kWSn1eW1tbVx88cVx2WWXxd133x0nnXSSPi8wGwCSWS2FX5cuXWLKlCkxZcqU2GeffRIaXWEsX748rr766rjqqqti27ZtjR4TghZspJe8klc7kleklbySVzuSV6SVvJJXO5JXpJW8klc7kleklbySVzuSV6SVvJJXO5JXpJW8klc7kleklbySVzuSV0BWyKt/0ef6fEfmB7TM/CCt9Lk+35G8ShffD9JKf+iPHckrICvk1b/oc32+I/MDWmZ+kFal1OdvvfVWfOYzn4m77rorIiL+8Y9/xJ577tnkefo8v2wASCb97ne/i4985CNNwm/MmDFxzTXXxEEHHZTQyIrjb3/7W3zhC1+IP/3pT42Od+3aNX7zm9/Ecccdl9DIkmXBRhrJK3nVHHlFGskredUceUUaySt51Rx5RRrJK3nVHHlFGskredUceUUaySt51Rx5RRrJK3nVHHlFGskredUceQVkhbyqp8/1eXPMD2iZ+UEa6XN93hx5lS6+H6SR/tAfzZFXQFbIq3r6XJ83x/yAlpkfpFEp9fnq1atj7NixMX/+/IiIGDhwYKxYsaLVr9Hn+WEDQDJn48aNMXTo0Fi1alWj45MmTYrp06dHZWVlQiMrrtra2pg8eXLccMMNjY4PHDgwFi9eHD169EhoZMnZsGFD9OzZMyIi1q9fH7vttlvCI6Lcyat68qopeUXayKt68qopeUXayKt68qopeUXayKt68qopeUXayKt68qopeUXayKt68qopeUXayKt68qopeUXayKt68qopeQVkhV/w0efb6fOmzA9omfmRLrW1tfHPf/4zIiLe9ra3lU13/Tt9Xk+f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z+EnXH/4ixXzvKioSC1atFDXrl0lSf3799eOHTt8/X1EMDDPU8P88Ac7fr9b3zWjH7E//I35AcBtzJrnQZzZCC7mOfyE6w/vmTNnjpYuXRrx3MCBAzV79mylp6cndcxwOKy+fftGPT9jxgw1bNgw7uemp6dr9uzZuuCCCyKef+mllzR37tyk1gPjfH8DwLlz56q4uFi7du3SuHHjnF4OPKpjx456+OGH9fDDD+uJJ57Q22+/rWnTpqmiokIPPPCAQqGQFixYoGbNmmnMmDEqKyuL+Py7775bxcXFmjZtms455xyHXoW91q5dK0nq1auXwyuxXu/evSUde81BcNttt6miosK041VUVOi2224z7XhBRq8SR6/8jV65F71KHL3yN3rlXvQqcfTK3+iVe9GrxNErf6NX7kWvEkev/I1euRe9Shy98jd65V70KnH0yt/olTP+/ve/67vf/W7M9+/YsUPt2rWrfTsnJyfqb7CuTygU0osvvqhhw4apXbt26tevn/7whz/U+x+oehm98jd6BcCtTpzrRuf4zp07dcYZZ9TeVDwUCqlt27basWNHIOc4goF5Dj/h+sNfrJjnnTp1UllZmf75z39KklasWKF9+/apuLjY2hcDWIx5nhrmhz/Y8fvdeDPGr9gf/sb8AOA2Zs1zIzP7xhtvVLdu3TRq1Cjt2rXLxFcB2It5Dj/h+sNbDh48qClTpkQ817x5cz3//PNJ3/xPku6///46n58wYYKhz09PT9fzzz8fdRPJKVOm6ODBg0mvC/Xz/Q0ABw0aFPHDKGCWUaNGSZLWrVsnSWrXrp2eeuoplZSUaPz48bUf98Ybb2j27Nm68MILdccddziyVifUfF9qhqef1fwQVPOa/a6goECrVq0y/birVq3Shg0bTD8u6FV96JV/0SvvoVfx0Sv/olfeQ6/io1f+Ra+8h17FR6/8i155D72Kj175F73yHnoVH73yL3rlPfQqPnrlX/TKOZ9//rmysrIs/RqVlZV69NFH9fLLL2v79u166623dMMNN+ibb76x9Os6iV75F70C4GZWzPUgznH4H/McfsP1h79YMc9POeUUvfTSS5oyZYp69eqlv/3tb8rNza29KQTgRczz1DE//MGO3+8GEfvDv5gfANzIrnn+7rvvauPGjVq/fr1OP/10/eQnP7H8awJWYJ7Db7j+8JYFCxZo9+7d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pLZt2+bI109PT9dHH31k+9/qDQCAH9k915njAACYj3kOAEiE07/fbdmypd58801HvjYAAH7BPAcAwP2+/vprbd++PeK5fv36JX28ffv2adq0aVHPb9myJeljHu/EtRUXF6ukpMSUYyNShtMLQGKaNGkS8z/Q9rM777xTc+bMcXoZkqovQO655x7t2bNHjz76qH7+85/rqaeecnpZMY0ZM0ZPPvmkrV+zqqpKzZo1kyQVFRUpKyvLlq974MCB2q9VUlKipk2b2vJ1S0pK1KFDB0nS3r17ff0vLSsqKpSVlaUjR45YcvzMzEyVlJQoI8O744leJY9eWY9emYdemYte1Y9e0atk0Stz0av60St6lSx6ZS56VT96Ra+SRa/MRa/qR6/oVbLolbnoVf3oFb1KFr0yF72qH72iV8miV/W7+OKLLTu20+iV9eiVefzQK8AIp3rlNLuuP/w4152Y504J6v6wE/Pcu9gfdeP6w97rD+Z58pjnMBPzPHXMD3/NDz/OjRr8ftd6Tu8POzE/AHME9edd5nnyuB6EmZjn3sX+qBvXH965Pv/www8j3j755JN1zjnnJL2Wmu/D8fLz89WlS5ekj3m83NxcnXTSSRH3Ofvwww81ZMgQU46PY5gYHhMKhQI5hBo0aOD0EqLcd999+v3vf69nn31WEydOVE5OjtNLqlODBg0c+WemUaNGOnz4sGP/zDZt2tS2rxsKhSRJjRs31sknn2zL13RS9+7dtXbtWsuOfcopp1hybLvQq+TRK+vRK3OPTa/MR6/io1f+Ra/io1fJo1fWo1fmHptemY9exUev/ItexUevkkevrEevzD02vTIfvYqPXvkXvYqPXiWPXlmPXpl7bHqVmK1bt+onP/mJvvnmG51yyilasGCBunbtWufHzps3T9OnT1dVVZUuuugiPfvss2rQoIH+/ve/6/LLL1fnzp1rP3b16tVq3LixXS9DEr2yA70y99he7xWQKDt75TS3zvNYs3z16tUaP368pOo/UNevXz/99re/VWZmpq2vQ3JunjstSPvDbsxz72N/ROL6wz5unedS7JkuSR9//LFuv/12lZSUSJJ++ctfatiwYba9Dol5DvMxz1PH/LCPF+fH22+/rcmTJ2v//v0KhUL63//9X02fPt32mzPw+13rOb0/7Mb8AMwVpJ93vTjPa4TDYV188cVav369vv32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fskll6h79+7Ky8tT//799a9//cv01wEguJjnqeH6wx+Y59Zgf/gb8wM4xuzf7x4+fFg//OEPdfbZZ6tHjx76wQ9+oMLCQlteixswPwD7MM8RNP/973913XXXRf3zfu211+rNN99UmzZtkjpuhw4dop7Lz89Xly5dop5v06aNVq5cqWuvvTbi+YqKCl133XX69ttvk1oDEuPrGwB+8cUXeuqpp3TJJZeobdu2atiwoVq3bq3hw4frww8/dHp58IDi4mKFQqGIR4MGDXTmmWfqqquu0tq1ayVJTz31lEKhkG666aaYx/r73/+utLQ09enTR5WVlXa9BF95/PHH9bvf/S7l4/zud7/T448/bsKKvOO///2v/vOf/0iSvv/97zu8GuvUvLaioqLA/SBBr9yFXiWPXvkfvXIXepU8euV/9Mpd6FXy6JX/0St3oVfJo1f+R6/chV4lj175H71yF3qVPHrlf/TKXehV8uiVv6xZs0a7d+/W+eefL0l6/vnntXnzZn322Wdas2aNnnjiiYg/YHi8H/3oR3rvvffUrl27Ot//4osvqqCgQAUFBbr66qstew1ALPTK/5jnQLVU5vnYsWN1880367PPPtOkSZM0cuTI2vfVN+v9ivkB2It5jqA7cY6fyKy5vnjxYm3cuFEFBQW66667It4HAKlinieP6w9/YJ5bg/3hf8wPoJpVv9+9+eab9emnn2rDhg0aOnSor2+GdzzmB2Av5jmCJBwOa8yYMdqxY0fE8z/96U/1xz/+UZmZmUkdd/Xq1dq1a1fU8x988EHMz8nMzNQf//hH/fSnP414fseOHRozZgw31LSBr28A+PTTT+vOO+/Uf/7zH11yySW6++671a9fPy1fvlx9+/blbwKGYR06dNBDDz2khx56SBMnTlTnzp21ZMkS9e3bV++++67uuOMODRw4UAsWLKi9i/fx9u/fr5tuukmZmZlauHChMjIyHHgV3rZx40Y9+OCDph3vwQcf1MaNG007ntutX79eknTWWWepefPmDq/GOi1atFBOTo6kY685aOiV8+hVauhVcNAr59Gr1NCr4KBXzqNXqaFXwUGvnEevUkOvgoNeOY9epYZeBQe9ch69Sg29Cg565Tx6lRp65S+zZs3SddddV/v2iy++qDFjxig9PV3NmzfX1VdfrUWLFtX5uQMGDFB2drZdSwUSRq/8jXkO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7LfffhERcc011xR5NEBXyCsgLeQVkBbyCkgLeQWkhbwC0kJeAWkhrwAg/fR56ctkMnHppZfGyJEjY+bMmVk/b+bMmTFy5Mi49NJLI5PJ5HGEQBrpDygsfU6p0B9AOdPnQD5YX5U+/QHkg/6AwtLn+ffkk0/G+PHjo66ursnx3XffPebPnx9nnHFG9OjRo0Pn/PDDD+OSSy5pdnz+/PmN/79Hjx5xxhlnxPz582PMmDFNHrdq1aoYP358PPnkkx16XTrPBoBA3qzd0fW4444r8kjyZ+213X///UUeCdAV8gpIC3kFpIW8AtJCXgFpIa+AtJBXQFrIq9Jw0EEHxVNPPdXiffX19XHKKafE4MGDY+utt46rrrqq1fO88sorMXr06Nh2221j1KhRMXfu3IiIWLFiRXz729+ObbfdNoYNGxb77LNP1NTU5OVaAOg4fV7aMplMnHLKKTF58uRmv+yQjbq6upg8eXKccsopfqmkA6yvKAf6AwpHnxdHvvs8ImLfffeNoUOHxvDhw2P33XePv//97zm/jqTRH0C50ufFkas+nzRpUgwaNCgqKiqiuro66/ugEKyvSpv+KI5C9MegQYNiu+22i+HDh8fw4cPj1ltvzeUlQLv0BxSOPs+/f//733H44Yc3e38PO+yweOSRR2KLLbbo1HkHDx7c7NiIESNi++23b3Z8iy22iBkzZsRhhx3W5HhdXV0cfvjh8d5773VqDHRMSW8AuGLFijj99NNjjz32iM022yx69eoVm266aXzpS1+KqVOndipgKC+1tbVRUVHR5NajR4/YfPPN4+CDD47Zs2dHRMSvf/3rqKioiGOOOabVc/35z3+OysrKGDVqVKxevbpQl1A0//73v+Of//xnRER86UtfKvJo8mfttS1YsKDsisv8oFTIq9InrygV8qr0yStKhbwqffKKUiGvSp+8olTIq9InrygV8qr0yStKhbwqDbNmzYp33303dttttxbvv/nmm2PevHnx8ssvx6xZs+LnP/95k19U/08nnHBCHH/88fHyyy/HWWedFUcffXTjfccff3y89NJL8fzzz8e4ceNK+i+RA6SJPi99l112Wfz2t7/t8nl++9vfxmWXXZaDEZU+6yvKgf6AwtLnhVeoPr/ttttizpw5UV1dHaeffnqT+0qR/gDKmT4vvFz2+Xe+853461//GgMHDuzQfZBv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dJFX5U1ekSbyqrzJK9JEXpU3eUWayKvyJq9IE3lV3uQVaSKvypu8Ik3kVWkYOnRovPTSSxERscEGG0R1dXVUV1fH3XffHRERBx10UFx//fWxZs2aePfdd+PWW2+NQw45pNl5+vbtGzvvvHPcfPPNERFx5513Rv/+/Rvfu1/96lcxffr0eOSRR2KDDTZo8tzJkyfHVVddlcerBKA1+rx0PfXUU6k8dymwvqIc6A8oDH1ePIXo8/fee69Jtvzxj3+MjTfeODbaaKOIiDjqqKMaX69U6A+gHOnz4slVn3dFKfY5yWJ9Vbr0R/EUoj8++uijeO+99xq/nj59eowYMaLxa/1BvukPKAx9nl/33HNPLFiwoMmxH/3oR10651NPPRVLlixpdvzpp5/u9DnPOOOMJl/X1NTEvffe2+nz0bbu7T8k/VatWhUXXnhh49cVFRXxox/9KC655JIijqpzMplMLF++vNjDKLi6urqivn5NTU38+Mc/joiGDyfPPvtsPP7449GvX7/4+c9/3uSx/fr1iylTpsT48ePjnnvuibFjx8YxxxxThFE3qKuri48++qigr1lfX9+4S3wmkynY6//n6xTymjOZTEREfPzxx/Hhhx9GZWVh91Y1PzqvGPODZJFX8kpekRbySl7JK9JCXskreUVayCt5Ja9IC3klr+QVaSGv5JW8Ii3kVenk1Xe+85146KGHYu+9927x/iOPPDKeeeaZ2GabbaKioiJOP/302GmnnSIi4t5774177723cfPSKVOmxNFHHx0XX3xxrL/++jF16tSIiHjjjTfijDPOiK222iq+8pWvREREVVVV/O1vf4uIiOeffz5v/7K8vAJonT4v3X/7va6uLubMmZO388+ZMyfef//96N49vX993vqq86yv0B+l2x8kiz5vX9r7/P3334+DDjooPv7446isrIw+ffrE/fffHxUVFRERMXv27Jg0aVJers/vR+Wf/gAi9Hk20tLnJ5xwQvzpT3+Kt99+O772ta/FeuutFzU1Ne3eV2p9TrJYX5Xu+kp/tC/t/bFo0aIYP358rFmzJjKZTGy11VYxbdq0xtfQH+ST/ijd/iBZ9Hn7utrnt912W5OvR4wY0fjnpp2RyWRi9OjRzY5fccUV0bNnz06f96tf/WoMHz48qqurG4/deuutccABB3T6nLQhU0bWrFmTef311zNXX311ZoMNNsh86Utfyrz//vvFHlaHLFu2LBMRZX876aSTCvJ+v/rqq62OYdNNN8288sorrT531113zUREZt68eQUZ61onnXRS0b8/bsW9mR+tMz/c3JJ1k1etk1dubsm6yavWySs3t2Td5FXr5JWbW7Ju8qp18srNLVk3edU6eeXmlqybvGqdvHJzS9Ytl3n14YcfZnbaaafMsmXLcnbOjli9enVm5MiRmTVr1uTkfPLKzc3Nzc3NrTM366vWWV+5ubm5uaXlVkp9vnjx4szee++ds/Ppczc3Nze3tNz0eev0uZubm1vrN/3ROv3h5ubm5paWW0f7fODAgU2ef80113SpMydPntziuHLh6quvbnLOQYMGdej5n+7zQv1d5zQqq21eKysro3///jFx4sS47rrr4sknn4yf/vSnxR4WKfC1r30tMplMZDKZWLx4cfz85z+PxYsXx9ixY2PZsmUtPqd3795N/hdKlfkBpIW8AtJCXgFpIa+AtJBXQFrIKyAt5BWQBJ/5zGfi8ssvj1dffbUor9+tW7d45pln/CvrAEDJsL4CgPQrdp/36dMnHnnkkaK8NgCUCn0OQGfoDwBIvrfffjsWLlzY5NiYMWM6fb4PP/wwLrnkkmbH58+f3+lz/qdPj622tjYWLVqUk3PTVPdiD6BY9t1334iI+POf/1zcgXTQOuus0+pfmC9lp512Wlx//fXFHkZENHwA+dGPfhTvv/9+XHTRRfHf//3f8etf/7rYw2rVhAkT4vLLLy/oa9bX18f6668fERELFiyIfv36FeR1P/roo8bXWrRoUay77roFed1FixbF4MGDIyLigw8+KPhfPjI/Oq8Y84NkkVfySl6RFvJKXskr0kJeySt5RVrIK3klr0gLeSWv5BVpIa/klbwiLeRVaeXVXnvtlbdzF5u8AmidPi/dzdHq6uqiX79+sWrVqrycv6qqKhYtWhTdu6f3r89bX3We9RX6o3T7g2TR5+3T553n96PyT38AEfo8G/q883w+x/qqdNdX+qN9+qPz9Af6o3T7g2TR5+3rSp//7W9/a/L1euutF5///Oc7PZa1OfGfRowYEdtvv32nz/mfhgwZEp/5zGea7HP2t7/9LcaOHZuT8/OJ9M6ILnrrrbciIqJHjx5FHknHVFRUFGxRkCRJ/D6dc8458bvf/S6uvvrqOPXUU2PQoEHFHlKLevToUZT/Znr16hUrVqwo2n+z6667bsFet6KiIiIievfuHeutt15BXvM/mR+dV6z5QbLIq8KRV50nr4iQV4UkrzpPXhEhrwpJXnWevCJCXhWSvOo8eUWEvCokedV58ooIeVVI8qrz5BUR8qqQCp1Xr7zySnzve9+Ld955Jz772c/GTTfdFDvssEOTx9TW1sbRRx8df//732PLLbeM6urqJvffeOONcemll0Z9fX189atfjauvvroouSuvANqmz0vX0KFDY/bs2Xk792c/+9m8nLtQkri+WqutdVQS1ljWV0ToDygUfd62JPZ5Wz8vae9nKYXk96PyT38Aa+nztiWxz9dq6zP4Cy+8EKecckosWrQoIiJ++tOfxoEHHliw64jw+ZwG1lelS3+0Lan90dbnvqeeeiomTpwYEQ2bQo0ZMyZ+85vfRFVVVaEuIyL0Bw30BxSGPm9bV/r8+eefb/L1qFGjolu3bp0611NPPRVLlixpdvzpp5/u1Pla0q1btxg1alQ8/vjjjceqq6ttAJgHJb3N67x582L58uXNji9fvjxOP/30iIj45je/WehhUSJ69+4dZ511VtTV1cX//M//FHs4ibPZZptFRMMO2qWupqYmIj65ZswP0kVelTd5RZrIq/Imr0gTeVXe5BVpIq/Km7wiTeRVeZNXpIm8Km/yijSRV6XrhBNOiOOPPz5efvnlOOuss+Loo49u9pj1118/Lrroorjlllua3ffqq6/GeeedFzNnzoyamppYtGhRXHfddQUYOQAdpc9L12677ZbKc5eqbNZXEW2vo6yxSBL9AYWhz5Olqz8vaeu+cqE/gHKkz5MlF5/Ply9fHuPGjYuLLroo5s+fHy+++GLsvvvuBbwK+IT1VenSH8mSbX+09blv2LBh8cwzz0R1dXW88MILsXjx4rj66qvzPHJomf6AwtDn+fPhhx82+XqLLbbo1HkymUyMHj262fErrrgievbs2alztubTY1y2bFlOz0+Dkt4A8LbbbotNN900vvnNb8ZJJ50UZ599dhx55JExYMCAePDBB2P33XeP0047rdjDJMWOP/742GyzzWLatGllsVDsiF122SUiIp599tkijyT/1l7j2mumgflBWsgr5BVpIa+QV6SFvEJekRbyCnlFWsgr5BVpIa+QV6SFvCpNixcvjtmzZ8cRRxwRERHjx4+P119/vfEvRa+10UYbxZgxY1r8V9nvuOOOGDt2bGy66aZRUVERJ554YkyfPr0g4wegY/R56fr+97+fynOXomzXVxFtr6OssUgS/QGFoc+TIxc/L2nrvnKhP4BypM+TI1efz2+55Zb44he/GGPGjImIiG7dukWfPn0KdyHwH6yvSpf+SI6O9Edbn/vWWWed6NGjR0RErFq1Kj7++OOoqKjI7+ChFfoDCkOf58+wYcPi0EMPjXHjxsW+++4bO+20U6fOc+6557Z4fNKkSV0ZXouGDh0a++67b4wbNy4OPfTQGDZsWM5fgxLfAHC//faLQw89NF577bWYPn16/PKXv4wHHngghg4dGlOmTInHHnssevfuXexhkmK9evWKyZMnx+rVq+PCCy8s9nASZe1icvbs2UUeSf5ZQLfM/CAt5BXyirSQV8gr0kJeIa9IC3mFvCIt5BXyirSQV8gr0kJelabXX389Pve5z0X37t0jIqKioiIGDBgQr732WtbneO2112LgwIGNXw8aNKhDzwegcPR56Ro+fHjsvvvuOT/v7rvv7pcROqgj66u21lHWWCSJ/oDC0OfJkYufl6A/gPKkz5MjV5/P582bF1VVVbHffvvF8OHD46ijjoolS5YU5iLgU6yvSpf+SI5cfh6sra2NYcOGxSabbBKf/exn46STTsr1cCEr+gMKQ5/nzxFHHBHTp0+PP/7xj/HQQw/FGWec0eFzfPjhh3HJJZc0Oz5//vxcDLGZM844Ix566KH44x//GNOnT4/vfve7eXmdcte92APIp5EjR8bIkSOLPQxSbNCgQZHJZNp8zMknnxwnn3xys+N//vOf8zSqdFg798phB+21HxLKLW/MD0qFvCp98opSIa9Kn7yiVMir0ievKBXyqvTJK0qFvCp98opSIa9Kn7yiVMgrAEg/fV7arrrqqhg5cmTU1dXl5Hw9evSI3/72tzk5F5Bu+gMKR59TSvQHUK70eWlZvXp1zJgxI55++unYbLPN4pxzzomJEyfGHXfcUeyhUYasr0qb/ig9gwYNiueffz6WLVsWRxxxRNx1111x6KGHFntYlCH9AYWjz5Nr8ODBzY6NGDEitt9++yKMhlypLPYAgNK08847R0TEq6++Gu+++26RR5M/S5cujdra2oj45JqBdJFXQFrIKyAt5BWQFvIKSAt5BaSFvALSQl6Vpi222CL+9a9/xerVqyMi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iX3emmnTpsVXv/rV2GCDDaKysjK+973vxeOPP97kMeXa5ySL9RXlIK1/fl6Mn/PqD7KlP4BCy3efL168OF566aUmxzbccMOYNGlSTl+nEPR59mwASCpssskmTb5+/fXXizSS5Pv0v5y18cYbF2kkLdt1111j+vTpUVlZGTfeeGOcdtppiV5EZzKZOO200+LGG2+MysrKmD59eowaNarYw2rC/Mhe0ucHySKvck9eZU9e0RHyKvfkVfbkFR0hr3JPXmVPXtER8ir35FX25BUdIa9yT15lT17REfIq9+RV9uQVHSGvci/feXXUUUdFdXV1VFdXx1lnnRU777xz3HzzzRERceedd0b//v1j6623bva88ePHx7333htvv/12ZDKZuPbaa+PQQw9t8pgbb7wxjj322GbPXbRoUVRUVMQWW2yR02uRVwC5oc8pdYX6PNi3b9+s1lZtrauWLVsWX//61+PrX/96/Pd//3ez18jXumot6ys6Qn8AhZS0Pm+rs//whz/E66+/HrW1tVFbWxsREXPmzIkRI0ZERMSaNWtiwYIFsdNOO+XlGpLe5/oDoHwlrc/bstVWW8Vjjz0Wq1atioiI+++/P3bcccfG+30+J0msryh1afzz82L9nFd/0BH6AyikfPd5v379Yt68eXH++edHVVVVrLvuujFnzpycvkah6PPs2QCQVPj0h4mampoijST5XnnllSZfb7PNNkUaSevGjx8fN9xwQ0REXHHFFTFhwoRYs2ZNkUfV3Jo1a+K4446LK664IiIa/nL3gQceWORRNWd+ZC8N84NkkVe5Ja+yJ6/oKHmVW/Iqe/KKjpJXuSWvsiev6Ch5lVvyKnvyio6SV7klr7Inr+goeZVb8ip78oqOkle5Vei8mjJlSkyZMiW23XbbuPTSS2Pq1KmN9x133HFx7733RkTDL7tdeOGF8aUvfSm23nrr6NOnT5xwwgmNj33ppZeiuro6DjnkkGav8eCDD8YBBxwQlZW5/Wt38gogd/Q5payQ66vW1lbZrquuuOKKmDVrVtx1110xfPjwGD58ePz0pz9tPH++1lVrWV/RUfoDKJSk9Xl7nd2Wv/71rzFq1KjYaKON8jL+NPS5/gAoT0nr8+XLl0f//v3joIMOinnz5kX//v1j8uTJERHxgx/8ILbccssYNmxYDB06NB599NG45pprGs/v8zlJY31F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AAAAAFAANgAEAAAAAAAAAAAAAAAAAAAAAAAAgAKwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIANAAEAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAAAFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAQAHYABAAAAAAAAAAAAAAAAAAAAAAAAAACsAGgAAAAAAAAAAAAAAAAAAAAAAAAABQADYABAAAAAAAAAAAAAAAAAAAAAAAAIACsAEgAAAAAAAAAAAAAAAAAAAAAAAAABSADQABAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAAABWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAEAB2AAQAAAAAAAAAAAAAAAAAAAAAAAAAArABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAA2AAQAAAAAAAAAAAAAAAAAAAAAAACAArABIAAAAAAAAAAAAAAAAAAAAAAAAAAUgA0AAQAAAAAAAAAAAAAAAAAAAAAAAKAAbAAIAAAAAAAAAAAAAAAAAAAAAAAAAAVgA0AAAAAAAAAAAAAAAAAAAAAAAAAAKAAbAAIAAAAAAAAAAAAAAAAAAAAAAABAAdgAEAAAAAAAAAAAAAAAAAAAAAAAAAAKwAaAAAAAAAAAAAAAAAAAAAAAAAAAAFAANgAEAAAAAAAAAAAAAAAAAAAAAAAAgAKwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIANAAEAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAAAFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAQAHYABAAAAAAAAAAAAAAAAAAAAAAAAAACsAGgAAAAAAAAAAAAAAAAAAAAAAAAABQADYABAAAAAAAAAAAAAAAAAAAAAAAAIACsAEgAAAAAAAAAAAAAAAAAAAAAAAAABSADQABAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAAABWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAEAB2AAQAAAAAAAAAAAAAAAAAAAAAAAAAArABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAA2AAQAAAAAAAAAAAAAAAAAAAAAAACAArABIAAAAAAAAAAAAAAAAAAAAAAAAAAUgA0AAQAAAAAAAAAAAAAAAAAAAAAAAKAAbAAIAAAAAAAAAAAAAAAAAAAAAAAAAAVgA0AAAAAAAAAAAAAAAAAAAAAAAAAAKAAbAAIAAAAAAAAAAAAAAAAAAAAAAABAAdgAEAAAAAAAAAAAAAAAAAAAAAAAAAAKwAaAAAAAAAAAAAAAAAAAAAAAAAAAAFAANgAEAAAAAAAAAAAAAAAAAAAAAAAAgAKwASAAAAAAAAAAAAAAAAAAAAAAAAAAFIANAAEAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAAAFYANAAAAAAAAAAAAAAAAAAAAAAAAAACgAGwACAAAAAAAAAAAAAAAAAAAAAAAAQAHYABAAAAAAAAAAAAAAAAAAAAAAAAAACsAGgAAAAAAAAAAAAAAAAAAAAAAAAABQADYABAAAAAAAAAAAAAAAAAAAAAAAAIACsAEgAAAAAAAAAAAAAAAAAAAAAAAAABSADQABAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAAABWADQAAAAAAAAAAAAAAAAAAAAAAAAAAoABsAAgAAAAAAAAAAAAAAAAAAAAAAAEAB2AAQAAAAAAAAAAAAAAAAAAAAAAAAAArABoAAAAAAAAAAAAAAAAAAAAAAAAAAUAA2AAQAAAAAAAAAAAAAAAAAAAAAAACAAvj/AXkuFp2HjbERAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 5100x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "@qml.qnode(q_device, interface=\"torch\")\n",
    "@qml.simplify\n",
    "def circuit(inputs, weights):  \n",
    "    aae_encoder_for_train(inputs)\n",
    "    \n",
    "    qml.StronglyEntanglingLayers(weights, wires=range(config.n_qubits))\n",
    "    return [qml.expval(qml.PauliZ(i)) for i in range(config.n_qubits)]\n",
    "\n",
    "qml.draw_mpl(circuit, decimals=2, expansion_strategy=\"device\")(samples[\"encoder_params\"][\"weights\"][0].unsqueeze(0).view(1, -1), torch.normal(0, 0.1, size=(config.n_ansatz_layers, config.n_qubits, 3)))\n",
    "\n",
    "# params show in the figure is inconsistent with encoder_params, but above test pass\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Sequential(\n",
       "  (0): Flatten(start_dim=1, end_dim=-1)\n",
       "  (1): <Quantum Torch Layer: func=circuit>\n",
       "  (2): LogSoftmax(dim=-1)\n",
       ")"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weight_shapes = {\"weights\": (config.n_ansatz_layers, config.n_qubits, 3)}\n",
    "\n",
    "qlayer = qml.qnn.TorchLayer(circuit, weight_shapes, init_method=nn.init.uniform_)\n",
    "# expecting (B, n_encoder_layers, n_qubits)\n",
    "model = torch.nn.Sequential(nn.Flatten(), qlayer, nn.LogSoftmax(dim=-1)).to(config.device)\n",
    "\n",
    "model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-1.4238, -1.4203, -1.5922, -1.1581],\n",
       "        [-1.3804, -1.6736, -1.6530, -0.9957],\n",
       "        [-1.8625, -0.9084, -1.3613, -1.6861],\n",
       "        [-1.4238, -1.2634, -1.6579, -1.2519]], grad_fn=<LogSoftmaxBackward0>)"
      ]
     },
     "execution_count": 141,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model(samples[\"encoder_params\"][\"weights\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train and Eval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = nn.NLLLoss()\n",
    "# Optimizer\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=5e-3, weight_decay=1e-4)\n",
    "scheduler = torch.optim.lr_scheduler.CosineAnnealingLR(optimizer, T_max=config.n_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.5550, grad_fn=<NllLossBackward0>)\n"
     ]
    }
   ],
   "source": [
    "pred = model(samples[\"encoder_params\"][\"weights\"])\n",
    "print(criterion(pred, samples[\"digits\"]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:17<00:00,  9.23it/s, loss=0.81] \n",
      "100%|██████████| 38/38 [00:03<00:00, 11.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.9518672199170124\n",
      "valid set loss: 0.806155800819397\n",
      "Epoch 2:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.33it/s, loss=0.685]\n",
      "100%|██████████| 38/38 [00:03<00:00, 11.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.9759336099585062\n",
      "valid set loss: 0.7286494374275208\n",
      "Epoch 3:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.37it/s, loss=0.75] \n",
      "100%|██████████| 38/38 [00:03<00:00, 12.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.975103734439834\n",
      "valid set loss: 0.6749855279922485\n",
      "Epoch 4:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.26it/s, loss=0.632]\n",
      "100%|██████████| 38/38 [00:03<00:00, 12.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.9684647302904564\n",
      "valid set loss: 0.6676006317138672\n",
      "Epoch 5:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.47it/s, loss=0.824]\n",
      "100%|██████████| 38/38 [00:03<00:00, 12.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.983402489626556\n",
      "valid set loss: 0.6617234349250793\n",
      "Epoch 6:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.44it/s, loss=0.74] \n",
      "100%|██████████| 38/38 [00:03<00:00, 12.12it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.9842323651452282\n",
      "valid set loss: 0.6582380533218384\n",
      "Epoch 7:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.50it/s, loss=0.746]\n",
      "100%|██████████| 38/38 [00:03<00:00, 12.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.979253112033195\n",
      "valid set loss: 0.6556654572486877\n",
      "Epoch 8:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.44it/s, loss=0.691]\n",
      "100%|██████████| 38/38 [00:03<00:00, 11.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.9784232365145228\n",
      "valid set loss: 0.6543428897857666\n",
      "Epoch 9:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.43it/s, loss=0.814]\n",
      "100%|██████████| 38/38 [00:03<00:00, 12.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.979253112033195\n",
      "valid set loss: 0.6536799669265747\n",
      "Epoch 10:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 157/157 [00:16<00:00,  9.55it/s, loss=0.6]  \n",
      "100%|██████████| 38/38 [00:03<00:00, 11.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid set accuracy: 0.979253112033195\n",
      "valid set loss: 0.6535065770149231\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "def train(dataloader, model, optimizer):\n",
    "    with tqdm(dataloader) as bar:\n",
    "        for batch in bar:\n",
    "\n",
    "            inputs = batch[\"encoder_params\"][\"weights\"].to(config.device)\n",
    "            targets = batch['digits'].to(config.device)\n",
    "            \n",
    "            # calculate gradients via back propagation\n",
    "            prediction = model(inputs)\n",
    "            loss = criterion(prediction, targets)\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            \n",
    "\n",
    "            optimizer.step()\n",
    "\n",
    "            bar.set_postfix(loss=loss.item())\n",
    "            # print(f\"loss: {loss.item()}\", end='\\r')\n",
    "\n",
    "def valid_test(dataloader, split, model):\n",
    "    target_all = []\n",
    "    output_all = []\n",
    "    with torch.no_grad():\n",
    "        for batch in tqdm(dataloader):\n",
    "            inputs = batch[\"encoder_params\"][\"weights\"].to(config.device)\n",
    "            targets = batch['digits'].to(config.device)\n",
    "\n",
    "            prediction = model(inputs)\n",
    "            target_all.append(targets)\n",
    "            output_all.append(prediction)\n",
    "\n",
    "        target_all = torch.cat(target_all, dim=0)\n",
    "        output_all = torch.cat(output_all, dim=0)\n",
    "#         print(output_all)\n",
    "\n",
    "    _, indices = output_all.topk(1, dim=1)\n",
    "    masks = indices.eq(target_all.view(-1, 1).expand_as(indices))\n",
    "    size = target_all.shape[0]\n",
    "    corrects = masks.sum().item()\n",
    "    accuracy = corrects / size\n",
    "    loss = criterion(output_all, target_all).item()\n",
    "\n",
    "    print(f\"{split} set accuracy: {accuracy}\")\n",
    "    print(f\"{split} set loss: {loss}\")\n",
    "\n",
    "\n",
    "\n",
    "weight_shapes = {\"weights\": (config.n_ansatz_layers, config.n_qubits, 3)}\n",
    "\n",
    "qlayer = qml.qnn.TorchLayer(circuit, weight_shapes, init_method=nn.init.uniform_)\n",
    "# expecting (B, n_encoder_layers, n_qubits)\n",
    "model = torch.nn.Sequential(nn.Flatten(), qlayer, nn.LogSoftmax(dim=-1)).to(config.device)\n",
    "\n",
    "criterion = nn.NLLLoss()\n",
    "\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=5e-3, weight_decay=1e-4)\n",
    "scheduler = torch.optim.lr_scheduler.CosineAnnealingLR(optimizer, T_max=config.n_epochs)\n",
    "\n",
    "for epoch in range(1, config.n_epochs + 1):\n",
    "    # train\n",
    "    print(f\"Epoch {epoch}:\")\n",
    "    train(train_loader, model, optimizer)\n",
    "    # print(optimizer.param_groups[0]['lr'])\n",
    "\n",
    "    # valid\n",
    "    valid_test(val_loader, 'valid', model)\n",
    "    scheduler.step()\n",
    "\n",
    "# test\n",
    "# valid(test_loader, 'test', model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 62/62 [00:05<00:00, 12.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test set accuracy: 0.9801829268292683\n",
      "test set loss: 0.6503280401229858\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "valid_test(test_loader, 'test', model)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**pennylane amplitude encoding**\n",
    "\n",
    "Epoch 1:\n",
    "0.005 0.8584052324295044\n",
    "valid set accuracy: 0.6730290456431536\n",
    "valid set loss: 0.9551709294319153\n",
    "\n",
    "Epoch 2:\n",
    "0.0048776412907378846457\n",
    "valid set accuracy: 0.8929460580912864\n",
    "valid set loss: 0.7974672913551331\n",
    "\n",
    "Epoch 3:\n",
    "0.0045225424859373685027\n",
    "valid set accuracy: 0.9352697095435685\n",
    "valid set loss: 0.753818690776825\n",
    "\n",
    "Epoch 4:\n",
    "0.0039694631307311836213\n",
    "valid set accuracy: 0.9485477178423236\n",
    "valid set loss: 0.7371468544006348\n",
    "\n",
    "Epoch 5:\n",
    "0.0032725424859373687498\n",
    "valid set accuracy: 0.9609958506224067\n",
    "valid set loss: 0.727253794670105\n",
    "\n",
    "Epoch 6:\n",
    "0.00250.6985626816749573\n",
    "valid set accuracy: 0.9643153526970955\n",
    "valid set loss: 0.721916913986206\n",
    "\n",
    "Epoch 7:\n",
    "0.0017274575140626316482\n",
    "valid set accuracy: 0.970954356846473\n",
    "valid set loss: 0.7195770144462585\n",
    "\n",
    "Epoch 8:\n",
    "0.0010305368692688174391\n",
    "valid set accuracy: 0.9701244813278008\n",
    "valid set loss: 0.7184303998947144\n",
    "\n",
    "Epoch 9:\n",
    "0.0004774575140626316366\n",
    "valid set accuracy: 0.9734439834024896\n",
    "valid set loss: 0.7179780006408691\n",
    "\n",
    "Epoch 10:\n",
    "0.0001223587092621161729\n",
    "valid set accuracy: 0.9742738589211618\n",
    "valid set loss: 0.7178515195846558\n",
    "\n",
    "test set accuracy: 0.9715447154471545\n",
    "test set loss: 0.7131120562553406\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**pennylane angle ecoding**\n",
    "\n",
    "Epoch 1:\n",
    "0.005 1.0613005161285421\n",
    "valid set accuracy: 0.8721991701244813\n",
    "valid set loss: 0.9659674167633057\n",
    "\n",
    "Epoch 2:\n",
    "0.0048776412907378846388\n",
    "valid set accuracy: 0.9294605809128631\n",
    "valid set loss: 0.7519037127494812\n",
    "\n",
    "Epoch 3:\n",
    "0.0045225424859373685668\n",
    "valid set accuracy: 0.9427385892116182\n",
    "valid set loss: 0.6945566534996033\n",
    "\n",
    "Epoch 4:\n",
    "0.0039694631307311838341\n",
    "valid set accuracy: 0.9477178423236514\n",
    "valid set loss: 0.6593191027641296\n",
    "\n",
    "Epoch 5:\n",
    "0.0032725424859373687941\n",
    "valid set accuracy: 0.941908713692946\n",
    "valid set loss: 0.6438149809837341\n",
    "\n",
    "Epoch 6:\n",
    "0.00250.6027146577835083\n",
    "valid set accuracy: 0.9394190871369295\n",
    "valid set loss: 0.637258768081665\n",
    "\n",
    "Epoch 7:\n",
    "0.0017274575140626316727\n",
    "valid set accuracy: 0.9402489626556016\n",
    "valid set loss: 0.6341438889503479\n",
    "\n",
    "Epoch 8:\n",
    "0.0010305368692688174798\n",
    "valid set accuracy: 0.9402489626556016\n",
    "valid set loss: 0.63267982006073\n",
    "\n",
    "Epoch 9:\n",
    "0.0004774575140626316303\n",
    "valid set accuracy: 0.9410788381742738\n",
    "valid set loss: 0.6321021318435669\n",
    "\n",
    "Epoch 10:\n",
    "0.0001223587092621161779\n",
    "valid set accuracy: 0.9410788381742738\n",
    "valid set loss: 0.6319551467895508\n",
    "\n",
    "test set accuracy: 0.9242886178861789\n",
    "test set loss: 0.639994740486145\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**AAE**\n",
    "\n",
    "Epoch 1:\n",
    "100%|██████████| 157/157 [00:17<00:00,  9.23it/s, loss=0.81] \n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 11.31it/s]\n",
    "valid set accuracy: 0.9518672199170124\n",
    "valid set loss: 0.806155800819397\n",
    "\n",
    "Epoch 2:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.33it/s, loss=0.685]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 11.88it/s]\n",
    "valid set accuracy: 0.9759336099585062\n",
    "valid set loss: 0.7286494374275208\n",
    "\n",
    "Epoch 3:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.37it/s, loss=0.75] \n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.11it/s]\n",
    "valid set accuracy: 0.975103734439834\n",
    "valid set loss: 0.6749855279922485\n",
    "\n",
    "Epoch 4:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.26it/s, loss=0.632]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.25it/s]\n",
    "valid set accuracy: 0.9684647302904564\n",
    "valid set loss: 0.6676006317138672\n",
    "\n",
    "Epoch 5:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.47it/s, loss=0.824]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.14it/s]\n",
    "valid set accuracy: 0.983402489626556\n",
    "valid set loss: 0.6617234349250793\n",
    "\n",
    "Epoch 6:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.44it/s, loss=0.74] \n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.12it/s]\n",
    "valid set accuracy: 0.9842323651452282\n",
    "valid set loss: 0.6582380533218384\n",
    "\n",
    "Epoch 7:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.50it/s, loss=0.746]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.31it/s]\n",
    "valid set accuracy: 0.979253112033195\n",
    "valid set loss: 0.6556654572486877\n",
    "\n",
    "Epoch 8:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.44it/s, loss=0.691]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 11.44it/s]\n",
    "valid set accuracy: 0.9784232365145228\n",
    "valid set loss: 0.6543428897857666\n",
    "\n",
    "Epoch 9:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.43it/s, loss=0.814]\n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 12.05it/s]\n",
    "valid set accuracy: 0.979253112033195\n",
    "valid set loss: 0.6536799669265747\n",
    "\n",
    "Epoch 10:\n",
    "100%|██████████| 157/157 [00:16<00:00,  9.55it/s, loss=0.6]  \n",
    "\n",
    "100%|██████████| 38/38 [00:03<00:00, 11.86it/s]valid set accuracy: 0.979253112033195\n",
    "valid set loss: 0.6535065770149231\n",
    "\n",
    "\n",
    "**Test set result**\n",
    "100%|██████████| 62/62 [00:05<00:00, 12.17it/s]test set accuracy: 0.9801829268292683\n",
    "test set loss: 0.6503280401229858\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "qenc",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
