{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/root/projects/JiangWenle/qenc\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/miniconda3/envs/qenc/lib/python3.10/site-packages/IPython/core/magics/osm.py:417: UserWarning: using dhist requires you to install the `pickleshare` library.\n",
      "  self.shell.db['dhist'] = compress_dhist(dhist)[-100:]\n"
     ]
    }
   ],
   "source": [
    "%cd ..\n",
    "\n",
    "import os\n",
    "from dataclasses import dataclass\n",
    "\n",
    "import torch \n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader\n",
    "import torchvision\n",
    "\n",
    "import pennylane as qml \n",
    "\n",
    "from data_utils.aae_dataset import MNIST_AAE_Dataset\n",
    "from models.batch_encoders import aae_encoder_for_train\n",
    "from models.superencoders import MLP\n",
    "from utils import resize_and_norm, visual_compare"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8\n",
      "4\n",
      "./mnist/processed\n",
      "./mnist/models/superencoder_v0.0.6.1_state.pt\n"
     ]
    }
   ],
   "source": [
    "from dataclasses import dataclass\n",
    "\n",
    "@dataclass\n",
    "class Config:\n",
    "    # General args\n",
    "    mode: str = \"train\"\n",
    "    seed: int = 42\n",
    "\n",
    "    # Model args\n",
    "    super_encoder_type: str = \"mlp\"\n",
    "    model: str = \"state\"\n",
    "    version: str = \"v0.0.1\"\n",
    "    n_qubits: int = 8\n",
    "    n_encoder_layers: int = 32\n",
    "    n_ansatz_layers: int = 5\n",
    "\n",
    "    # Training args\n",
    "    data_dir: str = \"./mnist/processed\"\n",
    "    n_epochs: int = 10\n",
    "    batch_size: int = 4\n",
    "    learning_rate: float = 5e-3\n",
    "    weight_decay: float = 1e-4\n",
    "    num_workers: int = 0\n",
    "    pin_memory: bool = False\n",
    "\n",
    "    # Additional info\n",
    "    device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "    q_device = None\n",
    "    save_path: str = \"./mnist/models/superencoder_v0.0.6.1_state.pt\"\n",
    "\n",
    "    def __post_init__(self):\n",
    "        # Set additional info based on provided values\n",
    "        self.q_device = qml.device(\"default.qubit\", wires=self.n_qubits)\n",
    "\n",
    "# Create an instance of the Config data class\n",
    "args = Config()\n",
    "\n",
    "# Access the configuration values as attributes\n",
    "print(args.n_qubits)\n",
    "print(args.batch_size)\n",
    "print(args.data_dir)\n",
    "print(args.save_path)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# data\n",
    "train_path = os.path.join(args.data_dir, \"mnist_train.pt\")\n",
    "val_path = os.path.join(args.data_dir, \"mnist_valid.pt\")\n",
    "test_path = os.path.join(args.data_dir, \"mnist_test.pt\")\n",
    "\n",
    "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(\n",
    "    train_ds,\n",
    "    args.batch_size,\n",
    "    True,\n",
    "    num_workers=args.num_workers,\n",
    "    pin_memory=args.pin_memory,\n",
    ")\n",
    "val_loader = DataLoader(\n",
    "    val_ds,\n",
    "    args.batch_size,\n",
    "    False,\n",
    "    num_workers=args.num_workers,\n",
    "    pin_memory=args.pin_memory,\n",
    ")\n",
    "test_loader = DataLoader(\n",
    "    test_ds,\n",
    "    args.batch_size,\n",
    "    False,\n",
    "    num_workers=args.num_workers,\n",
    "    pin_memory=args.pin_memory,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([4, 1, 28, 28])\n",
      "tensor([1, 1, 0, 0])\n",
      "torch.Size([4, 32])\n"
     ]
    }
   ],
   "source": [
    "samples = next(iter(train_loader))\n",
    "print(samples[\"images\"].shape)\n",
    "print(samples[\"digits\"])\n",
    "print(samples[\"pred_params\"].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# wrap around aae_encoder_for_train\n",
    "@qml.qnode(args.q_device, interface=\"torch\", diff_method=\"backprop\")\n",
    "@qml.simplify\n",
    "def aae_encoder(weights): # TODO: need refactor for batch_encoders.py and encoders.py\n",
    "    aae_encoder_for_train(weights, args.n_encoder_layers, args.n_qubits)\n",
    "    return qml.state()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "shape '[256, 32, 8]' is invalid for input of size 256",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[7], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mqml\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw_mpl\u001b[49m\u001b[43m(\u001b[49m\u001b[43maae_encoder\u001b[49m\u001b[43m)\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrandn\u001b[49m\u001b[43m(\u001b[49m\u001b[43m(\u001b[49m\u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_encoder_layers\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_qubits\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/pennylane/drawer/draw.py:542\u001b[0m, in \u001b[0;36m_draw_mpl_qnode.<locals>.wrapper\u001b[0;34m(*args, **kwargs_qnode)\u001b[0m\n\u001b[1;32m    540\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m    541\u001b[0m     qnode\u001b[38;5;241m.\u001b[39mexpansion_strategy \u001b[38;5;241m=\u001b[39m expansion_strategy \u001b[38;5;129;01mor\u001b[39;00m original_expansion_strategy\n\u001b[0;32m--> 542\u001b[0m     \u001b[43mqnode\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mconstruct\u001b[49m\u001b[43m(\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkwargs_qnode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    543\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m    544\u001b[0m     qnode\u001b[38;5;241m.\u001b[39mexpansion_strategy \u001b[38;5;241m=\u001b[39m original_expansion_strategy\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/pennylane/qnode.py:872\u001b[0m, in \u001b[0;36mQNode.construct\u001b[0;34m(self, args, kwargs)\u001b[0m\n\u001b[1;32m    869\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m old_interface \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mauto\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[1;32m    870\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39minterface \u001b[38;5;241m=\u001b[39m qml\u001b[38;5;241m.\u001b[39mmath\u001b[38;5;241m.\u001b[39mget_interface(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;28mlist\u001b[39m(kwargs\u001b[38;5;241m.\u001b[39mvalues()))\n\u001b[0;32m--> 872\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_tape \u001b[38;5;241m=\u001b[39m \u001b[43mmake_qscript\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mshots\u001b[49m\u001b[43m)\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    873\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_qfunc_output \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtape\u001b[38;5;241m.\u001b[39m_qfunc_output\n\u001b[1;32m    875\u001b[0m params \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtape\u001b[38;5;241m.\u001b[39mget_parameters(trainable_only\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/pennylane/tape/qscript.py:1531\u001b[0m, in \u001b[0;36mmake_qscript.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m   1529\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapper\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m AnnotatedQueue() \u001b[38;5;28;01mas\u001b[39;00m q:\n\u001b[0;32m-> 1531\u001b[0m         result \u001b[38;5;241m=\u001b[39m \u001b[43mfn\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1533\u001b[0m     qscript \u001b[38;5;241m=\u001b[39m QuantumScript\u001b[38;5;241m.\u001b[39mfrom_queue(q, shots)\n\u001b[1;32m   1534\u001b[0m     qscript\u001b[38;5;241m.\u001b[39m_qfunc_output \u001b[38;5;241m=\u001b[39m result\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/pennylane/ops/functions/simplify.py:104\u001b[0m, in \u001b[0;36msimplify.<locals>.qfunc\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    102\u001b[0m \u001b[38;5;129m@wraps\u001b[39m(old_qfunc)\n\u001b[1;32m    103\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mqfunc\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[0;32m--> 104\u001b[0m     qs \u001b[38;5;241m=\u001b[39m \u001b[43mmake_qscript\u001b[49m\u001b[43m(\u001b[49m\u001b[43mold_qfunc\u001b[49m\u001b[43m)\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    105\u001b[0m     _ \u001b[38;5;241m=\u001b[39m [qml\u001b[38;5;241m.\u001b[39msimplify(op) \u001b[38;5;28;01mfor\u001b[39;00m op \u001b[38;5;129;01min\u001b[39;00m qs\u001b[38;5;241m.\u001b[39moperations]\n\u001b[1;32m    106\u001b[0m     m \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mtuple\u001b[39m(qml\u001b[38;5;241m.\u001b[39msimplify(m) \u001b[38;5;28;01mfor\u001b[39;00m m \u001b[38;5;129;01min\u001b[39;00m qs\u001b[38;5;241m.\u001b[39mmeasurements)\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/pennylane/tape/qscript.py:1531\u001b[0m, in \u001b[0;36mmake_qscript.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m   1529\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapper\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m AnnotatedQueue() \u001b[38;5;28;01mas\u001b[39;00m q:\n\u001b[0;32m-> 1531\u001b[0m         result \u001b[38;5;241m=\u001b[39m \u001b[43mfn\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1533\u001b[0m     qscript \u001b[38;5;241m=\u001b[39m QuantumScript\u001b[38;5;241m.\u001b[39mfrom_queue(q, shots)\n\u001b[1;32m   1534\u001b[0m     qscript\u001b[38;5;241m.\u001b[39m_qfunc_output \u001b[38;5;241m=\u001b[39m result\n",
      "Cell \u001b[0;32mIn[5], line 5\u001b[0m, in \u001b[0;36maae_encoder\u001b[0;34m(weights)\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[38;5;129m@qml\u001b[39m\u001b[38;5;241m.\u001b[39mqnode(args\u001b[38;5;241m.\u001b[39mq_device, interface\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtorch\u001b[39m\u001b[38;5;124m\"\u001b[39m, diff_method\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mbackprop\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m      3\u001b[0m \u001b[38;5;129m@qml\u001b[39m\u001b[38;5;241m.\u001b[39msimplify\n\u001b[1;32m      4\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21maae_encoder\u001b[39m(weights): \u001b[38;5;66;03m# TODO: need refactor for batch_encoders.py and encoders.py\u001b[39;00m\n\u001b[0;32m----> 5\u001b[0m     \u001b[43maae_encoder_for_train\u001b[49m\u001b[43m(\u001b[49m\u001b[43mweights\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_encoder_layers\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_qubits\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m qml\u001b[38;5;241m.\u001b[39mstate()\n",
      "File \u001b[0;32m~/projects/JiangWenle/qenc/models/batch_encoders.py:32\u001b[0m, in \u001b[0;36maae_encoder_for_train\u001b[0;34m(encoder_params, num_layers, num_qubits)\u001b[0m\n\u001b[1;32m     30\u001b[0m inputs_shape \u001b[38;5;241m=\u001b[39m encoder_params\u001b[38;5;241m.\u001b[39mshape\n\u001b[1;32m     31\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m l \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_layers):\n\u001b[0;32m---> 32\u001b[0m     encoder_params \u001b[38;5;241m=\u001b[39m \u001b[43mencoder_params\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mview\u001b[49m\u001b[43m(\u001b[49m\u001b[43minputs_shape\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_layers\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_qubits\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     33\u001b[0m     RY_layer(weights\u001b[38;5;241m=\u001b[39mencoder_params[:, l])\n\u001b[1;32m     34\u001b[0m     EntanglingLayer(num_qubits)\n",
      "\u001b[0;31mRuntimeError\u001b[0m: shape '[256, 32, 8]' is invalid for input of size 256"
     ]
    }
   ],
   "source": [
    "qml.draw_mpl(aae_encoder)(torch.randn((args.n_encoder_layers*args.n_qubits)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './mnist/models/superencoder_v0.0.6.1_state.pt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[8], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m model \u001b[38;5;241m=\u001b[39m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msave_path\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m model\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/torch/serialization.py:986\u001b[0m, in \u001b[0;36mload\u001b[0;34m(f, map_location, pickle_module, weights_only, mmap, **pickle_load_args)\u001b[0m\n\u001b[1;32m    983\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m pickle_load_args\u001b[38;5;241m.\u001b[39mkeys():\n\u001b[1;32m    984\u001b[0m     pickle_load_args[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m--> 986\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[43m_open_file_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m opened_file:\n\u001b[1;32m    987\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_zipfile(opened_file):\n\u001b[1;32m    988\u001b[0m         \u001b[38;5;66;03m# The zipfile reader is going to advance the current file position.\u001b[39;00m\n\u001b[1;32m    989\u001b[0m         \u001b[38;5;66;03m# If we want to actually tail call to torch.jit.load, we need to\u001b[39;00m\n\u001b[1;32m    990\u001b[0m         \u001b[38;5;66;03m# reset back to the original position.\u001b[39;00m\n\u001b[1;32m    991\u001b[0m         orig_position \u001b[38;5;241m=\u001b[39m opened_file\u001b[38;5;241m.\u001b[39mtell()\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/torch/serialization.py:435\u001b[0m, in \u001b[0;36m_open_file_like\u001b[0;34m(name_or_buffer, mode)\u001b[0m\n\u001b[1;32m    433\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_open_file_like\u001b[39m(name_or_buffer, mode):\n\u001b[1;32m    434\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_path(name_or_buffer):\n\u001b[0;32m--> 435\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_open_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    436\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    437\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mw\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01min\u001b[39;00m mode:\n",
      "File \u001b[0;32m~/miniconda3/envs/qenc/lib/python3.10/site-packages/torch/serialization.py:416\u001b[0m, in \u001b[0;36m_open_file.__init__\u001b[0;34m(self, name, mode)\u001b[0m\n\u001b[1;32m    415\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, name, mode):\n\u001b[0;32m--> 416\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: './mnist/models/superencoder_v0.0.6.1_state.pt'"
     ]
    }
   ],
   "source": [
    "model = torch.load(args.save_path)\n",
    "model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'model' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[9], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m args\u001b[38;5;241m.\u001b[39mmodel \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mstate\u001b[39m\u001b[38;5;124m\"\u001b[39m:  \u001b[38;5;66;03m# when I load saved state model, I got a ModuleList, cann't forward throught ModuleList\u001b[39;00m\n\u001b[1;32m      2\u001b[0m     \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mmodels\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mstate_generators\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m MLPStateGenerator\n\u001b[0;32m----> 3\u001b[0m     model_ \u001b[38;5;241m=\u001b[39m MLPStateGenerator(\u001b[43mmodel\u001b[49m[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m.\u001b[39min_features, model[\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mout_features, aae_encoder)    \n\u001b[1;32m      4\u001b[0m     model_\u001b[38;5;241m.\u001b[39mlayers[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;241m=\u001b[39m model[\u001b[38;5;241m0\u001b[39m]\n\u001b[1;32m      5\u001b[0m     model_\u001b[38;5;241m.\u001b[39mlayers[\u001b[38;5;241m1\u001b[39m] \u001b[38;5;241m=\u001b[39m model[\u001b[38;5;241m1\u001b[39m]\n",
      "\u001b[0;31mNameError\u001b[0m: name 'model' is not defined"
     ]
    }
   ],
   "source": [
    "if args.model == \"state\":  # when I load saved state model, I got a ModuleList, cann't forward throught ModuleList\n",
    "    from models.state_generators import MLPStateGenerator\n",
    "    model_ = MLPStateGenerator(model[0].in_features, model[1].out_features, aae_encoder)    \n",
    "    model_.layers[0] = model[0]\n",
    "    model_.layers[1] = model[1]\n",
    "    pred = model_(resize_and_norm(samples[\"images\"], args.n_qubits))\n",
    "    print(pred[0].shape)\n",
    "else:\n",
    "    pred = model(resize_and_norm(samples[\"images\"], args.n_qubits))\n",
    "    print(pred.shape)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Encoded State Analyze "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# aae_state = aae_encoder(samples[\"encoder_params\"][\"weights\"], args.n_encoder_layers, args.n_qubits)\n",
    "image_data = resize_and_norm(samples[\"images\"], args.n_qubits)\n",
    "super_encoder_state = aae_encoder(samples[\"pred_params\"])\n",
    "# print(super_encoder_state)\n",
    "# # print(aae_state)\n",
    "# print(image_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([256])"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "super_encoder_state[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1, 0, 1, 1])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/projects/JiangWenle/qenc/utils.py:34: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at ../aten/src/ATen/native/Copy.cpp:299.)\n",
      "  super_encoder_state = super_encoder_state.detach().clone().type(torch.float64)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAo0AAAUSCAYAAABsOstVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACXuklEQVR4nOzde3hU5bn+8Xsyk0xCSAbCIQcJEAFROakgbAUtlNSYIpXueiy1EVusilpK6yH7V8BzirWWatlg3buCVhB1F7S21VoKUiuggLRaKwJGiGA4KQlJyCSZWb8/WsZGwDfJu4Y58P1c11yayXqf9WRl8nBnTWaNx3EcRwAAAMDnSIl1AwAAAIh/hEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERpwwFi5cKI/How8++CDWrQAAkHAIjUCMLF68WHPnzu3w+oaGBt1xxx1atWqVaz0BOLHdd999Wr58eYfXv/POO7rjjjv45TxJERqBGHEjNN55552ERgCucSM03nnnnYTGJEVoxFHV19fHuoW4xzECAJxICI3HwcGDBzV9+nT17dtXfr9fPXv21Je+9CVt3Lgxsk3fvn119dVXH7F27NixGjt2bOTjVatWyePxaOnSpfqv//ov5eXlKTMzU1/5yldUVVV1xPp169bpwgsvVCAQUKdOnfSFL3xBf/nLX1ptc8cdd8jj8eidd97R17/+dXXt2lVjxoz53K/pwIEDmj59ugoLC+X3+9W/f3/NmTNH4XA4ss0HH3wgj8ejBx54QL/4xS/Ur18/+f1+nX322XrjjTeOqPnuu+/qsssuU48ePZSRkaGBAwfq//2//9dqmzfffFOlpaXKzs5W586dNX78eK1du/aIWn//+9/1xS9+URkZGerVq5fuueeeVr39u9///vc677zzlJmZqaysLE2YMEF///vfW21z9dVXq3Pnztq2bZu+/OUvKysrS5MnTz7m8TF9z8eOHavf/va32r59uzwejzwej/r27StJampq0qxZszR8+HAFAgFlZmbqvPPO08qVK1sd2x49ekiS7rzzzkiNO+64o9XxvOSSS5STk6P09HSNGDFCzz///DF7BuCu7du364YbbtDAgQOVkZGhbt266dJLLz3iLNzHH3+sH/zgBxoyZIg6d+6s7OxslZaW6q9//esRNYPBoGbPnq3+/fvL7/ersLBQt956q4LBoLGfLVu26Gtf+5ry8vKUnp6uXr166YorrlBNTY0kyePxqL6+XosWLYrMlMP/LrXla1m4cKEuvfRSSdK4ceMiNf792ZC2zFvEL1+sGzgRXHfddXr22Wd144036vTTT9f+/fv16quv6h//+IfOOuusDtW899575fF4dNttt2nPnj2aO3euiouLtWnTJmVkZEiS/vSnP6m0tFTDhw/X7NmzlZKSoscee0xf/OIX9ec//1kjR45sVfPSSy/VgAEDdN9998lxnGPuu6GhQV/4whe0c+dOfec731Hv3r312muvqby8XB999NERT7kuXrxYBw8e1He+8x15PB7df//9+s///E+9//77Sk1NlST97W9/03nnnafU1FRde+216tu3r7Zt26bf/OY3uvfeeyX9Mwied955ys7O1q233qrU1FQ98sgjGjt2rF555RWNGjVKklRdXa1x48appaVFt99+uzIzM/WLX/wiclz+3RNPPKGysjKVlJRozpw5amho0Pz58zVmzBi9+eabkSAnSS0tLSopKdGYMWP0wAMPqFOnTsc8Rqbv+f/7f/9PNTU1+vDDD/XTn/5UktS5c2dJUm1trf7nf/5HV155paZOnaqDBw/qf//3f1VSUqLXX39dZ5xxhnr06KH58+fr+uuv11e/+lX953/+pyRp6NChkWM1evRonXTSSZFj8PTTT2vSpEn6v//7P331q189Zu8A3PHGG2/otdde0xVXXKFevXrpgw8+0Pz58zV27Fi98847kRny/vvva/ny5br00ktVVFSk3bt365FHHtEXvvAFvfPOOyooKJAkhcNhfeUrX9Grr76qa6+9Vqeddpreeust/fSnP9V77733uU8rNzU1qaSkRMFgUDfddJPy8vK0c+dOvfDCCzpw4IACgYCeeOIJffvb39bIkSN17bXXSpL69evX5q/l/PPP180336yHHnpI//Vf/6XTTjtNkiL/bc+8RZxyEHWBQMCZNm3a527Tp08fp6ys7Ij7v/CFLzhf+MIXIh+vXLnSkeScdNJJTm1tbeT+p59+2pHk/OxnP3Mcx3HC4bAzYMAAp6SkxAmHw5HtGhoanKKiIudLX/pS5L7Zs2c7kpwrr7yyTV/P3Xff7WRmZjrvvfdeq/tvv/12x+v1Ojt27HAcx3EqKysdSU63bt2c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3r27c+655zoPPPCA09TU5DjOp5fc+fGPf3zEeh3lUjFvv/2289WvftXp0qWLk56e7gwcONCZOXNmq202btzolJSUOJ07d3Y6derkjBs3znnttdeOqP+3v/3N+cIXvuCkp6c7J510knP33Xc7//u//9vqkjuHrVy50ikpKXECgYCTnp7u9OvXz7n66qud9evXR7YpKytzMjMz23Rs2vo9r6urc77+9a87Xbp0cSRFLr8TDoed++67z+nTp4/j9/udM88803nhhRecsrKyIy7R89prrznDhw930tLSjjim27Ztc775zW86eXl5TmpqqnPSSSc5F110kfPss8+26esAYOeTTz5xpkyZ4nTv3t3p3LmzU1JS4rz77rtHXGKtsbHR+f73v+/k5+c7GRkZzujRo501a9YcMf8dx3GampqcOXPmOIMGDXL8fr/TtWtXZ/jw4c6dd97p1NTUHLOX999/37nmmmucfv36Oenp6U5OTo4zbtw4549//GOr7d59913n/PPPdzIyMhxJkT7b+rU4juM8+uijzsknn+x4vd4jLr/TlnmL+OVxnBi/GgHtsmrVKo0bN07PPPOMLrnkkli3AwAAThD8TSMAAACMCI0AAAAwIjQCAADAiL9pBAAAgBFnGgEAAGBEaAQAAIBR3F3cOxwOa9euXcrKyurw2yQBODE4jqODBw+qoKCgze8LfqJglgJoi/bM0bgLjbt27TK+6ToA/Luqqir16tUr1m3EFWYpgPZoyxyNu9CYlZUlSTp/4M3yef0drnPopM5WffgaQ+aNDFKa7GuE0u2/RZ6w3WudfA1Hvk9oezV16fj38jD/R8d+X9U289qdcQllplm30JIZHz92Gdv2Wa13/PbHoqFvwGp9S0uj3lhREZkb+NThYzJGX5ZPqTHuBkC8alGzXtXv2jRH4+Nfr39z+GkUn9dvFRp9qelWffhaXAiNYfsaHl8chEav17qHsM8+NPq8LdY1bEOjx4WvQy58T93gS7H7WhyvfWi0/Tk9jKdfjxSZpUqVz0NoBHAM/4oIbZmj/BEQAAAAjKIWGufNm6e+ffsqPT1do0aN0uuvvx6tXQFAUmKOAognUQmNS5cu1YwZMzR79mxt3LhRw4YNU0lJifbs2RON3QFA0mGOAog3UQmNDz74oKZOnaopU6bo9NNP14IFC9SpUyf98pe/jMbuACDpMEcBxBvXQ2NTU5M2bNig4uLiT3eSkqLi4mKtWbPG7d0BQNJhjgKIR66/jHPfvn0KhULKzc1tdX9ubq7efffdI7YPBoMKBoORj2tra91uCQASSnvnqMQsBRB9MX/1dEVFhQKBQOTGxWgBoP2YpQCizfXQ2L17d3m9Xu3evbvV/bt371ZeXt4R25eXl6umpiZyq6qqcrslAEgo7Z2jErMUQPS5HhrT0tI0fPhwrVixInJfOBzWihUrdM455xyxvd/vV3Z2dqsbAJzI2jtHJWYpgOiLyltTzJgxQ2VlZRoxYoRGjhypuXPnqr6+XlOmTInG7gAg6TBHAcSbqITGyy+/XHv37tWsWbNUXV2tM844Qy+++OIRf9QNADg65iiAeBO1N8G98cYbdeONN0arPAAkPeYogHgS81dPAwAAIP4RGgEAAGAUtaenY60p22u1Pn3vIfsmPB7rEr5P7C/Q23iS3asoPxqdZd1DzrvN1jX2nd3VukbqIcdqfafqJusewqn2jwtPyLqEnLoGq/Wh3IB1D97GsNV6p8VuPXAi8vYvcqGI3b+xofe22ffg2M1ztB9nGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGvlg3cCzhzFSFfWkdXu9rDNs14Dh26yU5PvtMvv/s7tY1ur9cabU+I7evdQ+fDEi1rjHmmxusa/hSQlbrV/5qpHUPmbssH5uSmjp7rGtIfa1WpzTZfx1p+w/Z9RAKWvcAJJKUYadZ13j6t49Z1/jToRyr9fNOGWjdA44/zjQCAADAiNAIAAAAI0IjAAAAjAiNAAAAMHI9NFZUVOjss89WVlaWevbsqUmTJmnz5s1u7wYAkhZzFEA8cj00vvLKK5o2bZrWrl2rl19+Wc3NzbrgggtUX1/v9q4AICkxRwHEI9cvufPiiy+2+njhwoXq2bOnNmzYoPPPP9/t3QFA0mGOAohHUb9OY01NjSQpJ+fo13QKBoMKBj+91lptbW20WwKAhGKaoxKzFED0RfWFMOFwWNOnT9fo0aM1ePDgo25TUVGhQCAQuRUWFkazJQBIKG2ZoxKzFED0RTU0Tps2TW+//baeeuqpY25TXl6umpqayK2qqiqaLQFAQmnLHJWYpQCiL2pPT99444164YUXtHr1avXq1euY2/n9fvn9/mi1AQAJq61zVGKWAog+10Oj4zi66aabtGzZMq1atUpFRUVu7wIAkhpzFEA8cj00Tps2TYsXL9Zzzz2nrKwsVVdXS5ICgYAyMjLc3h0AJB3mKIB45PrfNM6fP181NTUaO3as8vPzI7elS5e6vSsASErMUQDxKCpPTwMAOo45CiAe8d7TAAAAMIr6xb07qrF7unyp6R1e76sPWe3f8drn6ebOqdY1vE32Zxxqzu1jtT6U5rHuofcl71vXGJz5oXWNhxZfbLU+9x/N1j0c6Gf/uOi5oc66Rkpdk9V6T3OLdQ8Hzuxutb6luVH6m3UbQMI49OND1jU6p3T839bD5l11iV0Bhx/cRMSZRgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGvlg3cCwtGSlSasczbee/fWS1/5oRBVbrJSmwwa4HScrYal1CzQVdrdZXn5th3cNQf511jTl//rJ1jV5/D1mt9+87ZN1DwIVf1Wr6dbKu0WlvmtV6/54G6x5CqR6r9WHHbj1wPH30/XOta/xt8H9b1yh66VvWNU5Zu8G6BhIPZxoBAABgRGgEAACAEaERAAAARlEPjT/60Y/k8Xg0ffr0aO8KAJIScxRAPIhqaHzjjTf0yCOPaOjQodHcDQAkLeYogHgRtdBYV1enyZMn69FHH1XXrnav3gWAExFzFEA8iVponDZtmiZMmKDi4uJo7QIAkhpzFEA8icp1Gp966ilt3LhRb7zxhnHbYDCoYDAY+bi2tjYaLQFAQmnPHJWYpQCiz/UzjVVVVfrud7+rJ598Uunp6cbtKyoqFAgEIrfCwkK3WwKAhNLeOSoxSwFEn+uhccOGDdqzZ4/OOuss+Xw++Xw+vfLKK3rooYfk8/kUCrV+R47y8nLV1NREblVVVW63BAAJpb1zVGKWAog+15+eHj9+vN56661W902ZMkWnnnqqbrvtNnm93laf8/v98vv9brcBAAmrvXNUYpYCiD7XQ2NWVpYGDx7c6r7MzEx169btiPsBAEdijgKIR7wjDAAAAIyi8urpz1q1atXx2A0AJC3mKIBY40wjAAAAjAiNAAAAMDouT093RGp9SL7UIy8r0VZO505W+w9srLZaL0nhLp2ta3iaO34MDqstyrBaP2vCs9Y9/P1QL+saAx5vtq4RTrX7Pcn7cZ11D50O1FvXSO9q/9gK++yOhWO5XpKyqoLmjT5HS4vdeqA9vKefYrX+lekPWPewKXjkK+fb65QpG6xr4MTEmUYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAkS/WDRyLf1+jfBbdNfTJttp/XUGO1XpJ6r7poHWNhsLO1jVyvr3Dav22YK51D7/5v3Ota3Tv3mJdI3N7ndX6T0bmWffQ5c191jXqCztZ18je+JFdD6fZPy7qetmNoFCTI/3Zug2cAHyFvaxr3PXbX1mt7+q1/7ktvf066xoBrbWugRMTZxoBAABgRGgEAACAEaERAAAARoRGAAAAGEUlNO7cuVPf+MY31K1bN2VkZGjIkCFav359NHYFAEmJOQog3rj+6ulPPvlEo0eP1rhx4/T73/9ePXr00JYtW9S1a1e3dwUASYk5CiAeuR4a58yZo8LCQj322GOR+4qKitzeDQAkLeYogHjk+tPTzz//vEaMGKFLL71UPXv21JlnnqlHH330mNsHg0HV1ta2ugHAiay9c1RilgKIPtdD4/vvv6/58+drwIABeumll3T99dfr5ptv1qJFi466fUVFhQKBQORWWFjodksAkFDaO0clZimA6HM9NIbDYZ111lm67777dOaZZ+raa6/V1KlTtWDBgqNuX15erpqamsitqqrK7ZYAIKG0d45KzFIA0ed6aMzPz9fpp5/e6r7TTjtNO3Yc/a3s/H6/srOzW90A4ETW3jkqMUsBRJ/roXH06NHavHlzq/vee+899enTx+1dAUBSYo4CiEeuh8bvfe97Wrt2re677z5t3bpVixcv1i9+8QtNmzbN7V0BQFJijgKIR66HxrPPPlvLli3TkiVLNHjwYN19992aO3euJk+e7PauACApMUcBxCPXr9MoSRdddJEuuuiiaJQGgBMCcxRAvOG9pwEAAGAUlTONbmgo6CRfanqH12dW1VvtP6XJb7VekhpzM6xrfDzQ/lv0rfzXrda/1WB/vbeMvY51jYbuXusa9bkBq/WOfQvaM6aHdY2UkH0fLT3tjkVKc9i6h9zfH/vVwG3REg5a94ATw8HhBdY1hvvTrNaf+cYV1j30fHKtdY1k4Tl7iHUN5423XOjkxMGZRgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGvlg3cCydt9fJ523ueAHHsdq/71DIar0kpb5bbV1jx5d7Wdfo5quzWv/b9wdZ95DS1WNdI+y1LqHmQQ1W668futq6h+LO71jXuGTx96xr+Gs7WdewFR5WYLW+pblR2ulSM0hqNX1j/8/dgf2drWv0dKGPlKws6xr7vzbYan3p9+xn6Z09nrCucfKy71jXGDBtnXWNRMGZRgAAABgRGgEAAGBEaAQAAICR66ExFApp5syZKioqUkZGhvr166e7775bjuXfGALAiYI5CiAeuf6XwXPmzNH8+fO1aNEiDRo0SOvXr9eUKVMUCAR08803u707AEg6zFEA8cj10Pjaa6/p4osv1oQJEyRJffv21ZIlS/T666+7vSsASErMUQDxyPWnp88991ytWLFC7733niTpr3/9q1599VWVlpa6vSsASErMUQDxyPUzjbfffrtqa2t16qmnyuv1KhQK6d5779XkyZOPun0wGFQwGIx8XFtb63ZLAJBQ2jtHJWYpgOhz/Uzj008/rSeffFKLFy/Wxo0btWjRIj3wwANatGjRUbevqKhQIBCI3AoLC91uCQASSnvnqMQsBRB9rofGW265RbfffruuuOIKDRkyRFdddZW+973vqaKi4qjbl5eXq6amJnKrqqpyuyUASCjtnaMSsxRA9Ln+9HRDQ4NSUlpnUa/Xq3A4fNTt/X6//H6/220AQMJq7xyVmKUAos/10Dhx4kTde++96t27twYNGqQ333xTDz74oK655hq3dwUASYk5CiAeuR4aH374Yc2cOVM33HCD9uzZo4KCAn3nO9/RrFmz3N4VACQl5iiAeOR6aMzKytLcuXM1d+5ct0sDwAmBOQogHvHe0wAAADAiNAIAAMDI9aen3RL2exX2dby9sN9rtf+avulW6yWp+8edrGsE/mH3dUiSSuyWX3vaq9Yt/GzvBdY1Zpz/knWND5u6Wq3vk7bPuod3m3KtazTnhKxrpDTbrfc12PfgPdRitT6lpcm6B5wYsnfYP15tVV74P9Y1Btx/vXWNOy5+2rrG5Kw/W9eIB54AM6Q9ONMIAAAAI0IjAAAAjAiNAAAAMCI0AgAAwIjQCAAAACNCIwAAAIwIjQAAADAiNAIAAMCI0AgAAAAjQiMAAACMCI0AAAAwIjQCAADAiNAIAAAAI0IjAAAAjAiNAAAAMPLFuoFj8YTC8ijc8QJ+r9X+u7++z2q9JAXzs61rdNpjcQz+5cYVV1mt/9OFP7XuIe+LNdY1zk6vsq7x3MGhVutTPS3WPWxtPMm6Rq+XPNY1wpY//f7qOuse6osCVutbmh3rHnBiyHx+g3WN0660m6X/GP2EdQ9bvjHfukayuGRbsXWNgTdss64Rsq6QODjTCAAAACNCIwAAAIwIjQAAADAiNAIAAMCo3aFx9erVmjhxogoKCuTxeLR8+fJWn3ccR7NmzVJ+fr4yMjJUXFysLVu2uNUvACQ85iiARNTu0FhfX69hw4Zp3rx5R/38/fffr4ceekgLFizQunXrlJmZqZKSEjU2Nlo3CwDJgDkKIBG1+6IbpaWlKi0tPernHMfR3Llz9cMf/lAXX3yxJOnxxx9Xbm6uli9friuuuMKuWwBIAsxRAInI1b9prKysVHV1tYqLP712UiAQ0KhRo7RmzZqjrgkGg6qtrW11A4ATVUfmqMQsBRB9robG6upqSVJubm6r+3NzcyOf+6yKigoFAoHIrbCw0M2WACChdGSOSsxSANEX81dPl5eXq6amJnKrqrJ/1w8AONEwSwFEm6uhMS8vT5K0e/fuVvfv3r078rnP8vv9ys7ObnUDgBNVR+aoxCwFEH2uhsaioiLl5eVpxYoVkftqa2u1bt06nXPOOW7uCgCSEnMUQLxq96un6+rqtHXr1sjHlZWV2rRpk3JyctS7d29Nnz5d99xzjwYMGKCioiLNnDlTBQUFmjRpkpt9A0DCYo4CSETtDo3r16/XuHHjIh/PmDFDklRWVqaFCxfq1ltvVX19va699lodOHBAY8aM0Ysvvqj09HT3ugaABMYcBZCI2h0ax44dK8dxjvl5j8eju+66S3fddZdVYwCQrJijABJRzF89DQAAgPjX7jONx40j6XN+EzcuT/FY7b56bHer9ZKU9WHIukbYa11C3oN2RYpSO1v3EJb95T/2h/3WNQLeBqv1D7xfYt3DvlfzrWvkNjRZ1/DvO2S1vva0LtY9ZP91r9X6llDQugecGJyWFusaRbMtH29/tG4hboz7+8WxbkHNC459NYG2yqxd50InJw7ONAIAAMCI0AgAAAAjQiMAAACMCI0AAAAwIjQCAADAiNAIAAAAI0IjAAAAjAiNAAAAMCI0AgAAwIjQCAAAACNCIwAAAIwIjQAAADAiNAIAAMCI0AgAAAAjQiMAAACMCI0AAAAw8sW6gWNpyUqTfP4Or09pDFntP3dNjdV6SWrMy7Su4W12rGtkVXqt1p/66lXWPYTf72xdw3fQY12j84d2xzNzd4t1D3137LOuEczLsq7R1DXduoatYO+uVutbWhqlbS41A0TZvAOF1jWe+/YXrWt4XvurdY00bbeukQw9nGg40wgAAAAjQiMAAACMCI0AAAAwandoXL16tSZOnKiCggJ5PB4tX7488rnm5mbddtttGjJkiDIzM1VQUKBvfvOb2rVrl5s9A0BCY44CSETtDo319fUaNmyY5s2bd8TnGhoatHHjRs2cOVMbN27Ur3/9a23evFlf+cpXXGkWAJIBcxRAImr3q6dLS0tVWlp61M8FAgG9/PLLre77+c9/rpEjR2rHjh3q3bt3x7oEgCTCHAWQiKL+N401NTXyeDzq0qVLtHcFAEmJOQogHkT1Oo2NjY267bbbdOWVVyo7O/uo2wSDQQWDwcjHtbW10WwJABJKW+aoxCwFEH1RO9PY3Nysyy67TI7jaP78+cfcrqKiQoFAIHIrLLS/+CkAJIO2zlGJWQog+qISGg8Puu3bt+vll1/+3N+Oy8vLVVNTE7lVVVVFoyUASCjtmaMSsxRA9Ln+9PThQbdlyxatXLlS3bp1+9zt/X6//P6Ov10gACSb9s5RiVkKIPraHRrr6uq0devWyMeVlZXatGmTcnJylJ+fr0suuUQbN27UCy+8oFAopOrqaklSTk6O0tLS3OscABIUcxRAImp3aFy/fr3GjRsX+XjGjBmSpLKyMt1xxx16/vnnJUlnnHFGq3UrV67U2LFjO94pACQJ5iiARNTu0Dh27Fg5jnPMz3/e5wAAzFEAiYn3ngYAAIARoREAAABGUb24t41waorCvo5n2uZMuy/N49j/sXlqbYt1jVB6qnWN7n9tsOthi/0rMh1Ps3WNULr97ziddtRbrfceqLPuIdjH/EpYk3Cqx7pGS6bXar2TYt+D47Wr4Tj2PQBtFXrnPav1z59u/7Pv0V+tawAdxZlGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgJEv1g0cS9q+Rvm8TofXh7LTXOymY1KaQ/Y1muy/RY7P7neDpmyvdQ8tfo91jcC2BusaocxUuwK+bOseUprD1jW8jS3WNTq987HV+mD/ntY9eFo6/jMuSU6L/c8YAKBtONMIAAAAI0IjAAAAjAiNAAAAMCI0AgAAwKjdoXH16tWaOHGiCgoK5PF4tHz58mNue91118nj8Wju3LkWLQJAcmGOAkhE7Q6N9fX1GjZsmObNm/e52y1btkxr165VQUFBh5sDgGTEHAWQiNp9PZfS0lKVlpZ+7jY7d+7UTTfdpJdeekkTJkzocHMAkIyYowASkevXaQyHw7rqqqt0yy23aNCgQcbtg8GggsFg5OPa2lq3WwKAhNLeOSoxSwFEn+svhJkzZ458Pp9uvvnmNm1fUVGhQCAQuRUWFrrdEgAklPbOUYlZCiD6XA2NGzZs0M9+9jMtXLhQHk/b3gGkvLxcNTU1kVtVVZWbLQFAQunIHJWYpQCiz9XQ+Oc//1l79uxR79695fP55PP5tH37dn3/+99X3759j7rG7/crOzu71Q0ATlQdmaMSsxRA9Ln6N41XXXWViouLW91XUlKiq666SlOmTHFzVwCQlJijAOJVu0NjXV2dtm7dGvm4srJSmzZtUk5Ojnr37q1u3bq12j41NVV5eXkaOHCgfbcAkASYowASUbtD4/r16zVu3LjIxzNmzJAklZWVaeHCha41BgDJijkKIBG1OzSOHTtWjuO0efsPPvigvbsAgKTGHAWQiHjvaQAAABi5fnFvt3hCIXkU6vD6YJdUq/1nPPe61XpJSjnjdPsaLWnWNVI/brBaH/J3tu6h085m6xoN+RnWNZo7tf0SJkfT5d2D1j34Pm60rlEzOMe6RmrXfKv1nnDbz5QdS0tXr9365rB1DwCAtuFMIwAAAIwIjQAAADAiNAIAAMCI0AgAAAAjQiMAAACMCI0AAAAwIjQCAADAiNAIAAAAI0IjAAAAjAiNAAAAMCI0AgAAwIjQCAAAACNCIwAAAIwIjQAAADAiNAIAAMDIF+sGPstxHElSSyhoVaeludFuvdNstV6SUiy/BklqabHP9V7bY9li/zDxtNgfTxdKKNTksevBhe9pSqjJuobt41uSPM1hu/X/+lm10dLstVof+tdxcFzoJdlEZqmaJQ4PgGNo0T//cW3LHPU4cTZtP/zwQxUWFsa6DQAJpKqqSr169Yp1G3GFWQqgPdoyR+MuNIbDYe3atUtZWVnyeI5+Vqi2tlaFhYWqqqpSdnb2ce4wuXAs3cXxdJfpeDqOo4MHD6qgoEApKfy1zb8zzVIeq+7ieLqHY+kuN+do3D09nZKS0uYzBtnZ2TygXMKxdBfH012fdzwDgcBx7iYxtHWW8lh1F8fTPRxLd7kxR/nVHAAAAEaERgAAABglZGj0+/2aPXu2/H5/rFtJeBxLd3E83cXxjB6Orbs4nu7hWLrLzeMZdy+EAQAAQPxJyDONAAAAOL4IjQAAADAiNAIAAMCI0AgAAACjhAuN8+bNU9++fZWenq5Ro0bp9ddfj3VLCemOO+6Qx+NpdTv11FNj3VbCWL16tSZOnKiCggJ5PB4tX7681ecdx9GsWbOUn5+vjIwMFRcXa8uWLbFpNgGYjufVV199xOP1wgsvjE2zSYA56g7mqB3mqLuOxxxNqNC4dOlSzZgxQ7Nnz9bGjRs1bNgwlZSUaM+ePbFuLSENGjRIH330UeT26quvxrqlhFFfX69hw4Zp3rx5R/38/fffr4ceekgLFizQunXrlJmZqZKSEjU2Nh7nThOD6XhK0oUXXtjq8bpkyZLj2GHyYI66iznaccxRdx2XOeokkJEjRzrTpk2LfBwKhZyCggKnoqIihl0lptmzZzvDhg2LdRtJQZKzbNmyyMfhcNjJy8tzfvzjH0fuO3DggOP3+50lS5bEoMPE8tnj6TiOU1ZW5lx88cUx6SfZMEfdwxx1D3PUXdGaowlzprGpqUkbNmxQcXFx5L6UlBQVFxdrzZo1MewscW3ZskUFBQU6+eSTNXnyZO3YsSPWLSWFyspKVVdXt3qsBgIBjRo1iseqhVWrVqlnz54aOHCgrr/+eu3fvz/WLSUc5qj7mKPRwRyNDts5mjChcd++fQqFQsrNzW11f25urqqrq2PUVeIaNWqUFi5cqBdffFHz589XZWWlzjvvPB08eDDWrSW8w49HHqvuufDCC/X4449rxYoVmjNnjl555RWVlpYqFArFurWEwhx1F3M0epij7nNjjvqi2B/iWGlpaeT/hw4dqlGjRqlPnz56+umn9a1vfSuGnQFHuuKKKyL/P2TIEA0dOlT9+vXTqlWrNH78+Bh2hhMZcxSJxI05mjBnGrt37y6v16vdu3e3un/37t3Ky8uLUVfJo0uXLjrllFO0devWWLeS8A4/HnmsRs/JJ5+s7t2783htJ+ZodDFH3cMcjb6OzNGECY1paWkaPny4VqxYEbkvHA5rxYoVOuecc2LYWXKoq6vTtm3blJ+fH+tWEl5RUZHy8vJaPVZra2u1bt06Hqsu+fDDD7V//34er+3EHI0u5qh7mKPR15E5mlBPT8+YMUNlZWUaMWKERo4cqblz56q+vl5TpkyJdWsJ5wc/+IEmTpyoPn36aNeuXZo9e7a8Xq+uvPLKWLeWEOrq6lr9dlZZWalNmzYpJydHvXv31vTp03XPPfdowIABKioq0syZM1VQUKBJkybFruk49nnHMycnR3feeae+9rWvKS8vT9u2bdOtt96q/v37q6SkJIZdJybmqHuYo3aYo+46LnPU6rXXMfDwww87vXv3dtLS0pyRI0c6a9eujXVLCenyyy938vPznbS0NOekk05yLr/8cmfr1q2xbithrFy50pF0xK2srMxxnH9eLmLmzJlObm6u4/f7nfHjxzubN2+ObdNx7POOZ0NDg3PBBRc4PXr0cFJTU50+ffo4U6dOdaqrq2PddsJijrqDOWqHOequ4zFHPY7jOJbhFgAAAEkuYf6mEQAAALFDaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARr5YN/BZ4XBYu3btUlZWljweT6zbARDHHMfRwYMHVVBQoJQUfgf+d8xSAG3Rnjkad6Fx165dKiwsjHUbABJIVVWVevXqFes24gqzFEB7tGWOxl1ozMrKkiSN7X2tfClpHa7j+Du+VpKacjtbrZekFr/XukZTtn2NjH3NVuv9VZ9Y99CcF7CuIcexLtHUxe5x0Wn7QeseUurqrWuEumVb1ziU28lqfUqL/fej07Z9Vutbwk1atf2RyNzApw4fkzH6snxKjXE3AOJVi5r1qn7Xpjkad6Hx8NMovpQ0+VL8Ha7jeO3CQdiXbrVekpRqH/jCLtTw+exq+Lwd/z4c5rhxPF0IjeFUu8eFz9tk3UNKSot1DY8L3xNfqt33JMVj//2w+Rn/dzz9eqTILFWqfB5CI4Bj+Ncob8sc5Y+AAAAAYBS10Dhv3jz17dtX6enpGjVqlF5//fVo7QoAkhJzFEA8iUpoXLp0qWbMmKHZs2dr48aNGjZsmEpKSrRnz55o7A4Akg5zFEC8iUpofPDBBzV16lRNmTJFp59+uhYsWKBOnTrpl7/8ZTR2BwBJhzkKIN64Hhqbmpq0YcMGFRcXf7qTlBQVFxdrzZo1R2wfDAZVW1vb6gYAJ7L2zlGJWQog+lwPjfv27VMoFFJubm6r+3Nzc1VdXX3E9hUVFQoEApEb1xUDcKJr7xyVmKUAoi/mr54uLy9XTU1N5FZVVRXrlgAg4TBLAUSb69dp7N69u7xer3bv3t3q/t27dysvL++I7f1+v/x+d67VBgDJoL1zVGKWAog+1880pqWlafjw4VqxYkXkvnA4rBUrVuicc85xe3cAkHSYowDiUVTeEWbGjBkqKyvTiBEjNHLkSM2dO1f19fWaMmVKNHYHAEmHOQog3kQlNF5++eXau3evZs2aperqap1xxhl68cUXj/ijbgDA0TFHAcSbqL339I033qgbb7wxWuUBIOkxRwHEk5i/ehoAAADxL2pnGm2Fszop7O34KwE9lTut9p8WdqzWS1Jqqv3hTU/1WtdI+dDubcfCvXpa99DSyf7r8H8ctK7RadU/rNY3njvQugf/Pvtj4Wx8x7pG56I+VutD3bKsewj2ybFa39LSKFVatwEAaAPONAIAAMCI0AgAAAAjQiMAAACMCI0AAAAwIjQCAADAiNAIAAAAI0IjAAAAjAiNAAAAMCI0AgAAwIjQCAAAACNCIwAAAIwIjQAAADAiNAIAAMCI0AgAAAAjQiMAAACMfLFu4FhCnVLl8aV1eH1qt652DdQctFsvqeGs3tY10nc32Pcxoq/V+kM97B8mqV/fbV3jg/e7W9fotmGw1fruG2ute3DlVzXHsa8RbLJa7t1zwLoFT3OW3fpQ0LoH4HjZe9051jUuvv4V6xrPPjnWukavn2+yWh9usP+3DccfZxoBAABgRGgEAACAEaERAAAARoRGAAAAGLkeGisqKnT22WcrKytLPXv21KRJk7R582a3dwMASYs5CiAeuR4aX3nlFU2bNk1r167Vyy+/rObmZl1wwQWqr693e1cAkJSYowDikeuX3HnxxRdbfbxw4UL17NlTGzZs0Pnnn+/27gAg6TBHAcSjqP9NY01NjSQpJycn2rsCgKTEHAUQD6J6ce9wOKzp06dr9OjRGjz46BdVDgaDCgY/vUBvba0LF08GgCTRljkqMUsBRF9UzzROmzZNb7/9tp566qljblNRUaFAIBC5FRYWRrMlAEgobZmjErMUQPRFLTTeeOONeuGFF7Ry5Ur16tXrmNuVl5erpqYmcquqqopWSwCQUNo6RyVmKYDoc/3pacdxdNNNN2nZsmVatWqVioqKPnd7v98vv9/vdhsAkLDaO0clZimA6HM9NE6bNk2LFy/Wc889p6ysLFVXV0uSAoGAMjIy3N4dACQd5iiAeOT609Pz589XTU2Nxo4dq/z8/Mht6dKlbu8KAJIScxRAPIrK09MAgI5jjgKIR7z3NAAAAIyiep1GG75t1fKlpHV4vRPobNdATsBuvaT0vY3WNfYPzbauEe74YZQknVb2D+secv3214wb1ne1dY2+F+6zWn/zT2+w7sETsi4h39BzrGsEPgiaN/o8LpwM81ieUWtp4Ywcjh9f395W6+/4/iLrHsr/9lXrGj+99lHrGrrWbvnPxnzRuoWW6t3WNdA+nGkEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYOSLdQPHEu7TU2FvesfXp9rl4ZRDLVbrJam+VyfrGs1ZHusaDQWO1frN/3OadQ9/z7D/On5z0ijrGhdfuNZqfX2h3bGUpPy/hKxrhFPtj2dLutdqvX9/o3UPKQ3NdgVCQesegLbacu1JVuvn/NdV1j30emaddY0ff+Eb1jV+t/h/rNbfd2Zv6x78v99tXQPtw5lGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEZRD40/+tGP5PF4NH369GjvCgCSEnMUQDyIamh844039Mgjj2jo0KHR3A0AJC3mKIB4EbXQWFdXp8mTJ+vRRx9V165do7UbAEhazFEA8SRqoXHatGmaMGGCiouLP3e7YDCo2traVjcAQNvnqMQsBRB9Ubm491NPPaWNGzfqjTfeMG5bUVGhO++8MxptAEDCas8clZilAKLP9TONVVVV+u53v6snn3xS6enmd3QpLy9XTU1N5FZVVeV2SwCQUNo7RyVmKYDoc/1M44YNG7Rnzx6dddZZkftCoZBWr16tn//85woGg/J6P337Mr/fL7/f73YbAJCw2jtHJWYpgOhzPTSOHz9eb731Vqv7pkyZolNPPVW33XbbEYMOANAacxRAPHI9NGZlZWnw4MGt7svMzFS3bt2OuB8AcCTmKIB4xDvCAAAAwCgqr57+rFWrVh2P3QBA0mKOAog1zjQCAADA6LicaewI7+4D8qZ0/JWAob497Pb/0T6r9ZKU1rVtl8r4PDkHW6xrZH5k923O/keNdQ+1pwWsazRl2//xf880uwsep9Z4rHto6GH/daQ2ONY1Amt3Wa13MuxfqRvqmmm1PtwSsu4BaKv+979jtT5cV2/dg/1PvuSta7KukSK7WdicZT8HuVbA8ceZRgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAICRL9YNHEu4a5bCXn+H13tawlb7P/gffazWS1KnqnrrGg29Mq1rdN7eYLW+9vQu1j3sGe6xrhEuOGRd4/T0nVbrmwOOdQ/pm+0em5LkDdr3UXt2L6v1mR/UWfcQTvParU+xWw+0R+hATaxbcEXVf9nX+Chk9+9KlzUfWvfQYl0B7cWZRgAAABgRGgEAAGBEaAQAAIARoREAAABGUQmNO3fu1De+8Q1169ZNGRkZGjJkiNavXx+NXQFAUmKOAog3rr96+pNPPtHo0aM1btw4/f73v1ePHj20ZcsWde3a1e1dAUBSYo4CiEeuh8Y5c+aosLBQjz32WOS+oqIit3cDAEmLOQogHrn+9PTzzz+vESNG6NJLL1XPnj115pln6tFHHz3m9sFgULW1ta1uAHAia+8clZilAKLP9dD4/vvva/78+RowYIBeeuklXX/99br55pu1aNGio25fUVGhQCAQuRUWFrrdEgAklPbOUYlZCiD6XA+N4XBYZ511lu677z6deeaZuvbaazV16lQtWLDgqNuXl5erpqYmcquqqnK7JQBIKO2doxKzFED0uR4a8/Pzdfrpp7e677TTTtOOHTuOur3f71d2dnarGwCcyNo7RyVmKYDocz00jh49Wps3b25133vvvac+fezfyxkATgTMUQDxyPXQ+L3vfU9r167Vfffdp61bt2rx4sX6xS9+oWnTprm9KwBISsxRAPHI9dB49tlna9myZVqyZIkGDx6su+++W3PnztXkyZPd3hUAJCXmKIB45Pp1GiXpoosu0kUXXRSN0gBwQmCOAog3vPc0AAAAjKJyptENTd0yFPald3i9J+xY7b/T9nqr9ZKU0thkXSN9r/23aOvXM63WDxx27FdsttVfBv7OukZN+JB1jSW1/a3Wt3QOWfeQ0mJdQp3f3Gldo7mwu9X6li5+6x5a0r1265vtvx9AW22/81yr9TOvWGrdw+Ss/dY1pE3WFfaEPFbr3/9Wb+seet/xoXUNtA9nGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAY+WLdwLGEfSkKp3Y802a8ttlq/y1DTrZa75bdIzOtaww7a4vV+hFddlj3MHzDZdY1GjZ0t64RTnWs1g8ZU2ndQ/XrRdY1WsYUWtdIqw1Zre9UecC6h/BJ2VbrU1rC1j0AbXXlpFVW60OOx7qHot9927rGwPmHrGtUXRCwWr922k+se7jy6TLrGqF33rOucSLhTCMAAACMCI0AAAAwIjQCAADAiNAIAAAAI9dDYygU0syZM1VUVKSMjAz169dPd999txzH7gUIAHCiYI4CiEeuv3p6zpw5mj9/vhYtWqRBgwZp/fr1mjJligKBgG6++Wa3dwcASYc5CiAeuR4aX3vtNV188cWaMGGCJKlv375asmSJXn/9dbd3BQBJiTkKIB65/vT0ueeeqxUrVui99/557aO//vWvevXVV1VaWnrU7YPBoGpra1vdAOBE1t45KjFLAUSf62cab7/9dtXW1urUU0+V1+tVKBTSvffeq8mTJx91+4qKCt15551utwEACau9c1RilgKI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paWlCoVCsW4toTBH3cUcjR7mqPvcmKO+KPaHOFZaWhr5/6FDh2rUqFHq06ePnn76aX3rW9+KYWfAka644orI/w8ZMkRDhw5Vv379tGrVKo0fPz6GneFExhxFInFjjibMmcbu3bvL6/Vq9+7dre7fvXu38vLyYtRV8ujSpYtOOeUUbd26NdatJLzDj0ceq9Fz8sknq3v37jxe24k5Gl3MUfcwR6OvI3M0YUJjWlqahg8frhUrVkTuC4fDWrFihc4555wYdpYc6urqtG3bNuXn58e6lYRXVFSkvLy8Vo/V2tparVu3jseqSz788EPt37+fx2s7MUejiznqHuZo9HVkjibU09MzZsxQWVmZRowYoZEjR2ru3Lmqr6/XlClTYt1awvnBD36giRMnqk+fPtq1a5dmz54tr9erK6+8MtatJYS6urpWv51VVlZq06ZNysnJUe/evTV9+nTdc889GjBggIqKijRz5kwVFBRo0qRJsWs6jn3e8czJydGdd96pr33ta8rLy9O2bdt06623qn///iopKYlh14mJOeoe5qgd5qi7jssctXrtdQw8/PDDTu/evZ20tDRn5MiRztq1a2PdUkK6/PLLnfz8fCctLc056aSTnMsvv9zZunVrrNtKGCtXrnQkHXErKytzHOefl4uYOXOmk5ub6/j9fmf8+PHO5s2bY9t0HPu849nQ0OBccMEFTo8ePZzU1FSnT58+ztSpU53q6upYt52wmKPuYI7aYY6663jMUY/jOI5luAUAAECSS5i/aQQAAEDsEBoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYERoBAAAgBGhEQAAAEaERgAAABgRGgEAAGBEaAQAAIARoREAAABGhEYAAAAYERoBAABgRGgEAACAEaERAAAARoRGAAAAGBEaAQAAYOSLdQOfFQ6HtWvXLmVlZcnj8cS6HQBxzHEcHTx4UAUFBUpJ4Xfgf8csBdAW7ZmjcRcad+3apcLCwli3ASCBVFVVqVevXrFuI64wSwG0R1vmaNyFxqysLEnS+afdLJ/X3+E69X2zrPrI/OCg1XpJ8jQErWs09epiXSNtb4PVek+93XpJas7r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",
      "text/plain": [
       "<Figure size 800x1600 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(samples[\"digits\"])\n",
    "# visual_compare(super_encoder_state, aae_state)\n",
    "visual_compare(super_encoder_state, image_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
