{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Imports and Setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch import optim\n",
    "from torch.optim.lr_scheduler import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import os\n",
    "\n",
    "import random\n",
    "\n",
    "import pennylane as qml\n",
    "from pennylane import numpy as np\n",
    "from pennylane.templates import RandomLayers, BasicEntanglerLayers, StronglyEntanglingLayers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x106cab91770>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "processed_data_dir = r\"./mnist/processed/\"\n",
    "\n",
    "# n_qubits = 4 + 1  # 4 data qubit, 1 post selection \n",
    "n_qubits = 4\n",
    "num_encoder_layer = 8 \n",
    "seed = 42\n",
    "\n",
    "batch_size = 1\n",
    "num_epochs = 10\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32m[2023-11-27 15:17:22.679]\u001b[0m \u001b[33m\u001b[1mOnly use the front 5000 images as TRAIN set.\u001b[0m\n",
      "\u001b[32m[2023-11-27 15:17:22.734]\u001b[0m \u001b[33m\u001b[1mOnly use the front 3000 images as TEST set.\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# from data_utils import MNIST\n",
    "\n",
    "# dataset = MNIST(\n",
    "#     root='./mnist',\n",
    "#     train_valid_split_ratio=[0.9, 0.1],\n",
    "#     digits_of_interest=[3, 6],\n",
    "#     n_test_samples=3000,\n",
    "#     n_train_samples=5000\n",
    "# )\n",
    "\n",
    "# dataflow = dict()\n",
    "# for split in dataset:\n",
    "#     sampler = torch.utils.data.RandomSampler(dataset[split])\n",
    "#     dataflow[split] = torch.utils.data.DataLoader(\n",
    "#         dataset[split],\n",
    "#         batch_size=len(dataset[split]),\n",
    "#         sampler=sampler,\n",
    "#         num_workers=0,\n",
    "#         pin_memory=True)\n",
    "    \n",
    "# train_data = next(iter(dataflow[\"train\"]))\n",
    "# val_data = next(iter(dataflow[\"valid\"]))\n",
    "# test_data = next(iter(dataflow[\"test\"]))\n",
    "\n",
    "data = {\n",
    "    \"train\":{\n",
    "        \"images\": train_data[\"image\"],\n",
    "        \"digits\": train_data[\"digit\"],\n",
    "        \"encoder_params\": [torch.nan for _ in range(len(train_data[\"digit\"]))]\n",
    "    },\n",
    "    \"valid\":{\n",
    "        \"images\": val_data[\"image\"],\n",
    "        \"digits\": val_data[\"digit\"],\n",
    "        \"encoder_params\": [torch.nan for _ in range(len(val_data[\"digit\"]))]\n",
    "    },\n",
    "    \"test\":{\n",
    "        \"images\": test_data[\"image\"],\n",
    "        \"digits\": test_data[\"digit\"],\n",
    "        \"encoder_params\": [torch.nan for _ in range(len(test_data[\"digit\"]))]\n",
    "    }\n",
    "}  # only 25M, acceptable\n",
    "\n",
    "# for split in data.keys():\n",
    "#     torch.save(data[split], os.path.join(processed_data_dir, f\"mnist_{split}.pt\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "class MNIST_AAE_Dataset(Dataset):\n",
    "    def __init__(self, processed_data_path) -> None:\n",
    "        super().__init__()\n",
    "        self.processed_data_path = processed_data_path\n",
    "        self.data = torch.load(processed_data_path)\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data[\"digits\"])\n",
    "\n",
    "    def __getitem__(self, index):\n",
    "    \n",
    "        encoder_params = self.data[\"encoder_params\"][index]  # can be torch.nan\n",
    "\n",
    "        return {\n",
    "            \"index\": index, # for setting the encoder_params after training\n",
    "            \"images\": self.data[\"images\"][index],\n",
    "            \"digits\": self.data[\"digits\"][index],\n",
    "            \"encoder_params\": encoder_params\n",
    "        }\n",
    "    \n",
    "    def save_encoder_params(self, index, encoder: nn.Module):\n",
    "        self.data[\"encoder_params\"][index] = encoder.state_dict()\n",
    "\n",
    "    def save_dataset_to_disk(self, path=None):\n",
    "        if path is None:\n",
    "            path = self.processed_data_path\n",
    "\n",
    "        torch.save(self.data, path)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_ds = MNIST_AAE_Dataset(os.path.join(processed_data_dir, \"mnist_train.pt\"))\n",
    "train_loader = DataLoader(train_ds, 4, False)\n",
    "samples = next(iter(train_loader))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### pennylane amplitude encoding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encodelayer(inputs):\n",
    "    for i in range(n_qubits):\n",
    "        qml.RY(inputs[:,i],wires=i)\n",
    "        qml.RZ(inputs[:,i+n_qubits],wires=i)\n",
    "        qml.RX(inputs[:,i+2*n_qubits],wires=i)\n",
    "        qml.RY(inputs[:,i+3*n_qubits],wires=i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "@qml.qnode(q_device, interface=\"torch\")\n",
    "@qml.simplify\n",
    "def quantum_net(inputs, new_weights):  \n",
    "    qml.templates.AmplitudeEmbedding(inputs, wires=range(n_qubits), normalize=True)\n",
    "    # encodelayer(inputs)\n",
    "    StronglyEntanglingLayers(new_weights, wires=range(n_qubits))\n",
    "    return [qml.expval(qml.PauliZ(i)) for i in range(n_qubits)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 2800x500 with 1 Axes>, <Axes: >)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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a9SokZ577jm99dZbgR2gxfXp08eU+wZgDpdffrmk8+8AtrqsrCxJv37Pocbdnh8+fFh/+tOflJqaqqysLOXm5mrZsmWBHawF0XNYDf0IDe60g24glNDz2qMfoYF+AM7oBwB/4vwqdPD7XWPRc1gN/QA8d/r0aafrLVu29Go/DodDffv2ddk+b9481a1b16t9VuXCMf7204LhO5ZeEBwREaEVK1bIbrerf//+GjdunKZOnapu3brpu+++0wsvvKDY2FijhwnAA3l5edqzZ4/uvfdeSdKIESN09OjRipOm32rSpIn69etn+nd4BpsHH3zQlPsGYA49evSQJO3du9fgkfhf+fdY/j2HEk96vn79eg0dOlQtWrSQzWZTcnKyVq9eHeghWw49h9XQD+tztx10A6GEntce/bA++gG4oh8A/Inzq9DA73eNR89hNfQD8Fy3bt109913a9iwYRo0aJCuuuoqr/bz5JNPVrp9ypQptRlepbp27apBgwZp2LBhuvvuu9WtWzefPwYsviBYkv7rv/5Ln3/+ua699lqtWbNGixcvVnR0tP75z39q6tSpRg8PgIeOHj2qyy67TBEREZLO/zmFVq1a6ciRIwaPLHQkJCTouuuu8/l+r7vuOmIPoGLy668/dRVMQnnC70nPjxw5otatW1dcj42Npfs+QM9hNfTD+txtB91AKKHntUc/rI9+AK7oBwB/4vwqNPD7XePRc1gN/QA8d++992r16tV65513tGXLFq/WQZ4+fVqzZ8922Z6ZmemLIbqYOnWqtmzZonfeeUerV6/W73//e788Tqiz/IJgSerdu7c++OADnTx5UkVFRfryyy911113GT0sADCtBQsWqE6dOj7bX506dbRw4UKf7Q+AefXs2VNSaLwDuPyXGuXfMxBo9BxWQj8AhCp6Xjv0A0Cooh8A/IXzKyBw6DmshH4AxoiLi3PZlpiYqE6dOhkwGvhKSCwIBmBuq1atUkJCghISErRt2zb99NNPKisrkyQ5HA4dOXJErVq1MniUoaVr16569tlnfba/Z5991us/XwDAWrp37y5JOnz4sE6cOGHwaPynoKBA2dnZkn79nq3O2563atVKOTk5Fdezs7Ppvo/Qc1gJ/bC+li1butUOuoFQQ89rh35YH/0AKkc/APgL51fWxe93gw89h5XQDyDwduzYofz8fJftO3fuNGA0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ALA+5h/WR88B+AP9sD764T2ODwBAsKDnAGB9zD+so6ysTEuXLlViYqISExM1f/58nThxwmf7v/XWW10+xfeaa67x2f7hPhYEAzC1gQMHasKECXrqqafUvXt3rVy5UpKUlZWlzz//XP3795ckXXTRRTp58qSRQw0ac+fOVUZGhqKjo/Xqq68aPZxamz9/vqKjo5WRkaFXXnnF6OEAALxAzwHAuph/hA56DsCX6EfooB+e4/gAAAQbeg4A1sX8wxp27Nihnj17Kjk5WWlpaX55jPfff19t2rSp+FTg2NhYtWjRwi+PheqxIBiA6f3pT3/S559/rldffVVr1qxRt27ddOedd2rFihVq1aqVJGnq1Km68cYblZCQoLy8PINHbJyysjItXLhQkvSXv/zFlH/K4UJNmzat+PMUixYtUllZmcEjAgB4g54DgPUw/wg99ByAL9CP0EM/3MfxAQAIVvQcAKyH+Yf5FRQUKCkpSX379tVXX31V5f06dOigkSNH6rnnntPmzZu1b98+paenKz09Xfv27dPmzZv13HPPuXwC8IW++eYb7dixQzfeeKOGDx/u628HboowegAA4KkL/9xM48aNVVBQIEnatm1bpV/zzDPP6JlnnvH30ILepk2b9MMPP6h58+YaNWqU0cPxmbvuukuPP/64vv/+e23evJkTi0qUlpbq9OnTks6/A7tOnToGjwhAqKPngOfoOcyG+Yf10XPAc6WlpZX+N35FP6yPfniP4yN0MR8EEGzoOeA5eg6zYf5hbmlpaRoyZIh++OGHSm9v2bKlxowZowceeEBxcXHV7isxMVFNmzbVU0895dZjb926VRkZGbr//vuVkJDg6dBRS3xCMACEkEWLFkmSxo4dW+M7d8wkMjJSY8eOlfTr94jzJ3hTpkxRr1691LBhQzVt2lRNmzZVw4YN1atXL02ZMqXad4EBAADj0XOYGfMPADjvtz2Pjo6u2B4dHU3PK0E/gKpxfIQW5oMAAJgfPYeZMf8wrw8//FD9+vWrdDFwly5d9MEHH+jw4cN69tlna1wMLEkOh0N9+/Z12T537lx98MEH6tKli8ttP/zwg/r166cPP/zQu28CXmNBMACEiG+++Ubbt29XWFiYxo0bZ/RwfG78+PGy2Wzatm2bvv32W6OHY6j9+/erf//+SkxM1Pz587Vnzx6dPXu24vazZ89qz549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jhyp8muOHTum9evXa8iQIYEaZlAqP3nx158qCSZmPmHzRkJCgq677jqf7/e6667j5AuA33jTdMDK6DmshvlHaPCk50eOHFHr1q0rrsfGxtJ9WA49rz36ERqYD3qH48O66AcAM2I+CDij57Aa5h/mcO+992r16tV65513tGXLFk2dOtXjfZw+fVqzZ8922Z6ZmemLIbqYOnWqtmzZonfeeUerV6/W73//e788Tqiz/ILg119/XQ6Ho8rL66+/bvQQAfjJqVOndNttt2natGnq2bOn0cMxVPn3Hwrv4Co/KQ2l53zBggWqU6eOz/ZXp04dLVy40Gf7AwAANaPnsBLmHwBCFT2vHfoBVI3jw9roBwAA5kfPYSXMP0JHXFycy7bExER16tTJgNHAVyy/IBiAdbRs2VI//fSTysrKJEkOh0NHjhxRq1atXO57+vRpDR48WMOGDdNjjz0W6KEGne7du0uSDh8+rBMnThg8Gv8pKChQdna2pF+/51DQtWtXPfvssz7b37PPPuv1n5MAgKqsWrVKCQkJSkhI0LZt29xuOhAq6DmshPmHdXnb81atWiknJ6fienZ2Nt2HJdHz2qEf1sV8sPY4PqyNfgAwA+aDQPXoOayE+Udo2LFjh/Lz812279y504DRwJdYEAzANJo3b67u3bvrzTfflCRt2LBBMTExateundP9CgsLNXjwYA0ePFhPPfWUy346deqkH374ISBjDhaNGzdW27ZtJUlffPGFwaPxn/LvLS4uTpdccomxgwmw6dOna9KkSbXez8MPP6zp06f7YEQA4Oz+++9XWlqa0tLSNH36dLeaXpMffviBd6jCUug5rIL5h3V52/MRI0Zo06ZNOnbsmBwOh5YsWaK7775bEj2H9dBz79EP62I+WHscH9ZHPwAEO+aDQM3oOayC+Yf1ORwO9e3b12X7vHnzVLduXQNGBF9iQTAAU1m6dKmWLl2qDh06KCUlRStXrpQkjR07Vps2bZJ0PlC7du3S22+/XfFO1eeff16SlJeXp4KCAjVp0sSw78Eot912myRpxYoVBo/Ef8q/tyFDhhg8ksCz2WyaP3++Zs+e7dWfo6lTp45mz56tV199VTabzQ8jBABnVTVdcu56UVGRYmJiNHLkSGVkZCgmJkYzZ86UdP4XxhEREYaMH/AHeg4rYf4RGtztedu2bTVr1ixde+21ateu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AIBz0HPf2LHnAGAXnH/UHj33jR17zv4BIJjoh2/oR+3QDwAILjv2fPHixbrxxht17Ngxj+VxcXH697//rfr163stb968ea22aceem4kJwQBq7Pvvv5fb7fZY1qFDB5NGY13t27f3uO5yubRv3z6TRgO7+cc//qE777xTJSUlGjJkiPbs2aNbb73V7GHp1ltvVVZWloYMGaKSkhINGzZMy5YtM3tYAPxAz31jt57TDwBwFnruG7v1HADsgvOPwKDnvrFbz9k/AAQb/fAN/QgM+gEAwWGnnrtcLk2aNEmjRo3SmTNnPG678sortW3bNiUkJGjr1q0et/Xq1avW27Zbz83GhGAANbZ3716P6zExMbrgggtMGo11NWrUSM2aNfNYdv7fDqjIsmXL9NBDD8nlcumhhx7SunXrTHnXb2WaNGmidevWlY/xwQcf5KQfsCF67hs79Zx+AIDz0HPf2KnnAGAXnH8EDj33jZ16zv4BwAj0wzf0I3DoBwAEnl16furUKQ0bNkwvvfRShbe/8cYbiomJkaSgTAi2U8+tgAnBAGosJyfH43q7du0M3X5cXJw6duyoxMREdezYUTNnzqz2Z/7617+qqKjIgNF5Ov9dKgQJ1Vm3bp1GjhwpSXr00Ue1ePFiRUREmDwqbxEREVq8eLEeffRRSdLIkSP19ttvmzwqADVBz31nh57TDwBwJnruOzv0HADsgvOPwKLnvrNDz9k/ABiFfviOfgQO/QCAwDK75746evSofvvtt0pv79Chg2688Ub99NNP+u677zxuC8SEYMkePbcKJgQDqLGffvrJ43rLli0NH8OqVauUmZmpjz76SDNmzND27durvP/06dNNOcGMjY31uF5YWGj4GGAf27dv19133y2Xy6WRI0dq9uzZCgsLM3tYlQoLC9Ps2bPL3wl811136csvvzR7WAB8RM99Z/We0w8AcC567jur9xwA7ILzj8Cj576zes/ZPwAYiX74jn4EFv0AgMCxQs99ERsbq3fffVcbNmxQXFxchfd5//331bRpU49l9erV0+WXXx6wMfye1XpuJUwIBlBj55+o1a9f36SRSC1atFCnTp2Un5+vnJwcDRgwQF27dlViYqLeeecdSdKYMWMkSX379lViYqIKCgoMG9/5fxszTnJhD0VFRRoxYoRKSko0ZMgQLVy40NIn+2XCwsKUlpamIUOG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n4XkO/sA1M7PP/+s77//XpJ09dVXmzya4Cn73XJzcx13oD1r1izNmzev1uuZN2+eZs2aFYAROQs9R6iiH4Cx6Lm5Atnz0aNHa9SoUfruu+80adIkjRgxIogjtx76AcDJ6Lk1nN91zsthdxxfhT76YS5e30Wooh+Aseh5cLndbqWkpGj//v0eyx988EG98cYbio6O9mu9W7du1ZEjR7yWb9u2rdKfiY6O1htvvKEHH3zQY/n+/fuVkpLChG4DhPSE4BMnTmjBggUKCwvTzTffrMcff1y33XabDh48qAcffFCDBg2Sy+Uye5gAKpGWlqbhw4dXevuqVauUkpKiiIgINW7cWHfeeadWrlxZ4X379eun2NjYYA0VgI3t2rVLktSmTRs1btzY5NEET5MmTRQXFyfp3O/sBLt379a0adMCtr5p06Zp9+7dAVufE9BzhCr6ARiHnpsvUD0vKCjQjh07dM8990iShg4dqgMHDignJydoY7ca+gHAqei5dZzfdc7LYXccX4U2+mE+Xt9FqKIfgHHoefAtXrxY69at81jWv39/LVq0SBEREX6t0+12q3fv3l7L58yZozp16lT5sxEREVq0aJH+9Kc/eSxfu3atlixZ4td44LuQnhDcuHFj/frrr/rkk0+0ePFivfjii1qwYIFycnLUv39/ffjhh3rvvffMHiaASvzrX//SlVdeWent+/fv93gHaVxcnNe7XQCgOjt27JAkde/e3eSRBF+PHj0knfudneCRRx4J6LdClJSU6JFHHgnY+pyAniNU0Q/AOPTcfIHq+YEDB3TJJZcoMjJSkhQWFqZWrVo5qv30A4BT0XPrOL/rnJfD7ji+Cm30w3y8votQRT8A49Dz4Dp16pSmTJnisaxx48ZasWKF35OBJWnq1KkVLh8/frxPPx8REaEVK1Z4veliypQpOnXqlN/jQvVCekJweHh4hTPSIyMjddttt0mSoz6BBLCbH374QTExMWYPA0CI27lzp6RzJ8OhrOxFjbLfOdRlZmYqIyMj4OvNyMjQV199FfD1hip6jlBFPwBj0HNroOeBQz8AOBE9txa6jlDD8VXooh/WQDcQqugHYAx6Hnyvv/66jh496rFs2bJlatGihd/rPH78uGbMmOG1PDs7u0briY2N1T/+8Q+PZYWFhfqf//kfv8eG6oX0hODKuFwuvf/++5KkLl26mDwa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",
      "text/plain": [
       "<Figure size 2800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "avg_pool = nn.AvgPool2d(kernel_size=7)\n",
    "image = next(iter(dataflow[\"train\"]))[\"image\"]\n",
    "image = avg_pool(image[0]).view(1, -1)\n",
    "qml.draw_mpl(quantum_net, decimals=1, expansion_strategy=\"device\")(image, torch.normal(0, 0.1, size=(num_qlayer, n_qubits, 3)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### AAE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def RY_layer(weights):\n",
    "    # weights: (n_qubits, )\n",
    "    for i in range(weights.shape[0]):\n",
    "        qml.RY(weights[i], wires=i)\n",
    "\n",
    "def EntanglingLayer(n_qubits):\n",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "# AAE encoder\n",
    "q_device = qml.device(\"default.qubit\", wires=n_qubits)\n",
    "@qml.qnode(q_device, interface=\"torch\", diff_method=\"backprop\")  # qml.state() only supported for backprop \n",
    "def aae_encoder(inputs=None, weights=None):\n",
    "\n",
    "    # to use StronglyEntanglingLayers\n",
    "    # input_weights = torch.zeros(weights.shape + (3,))\n",
    "    # input_weights[:,:,1] = weights  \n",
    "    # StronglyEntanglingLayers(input_weights, wires=range(n_qubits))  # only rotate along Y axis\n",
    "    \n",
    "\n",
    "    inputs = torch.tensor([0.0], dtype=torch.float32) # inputs of encoder doesn't exist (or always [1, 0, 0, ...]), but pennylane need this arg\n",
    "    for l in range(weights.shape[0]):\n",
    "        RY_layer(weights=weights[l])\n",
    "        EntanglingLayer(n_qubits)        \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",
    "q_device = qml.device(\"default.qubit\", wires=n_qubits)\n",
    "@qml.qnode(q_device, interface=\"torch\", diff_method=\"backprop\")  # qml.state() only supported for backprop \n",
    "def aae_encoder_hadamard(inputs, weights):\n",
    "\n",
    "    # to use StronglyEntanglingLayers\n",
    "    # input_weights = torch.zeros(weights.shape + (3,))\n",
    "    # input_weights[:,:,1] = weights  \n",
    "    # StronglyEntanglingLayers(input_weights, wires=range(n_qubits))  # only rotate along Y axis\n",
    "    \n",
    "    inputs = torch.tensor([0.0], dtype=torch.float32) # inputs of encoder doesn't exist (or always [1, 0, 0, ...]), but pennylane need this arg\n",
    "    for l in range(weights.shape[0]):\n",
    "        RY_layer(weights=weights[l])\n",
    "        EntanglingLayer(n_qubits)        \n",
    "    \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",
    "    HadamardLayer(n_qubits)\n",
    "    return qml.state()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 2700x500 with 1 Axes>, <Axes: >)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACqAAAAIHCAYAAAD65g/WAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAADLwklEQVR4nOzde3hU5b33/0+Ow0k8RIgVKNGAYopg5NDCBsRWsW41FNlQoX32I0gUEBCLW0BaPNQ2oFaliHJSKHbLIxQVtZeiuLVSn6ACT4QCWhIJHqohBJVASJiQ9fsjv0SHmUnWHNe6Z96v65qrnTvJmu9MWe81f9wzTbEsyxIAAAAAAAAAAAAAAAAAAABgU6rTAwAAAAAAAAAAAAAAAAAAAMAsbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhYQMqAAAAAAAAAAAAAAAAAAAAQsIGVAAAAAAAAAAAAAAAAAAAAISEDagAAAAAAAAAAAAAAAAAAAAICRtQAQAAAAAAAAAAAAAAAAAAEBI2oAIAAAAAAAAAAAAAAAAAACAkbEAFAAAAAAAAAAAAAAAAAABASNiACgAAAAAAAAAAAAAAAAAAgJCwARUAAAAAAAAAAAAAAAAAAAAhSXd6ACAe6urq9PHHH2vfvn0qLS3VoUOHVFtbq7q6OqdH8+HxeNSmTRudffbZ6tGjh3r27Knzzz9fHo/H6dGQwDg/AJiCXgEwBb0CYAp6BcAU9AqAKegVAFPQKwBAOLh+IBA2oCIh1dfX629/+5vWr1+vTZs26cCBA7Isy+mxwpKSkqLu3bvrqquu0pgxY3TZZZcpPZ1TF+Hj/ABgCnoFwBT0CoAp6BUAU9ArAKagVwBMQa8AAOHg+gE7UixT/1UAAZSWluoPf/iDNmzYoMrKSqfHiYlOnTpp9OjRuuOOO5Sbm+v0ODAI5wcAU9ArAKagVwBMQa8AmIJeATAFvQJgCnoFAAgH1w+Egg2oSAg1NTVasGCBFi5cqBMnTjg9Tlx4PB7deeedmjNnjtq1a+f0OHAxzg/OD8AU9IpeAaagV/QKMAW9oleAKegVvQJMQa/oFWAKekWvACAcXD+4foSDDagw3muvvaabb75ZBw4caPV3s7Oz1aNHD3Xr1k3t2rVTZmamUlNT4zBl6xoaGnTixAnV1NTo008/VWlpqSoqKlr9u5ycHC1btkwjRoyIw5QwDecH5wdgCnpFrwBT0Ct6BZiCXtErwBT0il4BpqBX9AowBb2iVwAQjkS7fuzatUtffPGFvF4v148YYwMqjPb8889r7Nixqq+vD/jzfv36acyYMbriiivUs2dPdezYMc4TRubIkSPat2+fNm/erHXr1mnHjh0Bfy89PV3r1q3TqFGj4jwh3IzzoxHnB+B+9KoRvQLcj141oleA+9GrRvQKcD961YheAe5HrxrRK8D96FUjegUAoUmk60dDQ4PuuusuLVy4UM8995xGjRrF9SPWLMBQzz33nJWenm5J8rmlpaVZM2fOtMrKypweMepKS0utmTNnWmlpaX7POz093XruueecHhEuwfnB+QGYgl7RK8AU9IpeAaagV/QKMAW9oleAKegVvQJMQa/oFQCEI5GuHzU1NdZ//Md/ND+HL774IuDvcf2ILr4BFUZ67bXXdM011/jtvB82bJiWLFmi3r17OzRZfPzjH//QrbfeqrfffttnPT09XX/961/5Ougkx/nB+QGYgl7RK8AU9IpeAaagV/QKMAW9oleAKegVvQJMQa/oFQCEI5GuHxUVFSooKNB7770nScrJydH+/ftb/BuuH9HBBlQYp6amRnl5eTpw4IDPemFhoZYuXarU1FSHJouvhoYGTZ48WStWrPBZz8nJ0Z49e9S2bVuHJoOTOD8acX4A7kevGtErwP3oVSN6BbgfvWpErwD3o1eN6BXgfvSqEb0C3I9eNaJXABCaRLp+7N69W9dcc43Pcxk3bpyeeeaZVv+W60fkzPmXAvz/FixYkBDxi1RqaqqWLl2qwsJCn/Xy8nItWLDAoangNM6PRpwfgPvRq0b0CnA/etWIXgHuR68a0SvA/ehVI3oFuB+9akSvAPejV43oFQCEJlGuH5s3b9bgwYP9nsugQYNs/T3Xj8jxDagwSmlpqXr37q26urrmtWHDhunNN980Kn7R1NDQoOHDh2vLli3Nax6PR7t371Zubq6DkyHeOD/8cX4A7kSv/NErwJ3olT96BbgTvfJHrwB3olf+6BXgTvTKH70C3Ile+aNXANC6RLl+rFy5UlOmTFF9fb3fz95//33179/f9rG4foTPnH8xgKQ//OEPPvFLS0vTkiVLjIpftKWmpmrJkiVKS0trXqurq9NDDz3k4FRwAueHP84PwJ3olT96BbgTvfJHrwB3olf+6BXgTvTKH70C3Ile+aNXgDvRK3/0CgBaZ/r1o6GhQbNnz1ZhYWHAzadt27ZV3759Qzom14/wmfGvBpBUX1+vDRs2+KxNnz5dvXv3dmgi97j44os1ffp0n7XnnnsuYGSRmDg/guP8ANyFXgVHrwB3oVfB0SvAXehVcPQKcBd6FRy9AtyFXgVHrwB3oVfB0SsACM7068fx48c1duxYPfDAA0F/p3///srIyAj52Fw/wsMGVBjjb3/7myorK33WTj3pk9m0adN87h88eFBvv/22Q9Mg3jg/Wsb5AbgHvWoZvQLcg161jF4B7kGvWkavAPegVy2jV4B70KuW0SvAPehVy+gVAARm8vWjoqJCw4cP99tAe6pBgwaF/RhcP0LHBlQYY/369T73+/Xrp/PPP9+hadwnNzdXl156qc/aqa8ZEhfnR8s4PwD3oFcto1eAe9CrltErwD3oVcvoFeAe9Kpl9ApwD3rVMnoFuAe9ahm9AoDATL1+7N69Wz/84Q/13nvv+aynpvpvf4xkAyrXj9CxARXG2LRpk8/9MWPGODSJe536mpz6miFxcX60jvMDcAd61Tp6BbgDvWodvQLcgV61jl4B7kCvWkevAHegV62jV4A70KvW0SsA8Gfi9eP111/X4MGDdeDAAZ/1008/XQ899JDf7//oRz+K6PG4foSGDagwQl1dnV9ErrjiCoemca8rr7zS5/6BAwdUV1fn0DSIF84Pezg/AOfRK3voFeA8emUPvQKcR6/soVeA8+iVPfQKcB69sodeAc6jV/bQKwDwZeL1Y8WKFbr66qt15MgRn/WcnBz93//7f9WuXTu/9XPOOSeix+T6ERo2oMIIH3/8sSzL8lm74IILHJrGvXr27Olzv6GhQfv373doGsQL54c9nB+A8+iVPfQKcB69sodeAc6jV/bQK8B59MoeegU4j17ZQ68A59Ere+gVAPgy6frR0NCg2bNn6+abb9bJkyd9fvbDH/5QW7duVV5enoqLi31+NmjQoIgfm+tHaNiACiPs27fP5352drZOO+00h6Zxr44dO6pz584+a6e+dkg8nB/2cH4AzqNX9tArwHn0yh56BTiPXtlDrwDn0St76BXgPHplD70CnEev7KFXAODLlOtHTU2Nxo4dqwceeCDgz59++mllZ2dLUkw2oHL9CA0bUGGE0tJSn/s9evRwaBL3O3UXPgFMfJwf9nF+AM6iV/bRK8BZ9Mo+egU4i17ZR68AZ9Er++gV4Cx6ZR+9ApxFr+yjVwDwLVOuH4cPH9bx48eD/vyCCy7Q1VdfrUOHDumf//ynz8+isQFV4voRCjagwgiHDh3yud+tWzeHJnG/rl27+tyvqqpyaBLEC+eHfZwfgLPolX30CnAWvbKPXgHOolf20SvAWfTKPnoFOIte2UevAGfRK/voFQB8y5TrR9euXfXyyy9r48aNysnJCfg7r776qjp16uSz1rZtW/Xt2zdqM3wX14/g2IAKI9TW1vrcb9eunUOTuN+pr82prx0SD+eHfZwfgLPolX30CnAWvbKPXgHOolf20SvAWfTKPnoFOIte2UevAGfRK/voFQB8y83Xj5MnT+rkyZPN91NSUlRQUKA9e/Zo/vz5to7Rv39/ZWRkRGUerh/2pTs9AGBHXV2dz/3MzEyHJnE/j8fjc58AJj7OD/s4PwBn0Sv76BXgLHplH70CnEWv7KNXgLPolX30CnAWvbKPXgHOolf20SsA+JbT148TJ07ogw8+8Lnt3r1b1dXV8nq9kqSMjAyddtpp+sEPfqC+ffuqb9+++v73v2/r+IMGDYrarFw/7GMDKoyUmsqX9wbDawP+DQTHawO4C+dkcLw2gLtwTgbHawO4C+dkcLw2gLtwTgbHawO4C+dkcLw2gLtwTgbHawMAwcWrkSUlJXrqqaf03//93zp8+HCLv+v1enX48GFt2bJFW7ZsCelxorkBleuHfWxABQAAAAAAAAAAAAAAAAAAUVFfX68nn3xSS5cuVUlJSdSPf80112jz5s0+3+r6ox/9KOqPg9axARUAAAAAAAAAAAAAAAAAAESsuLhYU6ZM0QcffBCzx/jrX/+qXr166cwzz1RxcbFycnJ0zjnnxOzxEBwbUAEAAAAAAAAAAAAAAAAAQNiqqqo0Z84crVy5ssXfu+CCC9S3b9/mW5cuXeTxeCRJdXV1+vzzz/XBBx/ot7/9rc83nJ7qww8/lCRdeeWV6t27d/SeCELCBlQACcPr9aq6ulqSdNpppykjI8PhiQAgMHoFwBT0CoAp6BUAU9ArAKagVwBMQa8AmIJeIdGVlJTo2muv1eeffx7w5926ddONN96o//2//7dyc3NbPFZ+fr6ysrL061//2tZjv/7669qzZ4/+8z//U5dcckmooyNCqU4PAACRKCkp0YwZMzRgwAB16NBBWVlZysrKUocOHTRgwADNmDEjpl/pDQB20SsApqBXAExBrwCYgl4BMAW9AmAKegXAFPQKyeLVV1/VkCFDAm4+7d27t1555RXt379f9913X6ubTyXJsiwNHjzYb/2RRx7RK6+8EvDbTj///HMNGTJEr776anhPAmFjAyoAI+3cuVPDhg1Tfn6+Fi9erG3btunEiRPNPz9x4oS2bdumxYsX65JLLtGwYcO0c+dOBycGkKzoFQBT0CsApqBXAExBrwCYgl4BMAW9AmAKeoVk8tJLL6mgoEDHjh3zWW/fvr0eeugh7dixQz/96U+VlpZm+5jz5s0LuD5z5kz99Kc/1Y4dO/TQQw+pffv2Pj8/duyYRo4cqZdeein0J4KwsQEVgFEsy9KCBQvUv39/bdmyxfbfbdmyRf3799eCBQtkWVYMJwSARvQKgCnoFQBT0CsApqBXAExBrwCYgl4BMAW9QrJ55513NHr0aHm9Xp/1oUOHau/evZo1a5YyMjJCOmZ1dbWKior81vfu3dv83zMyMjRr1izt3btXQ4YM8fm9EydOaPTo0XrnnXdCelyEjw2oAIxhWZamT5+uuXPn+l287PB6vZo7d66mT5/OmzYAMUWvAJiCXgEwBb0CYAp6BcAU9AqAKegVAFPQKySbr776SuPHj/f79z5u3Di9/vrr6tatW1jHzc3N9VvLz89Xr169/Na7deumzZs3a9y4cT7rXq9X48eP19dffx3WDAhNUmxAff/99/Xv//7vOuOMM9S+fXv96Ec/0rp165weCwYoLy9XSkqKzy0jI0NdunTR2LFjtW3bNknSo48+qpSUFE2YMCHosd566y2lpqZqwIABqq+vj9dTSCgLFy7UkiVLIj7OkiVLtHDhwihMlNw4P4Dg6JW70CsgOHrlLvQKCI5euQu9AoKjV+5Cr4Dg6JW70CsgOHrlLvQKCI5eIZlYlqXCwkJ98sknPusTJ07U008/LY/HE9Zxi4uLVVlZ6be+devWoH/j8Xj09NNPa+LEiT7rn3zyiQoLC9nQHQfpTg8Qa2+++aauuuoqtWnTRjfccINOO+00bdiwQT//+c/16aefatasWU6PCAPk5ubql7/8pSTp2LFj2r59u9avX68XXnhBmzdv1m233aaNGzdq9erVuv7663Xdddf5/P3Ro0c1YcIEeTwerVmzRunpCX/qRd3OnTs1f/78qB1v/vz5+vd//3f16dMnasdMVpwfgC965V70CvBFr9yLXgG+6JV70SvAF71yL3oF+KJX7kWvAF/0yr3oFeCLXiHZrFixQhs2bPBZGz58uJYvX660tLSwjmlZlgYPHuy3vmjRImVmZrb4t2lpaVq+fLnKysr0t7/9rXn9L3/5i1auXKnCwsKwZoJNVgLzer1Wbm6u5fF4rP/3//5f8/rXX39tXXDBBVZmZqZVXl7u3ICwberUqZak5tvUqVPj8rj79++3JFlXXXWV38+KioosSdawYcMsy7Ks8vJyq2PHjlZ2drZ16NAhn9+9+eabLUnWI488EvOZnXqtYm3o0KE+zysat6FDhzr9tKKC88O+RD0/4C70Kjh6ZR+9QjzQq+DolX30CvFAr4KjV/bRK8QDvQqOXtlHrxAP9Co4emUfvUI80Kvg6JV99ArxQK9gimg08dixY9ZZZ53lc5yzzjrL+uyzzyKabe7cuQHPhVB8+umnfrNlZWVZx44dC3kerh/2pSqB/c///I/Kyso0fvx4XXLJJc3rp59+uu666y6dOHFCf/rTn5wbEEa76aabJEnbt2+XJHXv3l2PPvqoKioqNGXKlObf27Rpk5YvX67LL79ct912myOzmq6kpERbtmyJ+nG3bNmiDz74IOrHBecHkhe9Mg+9QrKiV+ahV0hW9Mo89ArJil6Zh14hWdEr89ArJCt6ZR56hWRFr5BsVq9ercOHD/usrVq1Sl26dAn7mNXV1SoqKvJb37t3b0jH6dq1q5566imftaqqKvYHxlhCb0B96623JEkjRozw+9lVV10lST5fuwuE47v/dwATJkxQQUGB1q9fr7Vr1+rrr7/WpEmT1LFjR61atUopKSkOTmquUy8OphwbnB9IPvTKXPQKyYZemYteIdnQK3PRKyQbemUueoVkQ6/MRa+QbOiVuegVkg29QjI5efKkHn74YZ+1q6++WgUFBREdNzc3128tPz9fvXr1CvlYI0eO1NVXX+2z9vDDD+vkyZNhz4eWJfQG1H379kmSevbs6fezc845Rx06dGj+HSBUK1eulCQNGTLEZ3358uU6++yzdeutt+rGG2/UZ599pkcffVTdu3d3YsyEUFxcbOSxkxnnB5IVvTIPvUKyolfmoVdIVvTKPPQKyYpemYdeIVnRK/PQKyQremUeeoVkRa+QTDZu3KiysjKftTvuuCOiYxYXF6uystJvfevWrWEfc9asWT73S0tL9eKLL4Z9PLQsvfVfMdc333wjSTr99NMD/rxjx47Nv2MKy7JUU1Pj9Bhx5/V6HX380tJS3XPPPZKkY8eOafv27XrzzTeVnZ2tBx980Od3s7OztWzZMo0ePVobN25UQUGBJkyY4MDUjbxer44dO+bY40fK6/Vq586dMTv+zp079c033/h8Es80nB/hM/38gLvQq9bRq/DRK0QTvWodvQofvUI00avW0avw0StEE71qHb0KH71CNNGr1tGr8NErRBO9ah29Ch+9QjTRK5gm0uvHunXrfO7n5+fr8ssvD/t4lmVp8ODBfuuLFi1SZmZm2Mf98Y9/rEsuuUQlJSXNa88++6xGjRoV9jHRAiuBXXnllZYka9++fQF/fu6551odO3aM81SROXr0qCUp6W9Tp06Ny+u9f//+oDOcc845Qf9tWZZlDRw40JJk7dmzJy6zNpk6darj//twc/bG+REc5wc3bu660avg6BU3bu660avg6BU3bu660avg6BU3bu660avg6BU3bu660avg6BU3bu660avg6BU3bty4Bb+Fev3o3r27z98/8cQTETV67ty5AeeKhscff9znmDk5OSH9/anXj3hda02UqgTW9M2nwb7l9MiRI0G/HRX4rquuukqWZcmyLB08eFAPPvigDh48qIKCAh09ejTg37Rt29bnP4FExfkBwBT0CoAp6BUAU9ArAKagVwBMQa8AmIJeAUDy+fLLL3XgwAGftSFDhoR9vOrqahUVFfmt7927N+xjfteps5WXl6uioiIqx4avhP6O5p49e0qS9u3bp379+vn87Msvv9TRo0c1cOBAJ0YLW7t27YK+YUtkt99+u1asWOH0GJKkTp066Y477tA333yj+++/X7/+9a/16KOPOj1WUIWFhXrkkUecHiNsXq9X2dnZOnHiREyO7/F4VFFRYfRX1nN+hM/08wPuQq9aR6/CR68QTfSqdfQqfPQK0USvWkevwkevEE30qnX0Knz0CtFEr1pHr8JHrxBN9Kp19Cp89ArRRK9gmkiuH++++67P/dNOO00XXXRR2LPk5ub6reXn56tXr15hH/O78vLy1KFDB599du+++64KCgqicnx8K6ELddlll6moqEivvfaabrjhBp+fbdq0qfl3TJKSkqL27ds7PUbcZWRkOD2Cn7vuuktPPfWUHn/8cc2cOVM5OTlOjxRQRkaG8f9m+vTpo23btsXs2KZ/EzLnR/gS4fyAu9CrltGr8NErRBu9ahm9Ch+9QrTRq5bRq/DRK0QbvWoZvQofvUK00auW0avw0StEG71qGb0KH71CtNErmCSS68cHH3zgc3/AgAFKS0sL61jFxcWqrKz0W9+6dWtYxwskLS1NAwYM0Jtvvtm8VlJSwgbUGEh1eoBY+slPfqLzzz9fzzzzjEpKSprXv/nmG/3+979XZmam/vM//9O5AWG0tm3bavbs2fJ6vfrtb3/r9DgJbdCgQUYeO5lxfiBZ0Svz0CskK3plHnqFZEWvzEOvkKzolXnoFZIVvTIPvUKyolfmoVdIVvQKyaK6utrnfrdu3cI6jmVZGjx4sN/6okWLlJmZGdYxgzl1xmT8fx2Ph4TegJqenq6VK1eqoaFBw4YN080336xZs2apb9+++uc//6nf//73rv3UDcxw880369xzz9WaNWtUVlbm9DgJa+LEiUYeO9lxfiAZ0Ssz0SskI3plJnqFZESvzESvkIzolZnoFZIRvTITvUIyoldmoldIRvQKyaJv37664YYbNHLkSI0YMUIXX3xxWMeZN29ewPUZM2ZEMl5Affr00YgRIzRy5EjdcMMN6tu3b9QfAwm+AVWSLr/8cv3973/Xv/3bv+nZZ5/VE088oezsbP2f//N/NGvWLKfHg+HatGmjuXPnqr6+Xvfee6/T4ySsSy65REOHDo36cYcOHcrFJYY4P5CM6JWZ6BWSEb0yE71CMqJXZqJXSEb0ykz0CsmIXpmJXiEZ0Ssz0SskI3qFZPHLX/5Sa9eu1QsvvKBNmzaFte+uurpaRUVFfut79+6Nxoh+Zs2apU2bNumFF17Q2rVr9Ytf/CImj5Ps0p0eIB4GDhyoV155xekxYKCcnBxZltXi70ybNk3Tpk3zW3/rrbdiNFVyeuyxx9S/f395vd6oHC8jI0NLliyJyrGSFecHEBi9ch96BQRGr9yHXgGB0Sv3oVdAYPTKfegVEBi9ch96BQRGr9yHXgGB0SvAntzcXL+1/Px89erVy4FpEC0J/w2oABJDnz59dN9990XtePfdd1/YXwcOAC2hVwBMQa8AmIJeATAFvQJgCnoFwBT0CoAp6BXQuuLiYlVWVvqtb9261YFpEE1sQAVgjNmzZ+vWW2+N+DjTpk3T7NmzozARAARGrwCYgl4BMAW9AmAKegXAFPQKgCnoFQBT0CsgOMuyNHjwYL/1RYsWKTMz04GJEE1sQAVgjJSUFC1evFhFRUXKyMgI+e8zMjJUVFSkP/7xj0pJSYnBhADQiF4BMAW9AmAKegXAFPQKgCnoFQBT0CsApqBXQHDz5s0LuD5jxow4T4JYYAMqAKOkpKRozpw52rZtm4YOHWr774YOHart27drzpw5vFkDEBf0CoAp6BUAU9ArAKagVwBMQa8AmIJeATAFvQL8VVdXq6ioyG997969DkyDWEh3egAACEefPn309ttv64MPPtBTTz2l4uJiffDBBzpx4oQkyePxqE+fPho0aJAmTpyovn37OjwxgGRFrwCYgl4BMAW9AmAKegXAFPQKgCnoFQBT0CvgW7m5uX5r+fn56tWrlwPTIBbYgArAaH379tWiRYskSd98843OOOMMSVJFRYVOP/10BycDAF/0CoAp6BUAU9ArAKagVwBMQa8AmIJeATAFvUKyKy4uVmVlpd/61q1bHZgGsZLq9AAAEC3p6ekB/zsAuA29AmAKegXAFPQKgCnoFQBT0CsApqBXAExBr5BsLMvS4MGD/dYXLVqkzMxMByZCrLABFQAAAAAAAAAAAAAAAAAARMW8efMCrs+YMSPOkyDW2IAKAAAAAAAAAAAAAAAAAAAiVl1draKiIr/1vXv3OjANYo0NqAAAAAAAAAAAAAAAAAAAIGK5ubl+a/n5+erVq5cD0yDW2IAKIzU0NDg9gmvx2oB/A8Hx2gDuwjkZHK8N4C6ck8Hx2gDuwjkZHK8N4C6ck8Hx2gDuwjkZHK8N4C6ck8Hx2gBAcLFo5IcffqjKykq/9a1bt0b9sWKJ64d9bECFETwej8/9EydOODSJ+9XV1fncb9OmjUOTIF44P+zj/ACcRa/so1eAs+iVffQKcBa9so9eAc6iV/bRK8BZ9Mo+egU4i17ZR68A4Fuxvn5YlqWZM2f6rS9atEiZmZlRfaxY4/phHxtQYYRTT+KamhqHJnG/U18bApj4OD/s4/wAnEWv7KNXgLPolX30CnAWvbKPXgHOolf20SvAWfTKPnoFOIte2UevAOBbsb5+HDx4UB999JHP2plnnqkZM2ZE9XHigeuHfWxAhRHOPvtsn/uffvqpQ5O432effeZzPysry6FJEC+cH/ZxfgDOolf20SvAWfTKPnoFOIte2UevAGfRK/voFeAsemUfvQKcRa/so1cA8K1YXz+ys7O1Z88ezZ8/Xx6PR+3bt9fOnTuj+hjxwvXDPjagwgg9evTwuV9aWurQJO63b98+n/s9e/Z0aBLEC+eHfZwfgLPolX30CnAWvbKPXgHOolf20SvAWfTKPnoFOIte2UevAGfRK/voFQB8Kx7Xj7Zt2+ree+/V7t27tWbNGnXt2jXqjxEPXD/sYwMqjHDqSVxRUaEjR444NI17HTlyRAcPHvRZI4CJj/PDHs4PwHn0yh56BTiPXtlDrwDn0St76BXgPHplD70CnEev7KFXgPPolT30CgB8xfP6kZubq+uvvz4mx441rh+hYQMqjHD++ecrJSXFZ+3Unebwf01SU1N13nnnOTQN4oXzwx7OD8B59MoeegU4j17ZQ68A59Ere+gV4Dx6ZQ+9ApxHr+yhV4Dz6JU99AoAfHH9sIfrR2jYgAojeDwede/e3Wdt8+bNDk3jXq+//rrP/e7du8vj8Tg0DeKF88Mezg/AefTKHnoFOI9e2UOvAOfRK3voFeA8emUPvQKcR6/soVeA8+iVPfQKAHxx/bCH60do2IAKY1x11VU+99evX+/QJO516mty6muGxMX50TrOD8Ad6FXr6BXgDvSqdfQKcAd61Tp6BbgDvWodvQLcgV61jl4B7kCvWkevAMAf14/Wcf0IDRtQYYwxY8b43N++fbs+/vhjh6Zxn7KyMu3YscNn7dTXDImL86NlnB+Ae9CrltErwD3oVcvoFeAe9Kpl9ApwD3rVMnoFuAe9ahm9AtyDXrWMXgFAYFw/Wsb1I3RsQIUxLrvsMnXq1MlnbfHixQ5N4z6PPfaYz/3OnTtr2LBhDk2DeOP8aBnnB+Ae9Kpl9ApwD3rVMnoFuAe9ahm9AtyDXrWMXgHuQa9aRq8A96BXLaNXABAY14+Wcf0IHRtQYYz09HSNHj3aZ23x4sX6xz/+4dBE7rFr1y6/i8H111+v9PR0hyZCvHF+BMf5AbgLvQqOXgHuQq+Co1eAu9Cr4OgV4C70Kjh6BbgLvQqOXgHuQq+Co1cAEBzXj+C4foQnxbIsy+khALvKysr0gx/8QHV1dc1rw4YN05tvvqnU1OTcT93Q0KDhw4dry5YtzWsej0e7d+9Wbm6ug5PF37Fjx9ShQwdJ0tGjR9W+fXuHJ4ovzg9/nB9wK3pFr05Fr+BW9IpenYpewa3oFb06Fb2CW9ErenUqegW3olf06lT0Cm5Fr+jVqegV3CrZewV34frhj+tH+JLzXwyMlZubqzvvvNNn7e2339bkyZPV0NDg0FTOaWho0OTJk33iJ0mzZ88mfkmI88MX5wfgXvTKF70C3Ite+aJXgHvRK1/0CnAveuWLXgHuRa980SvAveiVL3oFAPZw/fDF9SMyfAMqjFNTU6O8vDwdOHDAZ72wsFBLly5Nmp34TfFbsWKFz3pOTo727Nmjtm3bOjSZc/jEEOdHE84PuB29oldN6BXcjl7Rqyb0Cm5Hr+hVE3oFt6NX9KoJvYLb0St61YRewe3oFb1qQq/gdvQKbsP1oxHXj8glx78UJJR27dpp+fLlSk9P91lfsWKFhg8frl27djk0Wfzs2rVLw4cP94tfenq6li1bRvySGOcH5wdgCnpFrwBT0Ct6BZiCXtErwBT0il4BpqBX9AowBb2iVwAQDq4fXD+ihQ2oMNKIESO0bt06vwhu2bJF+fn5uv3221VWVubQdLFTVlam22+/Xfn5+X5f+5yenq5169ZpxIgRDk0Ht+D84PwATEGv6BVgCnpFrwBT0Ct6BZiCXtErwBT0il4BpqBX9AoAwsH1g+tHNKRYlmU5PQQQrueff15jx45VfX19wJ9feumlGjNmjK688kr17NlTHTt2jPOEkTly5Ij27dun119/XevXr9eOHTsC/l5T/EaNGhXnCd2Fr6z3xfnRiPMDbkSvfNGrRvQKbkSvfNGrRvQKbkSvfNGrRvQKbkSvfNGrRvQKbkSvfNGrRvQKbkSvfNGrRvQKbkSv4GZcPxpx/QgPG1BhvNdee0233HKLysvLW/3dzp07q2fPnuratavatWsnj8ej1FR3fBFwQ0OD6urqVFNTo88++0z79u3TwYMHW/27nJwcLVu2jJ334g1bIJwfnB9wJ3rlj17RK7gTvfJHr+gV3Ile+aNX9AruRK/80St6BXeiV/7oFb2CO9Erf/SKXsGd6BXcjusH149wsQEVCeH48eNasGCBFi5cqLq6OqfHiQuPx6PZs2drzpw5atu2rdPjuAJv2ALj/OD8gPvQq8DoFb2C+9CrwOgVvYL70KvA6BW9gvvQq8DoFb2C+9CrwOgVvYL70KvA6BW9gvvQK5iA6wfXj3CwARUJpaysTA899JA2bNigyspKp8eJic6dO+v666/XHXfcodzcXKfHcRXesLWM8wNwD3rVMnoFuAe9ahm9AtyDXrWMXgHuQa9aRq8A96BXLaNXgHvQq5bRK8A96BVMwvUDoWADKhJSfX293n77ba1fv16bNm1SeXm5TP2nnpKSopycHF111VUaM2aMhg0bpvT0dKfHciXesNnD+QE4j17ZQ68A59Ere+gV4Dx6ZQ+9ApxHr+yhV4Dz6JU99ApwHr2yh14BzqNXMBHXD9jBBlQkhbq6Ou3fv1/79u3Tvn37VFVVpdraWtXW1jo9mo82bdqoTZs2ysrKUs+ePdWzZ0+dd9558ng8To9mBN6whYfzA4g/ehUeegXEH70KD70C4o9ehYdeAfFHr8JDr4D4o1fhoVdA/NGr8NArIP7oFRIB1w8EwgZUAAmDN2wATEGvAJiCXgEwBb0CYAp6BcAU9AqAKegVAFPQKwCJKtXpAQAAAAAAAAAAAAAAAAAAAGAWNqACAAAAAAAAAAAAAAAAAAAgJGxABQAAAAAAAAAAAAAAAAAAQEjYgAoAAAAAAAAAAAAAAAAAAICQsAEVAAAAAAAAAAAAAAAAAAAAIWEDKgAAAAAAAAAAAAAAAAAAAELCBlQAAAAAAAAAAAAAAAAAAACEhA2oAAAAAAAAAAAAAAAAAAAACAkbUAEAAAAAAAAAAAAAAAAAABASNqACAAAAAAAAAAAAAAAAAAAgJGxABQAAAAAAAAAAAAAAAAAAQEjYgAoAAAAAAAAAAAAAAAAAAICQsAEVAAAAAAAAAAAAAAAAAAAAIWEDKgAAAAAAAAAAAAAAAAAAAELCBlQAAAAAAAAAAAAAAAAAAACEhA2oAAAAAAAAAAAAAAAAAAAACAkbUAEAAAAAAAAAAAAAAAAAABASNqACAAAAAAAAAAAAAAAAAAAgJGxABQAAAAAAAAAAAAAAAAAAQEjSnR4AiIe6ujp9/PHH2rdvn0pLS3Xo0CHV1taqrq7O6dF8eDwetWnTRmeffbZ69Oihnj176vzzz5fH43F6NABxQq8AmIJeATAFvQJgCnoFwBT0CoAp6BUAU9ArAKagVwiEDahISPX19frb3/6m9evXa9OmTTpw4IAsy3J6rLCkpKSoe/fuuuqqqzRmzBhddtllSk/n1AUSBb0CYAp6BcAU9AqAKegVAFPQKwCmoFcATEGvAJiCXsGOFMvUfxVAAKWlpfrDH/6gDRs2qLKy0ulxYqJTp04aPXq07rjjDuXm5jo9jqscO3ZMHTp0kCQdPXpU7du3d3giIDh6ldzoFUxCr5IbvYJJ6FVyo1cwCb1KbvQKJqFXyY1ewST0KrnRK5iEXiU3egWT0CuEgg2oSAg1NTVasGCBFi5cqBMnTjg9Tlx4PB7deeedmjNnjtq1a+f0OK7AGzaYgF7RK4lewQz0il5J9ApmoFf0SqJXMAO9olcSvYIZ6BW9kugVzECv6JVEr2AGekWvJHoFM9ArehUONqDCeK+99ppuvvlmHThwoNXfzc7OVo8ePdStWze1a9dOmZmZSk1NjcOUrWtoaNCJEydUU1OjTz/9VKWlpaqoqGj173JycrRs2TKNGDEiDlO6G2/Y4Hb0il41oVdwO3pFr5rQK7gdvaJXTegV3I5e0asm9ApuR6/oVRN6BbejV/SqCb2C29EretWEXsHtEq1Xu3bt0hdffCGv10uvYowNqDDa888/r7Fjx6q+vj7gz/v166cxY8boiiuuUM+ePdWxY8c4TxiZI0eOaN++fdq8ebPWrVunHTt2BPy99PR0rVu3TqNGjYrzhO7CGza4Gb1qRK8a0Su4Gb1qRK8a0Su4Gb1qRK8a0Su4Gb1qRK8a0Su4Gb1qRK8a0Su4Gb1qRK8a0Su4Gb1qRK8a0Su4WSL1qqGhQXfddZcWLlyo5557TqNGjaJXsWYBhnruuees9PR0S5LPLS0tzZo5c6ZVVlbm9IhRV1paas2cOdNKS0vze97p6enWc8895/SIjjp69Gjz63H06FGnxwGa0St6dSp6BbeiV/TqVPQKbkWv6NWp6BXcil7Rq1PRK7gVvaJXp6JXcCt6Ra9ORa/gVvSKXp2KXsGtEqlXNTU11n/8x380P4cvvvgi4O/Rq+hiAyqMtGnTpoDxGzZsmLVr1y6nx4u5Xbt2WcOGDQsYwU2bNjk9nmN4wwY3olf0KhB6BTeiV/QqEHoFN6JX9CoQegU3olf0KhB6BTeiV/QqEHoFN6JX9CoQegU3olf0KhB6BTdKpF59+eWX1sCBA5ufQ05OTqt/Q6+iI8WyLEuAQWpqapSXl6cDBw74rBcWFmrp0qVKTU11aLL4amho0OTJk7VixQqf9ZycHO3Zs0dt27Z1aDLnVFdXN3/N95EjR3Taaac5PBGSHb1qRK/80Su4Db1qRK/80Su4Db1qRK/80Su4Db1qRK/80Su4Db1qRK/80Su4Db1qRK/80Su4Db1qRK/80Su4TSL1avfu3brmmmt8nsu4ceP0zDPPtPq39Cpy6U4PAIRqwYIFCRG/SKWmpmrp0qWS5BPB8vJyLViwQPfee69To8XcV199pR07dmjbtm3avn27tm/frn/961+qra1t/p2OHTuqTZs2Ovfcc9WvXz/1799f/fr106WXXqozzzzTwemRTOhVI3pFr+B+9KoRvaJXcD961Yhe0Su4H71qRK/oFdyPXjWiV/QK7kevGtEregX3o1eN6BW9gvslSq82b96s0aNH68iRIz7rgwYNsvX3ydyraOEbUGGU0tJS9e7dW3V1dc1rw4YN05tvvmlU/KKpoaFBw4cP15YtW5rXPB6Pdu/erdzcXAcni66PPvpITzzxhF566SV9/PHHER3r/PPP13XXXacpU6bowgsvjNKEgC965Y9ehY5eIR7olT96FTp6hXigV/7oVejoFeKBXvmjV6GjV4gHeuWPXoWOXiEe6JU/ehU6eoV4oFf+6FXo6BXiIVF6tXLlSk2ZMkX19fV+P3v//ffVv39/28dKll7FAhtQYZQpU6Y07zqXpLS0NJWUlKh3794OTuW8Xbt2KT8/XydPnmxemzx5sp544gkHp4pcfX29XnzxRT3++ON64403fH523nnn+XwSKDc3V5ZlNUe/rKxMKSkpKisr0/bt25s/XbR//36f4/zkJz/R1KlTVVBQoPR0vhQa0UOvAqNX9AruQ68Co1f0Cu5DrwKjV/QK7kOvAqNX9AruQ68Co1f0Cu5DrwKjV/QK7kOvAqNX9AruY3qvGhoaNHfuXD3wwAMBf962bVt98803ysjICOm4idqrmLMAQ3i9XqtTp06WpObbzJkznR7LNWbOnOnz2nTu3Nnyer1OjxWW48ePW7/73e+sLl26ND+f1NRUq6CgwHrxxRetqqqqgH939OjR5t8/evRowN+pqqqyXnzxRaugoMBKTU1t/v0uXbpYv//9763a2tpYPjUkCXrVMnpFr+Ae9Kpl9IpewT3oVcvoFb2Ce9CrltEregX3oFcto1f0Cu5Br1pGr+gV3INetYxe0Su4h+m9qqmpsUaPHu0z/6m3oUOHhn38ROpVvLABFcbYvHmzXzDKysqcHss1SktL/V6fN954w+mxQvbuu+9aeXl5zc+hU6dO1l133WWVl5e3+rd23rB9V3l5uXXXXXf5XFjz8vKs9957LxpPBUmMXrWMXtEruAe9ahm9oldwD3rVMnpFr+Ae9Kpl9IpewT3oVcvoFb2Ce9CrltEregX3oFcto1f0Cu5hcq++/PJLa+DAgS1uPpVk3XnnnWE/RqL0Kp7YgApj3HLLLT4nd79+/ZweyXUuvfRSn9do8uTJTo9k2/Hjx63Zs2c3f4onOzvbWrNmTUif4An1DVuT2tpaa82aNVZ2drYlNX46ac6cOdbx48fDeSoAvbKBXtEruAO9ah29oldwB3rVOnpFr+AO9Kp19IpewR3oVevoFb2CO9Cr1tEregV3oFeto1f0Cu5gaq/+8Y9/WN27d/fbHPrdbwtuuj3//PMRPZbJvXICG1BhjJycHJ+Te8GCBU6P5DpFRUU+r9F5553n9Ei2vPvuu9ZFF13UPPf48eOtQ4cOhXyccN+wNTl06JA1fvx4n08PvfvuuyEfB6BXraNX9AruQK9aR6/oFdyBXrWOXtEruAO9ah29oldwB3rVOnpFr+AO9Kp19IpewR3oVevoFb2CO5jYq9dee83q2LGj30bT008/3Xr44Yf91r/44ouIHs/UXjmFDagwQm1trZWSkuJzcm/bts3psVxn27Ztfrv8Q/nEjRPWr19vZWRkWFLjp4Qi+RRCpG/Ymjz//PNW586dLUlWRkaG9Ze//CXsYyH50Ct76BW9gvPolT30il7BefTKHnpFr+A8emUPvaJXcB69sode0Ss4j17ZQ6/oFZxHr+yhV/QKzjOxV8uXL7fS0tL8Npnm5ORYu3fvtpYuXeq3HikTe+WkVAEG+Pjjj2VZls/aBRdc4NA07tWzZ0+f+w0NDdq/f79D07Tuqaee0s9//nN5vV6NHDlSu3fv1s9+9jOnx9LPfvYz7dmzRyNHjpTX69XYsWO1atUqp8eCIeiVPfQqOugVIkGv7KFX0UGvEAl6ZQ+9ig56hUjQK3voVXTQK0SCXtlDr6KDXiES9MoeehUd9AqRoFf20KvooFeIhEm9amho0OzZs3XzzTfr5MmTPj/74Q9/qK1btyovL0/FxcU+Pxs0aFDEj21ar5zGBlQYYd++fT73s7Ozddpppzk0jXt17NhRnTt39lk79bVzi1WrVummm25SQ0ODbrrpJm3YsEFZWVlOj9UsKytLGzZsaJ5x4sSJvGmDLfTKHnoVPfQK4aJX9tCr6KFXCBe9sodeRQ+9QrjolT30KnroFcJFr+yhV9FDrxAuemUPvYoeeoVw0St76FX00CuEy5Re1dTUaOzYsXrggQcC/vzpp59Wdna2JMVkA6pJvXIDNqDCCKWlpT73e/To4dAk7nfqLnw3BnDDhg2aNGmSJOm2227TihUrlJaW5vBU/tLS0rRixQrddtttkqRJkybpueeec3gquB29so9eRQ+9QjjolX30KnroFcJBr+yjV9FDrxAOemUfvYoeeoVw0Cv76FX00CuEg17ZR6+ih14hHPTKPnoVPfQK4TClV4cPH9bx48eD/vyCCy7Q1VdfrUOHDumf//ynz8+isQFVMqNXbsEGVBjh0KFDPve7devm0CTu17VrV5/7VVVVDk0S2Hvvvadx48apoaFBkyZN0iOPPKKUlBSnxwoqJSVFjzzySPMnh2644Qa9//77To8FF6NX9tGr6KJXCBW9so9eRRe9QqjolX30KrroFUJFr+yjV9FFrxAqemUfvYoueoVQ0Sv76FV00SuEil7ZR6+ii14hVKb0qmvXrnr55Ze1ceNG5eTkBPydV199VZ06dfJZa9u2rfr27Ru1Gb7Lbb1yEzagwgi1tbU+99u1a+fQJO536mtz6mvnpNraWt14443yer0aOXKkli5d6uo3a01SUlK0bNkyjRw5Ul6vVzfeeKOrXle4C72yj15FH71CKOiVffQq+ugVQkGv7KNX0UevEAp6ZR+9ij56hVDQK/voVfTRK4SCXtlHr6KPXiEU9Mo+ehV99AqhcHOvTp48qZMnTzbfT0lJUUFBgfbs2aP58+fbOkb//v2VkZERlXnc3Cu3YQMqjFBXV+dzPzMz06FJ3M/j8fjcd1MA7733Xu3du1fZ2dl68sknXfk19cGkpaVp5cqV6ty5s/bs2aP77rvP6ZHgUvTKPnoVG/QKdtEr++hVbNAr2EWv7KNXsUGvYBe9so9exQa9gl30yj56FRv0CnbRK/voVWzQK9hFr+yjV7FBr2CX0706ceKE3n//fa1cuVLTp0/XsGHDlJWVpczMTKWnpys9PV2ZmZnKysrSsGHDNH36dP33f/+3vv/979s6/qBBg6I2q5t75TZsQIWRUlP5pxuMW1+b9957Tw888IAkaenSpcrKynJ4otCdffbZWrp0qSRp4cKFfHU9bHHrOekGbn1t6BWSlVvPSTdw62tDr5Cs3HpOuoFbXxt6hWTl1nPSDdz62tArJCu3npNu4NbXhl4hWbn1nHQDt7429ArJyq3npBu49bWhV0hW8TonS0pKNGPGDH3ve9/TwIEDVVhYqMcee0xbtmzR4cOH5fV6m3/X6/Xq8OHD2rJlix577DEVFhZq0qRJth4nmhtQ3dorN+KVAhBztbW1mjBhghoaGjR+/Hj97Gc/c3qksI0aNUrjxo1TQ0ODbrzxRr9PhwAwG70CYAp6BcAU9AqAKegVAFPQKwCmoFcATEGvgNior6/XsmXLlJ+fr/z8fC1evFiHDx+O2vGvueYav28p/dGPfhS148M+NqACiLlHHnlEe/bsUXZ2tv74xz86PU7EFi9erOzsbO3Zs0cPP/yw0+MAiCJ6BcAU9AqAKegVAFPQKwCmoFcATEGvAJiCXgHRV1xcrP79+2vy5MkqKSmJyWP89a9/1Xnnndf8rac5OTk655xzYvJYaBkbUAHEVH19vZYsWSJJevDBB438qvpTZWVlNX/9/uOPP676+nqHJwIQDfQKgCnoFQBT0CsApqBXAExBrwCYgl4BMAW9AqKrqqpKhYWFGjx4sD744IOgv3fBBRdozJgxuv/++/XSSy9px44d2r17t3bv3q0dO3bopZde0v333+/3Daen+vDDD1VcXKwrr7xSo0aNivbTgU1sQAUQUy+++KI+//xzde7cWWPHjnV6nKj5+c9/rk6dOumzzz7TSy+95PQ4ruT1enX48GEdPnxYXq/X6XGAVtGr5EWvYBp6lbzoFUxDr5IXvYJp6FXyolcwDb1KXvQKpqFXyYtewTT0KnnRq+grKSlR3759tXLlyoA/79atm37zm9+otLRUH330kdatW6d58+bp2muvVX5+vvLy8pSXl6f8/Hxde+21+vGPf6y6ujpbj/36669r3bp1Mfu2VbSMDagAYurxxx+XJE2aNKnVTyaYxOPxaNKkSZK+fY5ofEMxY8YMDRgwQB06dFBWVpaysrLUoUMHDRgwQDNmzGjxUy6Ak+hVcqFXMBm9Si70CiajV8mFXsFk9Cq50CuYjF4lF3oFk9Gr5EKvYDJ6lVzoVey8+uqrGjJkiD7//HO/n/Xu3VuvvPKK9u/fr/vuu0+5ubmtHs+yLA0ePNhv/ZFHHtErr7yi3r17+/3s888/15AhQ/Tqq6+G9yQQNjagAoiZDz/8UG+88YZSU1N18803Oz1O1N1yyy1KSUnR5s2b9dFHHzk9jqN27typYcOGKT8/X4sXL9a2bdt04sSJ5p+fOHFC27Zt0+LFi3XJJZdo2LBh2rlzp4MTA77oVfKgVzAdvUoe9Aqmo1fJg17BdPQqedArmI5eJQ96BdPRq+RBr2A6epU86FVsvfTSSyooKNCxY8d81tu3b6+HHnpIO3bs0E9/+lOlpaXZPua8efMCrs+cOVM//elPtWPHDj300ENq3769z8+PHTumkSNH8s2/ccYGVAAxs3TpUknStddeq+7duzs8TfR1795d1157rSTpiSeecHgaZ1iWpQULFqh///7asmWL7b/bsmWL+vfvrwULFsiyrBhOCNhDrxIfvUKioFeJj14hUdCrxEevkCjoVeKjV0gU9Crx0SskCnqV+OgVEgW9Snz0KvbeeecdjR49Wl6v12d96NCh2rt3r2bNmqWMjIyQjlldXa2ioiK/9b179zb/94yMDM2aNUt79+7VkCFDfH7vxIkTGj16tN55552QHhfhYwMqgJhp+kRB01e7J6Km5/byyy87PEn8WZal6dOna+7cuX5vJuzwer2aO3eupk+fzps2OI5eJTZ6hURCrxIbvUIioVeJjV4hkdCrxEavkEjoVWKjV0gk9Cqx0SskEnqV2OhV7H311VcaP3683+s7btw4vf766+rWrVtYx83NzfVby8/PV69evfzWu3Xrps2bN2vcuHE+616vV+PHj9fXX38d1gwITcJvQP3zn/+sW265Rf3795fH41FKSopWr17t9FgwRHl5uVJSUnxuGRkZ6tKli8aOHatt27ZJkh599FGlpKRowoQJQY/11ltvKTU1VQMGDFB9fX28noJjvvrqK3388ceSpH/7t39zeJrYaXpuZWVlSXfhWrhwoZYsWRLxcZYsWaKFCxdGYaLkRq/CR68SH71yF3oVPnqV+OiVu9Cr8NGrxEev3IVehY9eJT565S70Knz0KvHRK3ehV+GjV4mPXrkLvQofvUp89Cq2LMtSYWGhPvnkE5/1iRMn6umnn5bH4wnruMXFxaqsrPRb37p1a9C/8Xg8evrppzVx4kSf9U8++USFhYVsII6DhN+A+utf/1rLly/XgQMH9L3vfc/pcWCo3Nxc3X333br77rs1c+ZMXXjhhVq/fr0GDx6st99+W7fddpuGDx+u1atXN39K5ruOHj2qCRMmyOPxaM2aNUpPT3fgWcTXjh07JEnnnXeezjrrLIeniZ2srCzl5ORI+vY5J4OdO3dq/vz5UTve/PnztXPnzqgdL5nRq9DRq8RGr9yLXoWOXiU2euVe9Cp09Cqx0Sv3oleho1eJjV65F70KHb1KbPTKvehV6OhVYqNX7kWvQkevEhu9ir0VK1Zow4YNPmvDhw/X8uXLlZaWFtYxLcvS4MGD/dYXLVqkzMzMFv82LS1Ny5cv12WXXeaz/pe//EUrV64Max7Yl/AbUFeuXKny8nJVVlZq8uTJTo8DQ/Xo0UP33HOP7rnnHj344IP6n//5HxUVFcnr9eo3v/lN8zfrduzYUYWFhaqqqvL5+1mzZqm8vFxFRUW66KKLHHoW8dX0aap+/fo5PEns9e/fX9K3zzkZTJs2LayvqQ/G6/Vq2rRpUTteMqNXoaNXiY1euRe9Ch29Smz0yr3oVejoVWKjV+5Fr0JHrxIbvXIvehU6epXY6JV70avQ0avERq/ci16Fjl4lNnoVWzU1NZo7d67P2llnnaU///nPYW8+laR58+YFXJ8xY4atv09LS9Of//xnv03lc+fOVU1NTdhzoXUJvwH1iiuuUPfu3Z0eAwnopptukiRt375dktS9e3c9+uijqqio0JQpU5p/b9OmTVq+fLkuv/xy3XbbbY7M6oSm16XpzUwia3pT2vScE11JSYm2bNkS9eNu2bJFH3zwQdSPC3rVGnqVuOiVeehVy+hV4qJX5qFXLaNXiYtemYdetYxeJS56ZR561TJ6lbjolXnoVcvoVeKiV+ahVy2jV4mLXsXe6tWrdfjwYZ+1VatWqUuXLmEfs7q6WkVFRX7re/fuDek4Xbt21VNPPeWzVlVVpT/96U9hz4bWJfwGVCDWvvv18xMmTFBBQYHWr1+vtWvX6uuvv9akSZPUsWNHrVq1SikpKQ5OGl9Nb16S4RNDyfaG7dSLtSnHBr0Khl4lLnplLnoVGL1KXPTKXPQqMHqVuOiVuehVYPQqcdErc9GrwOhV4qJX5qJXgdGrxEWvzEWvAqNXiYtexdbJkyf18MMP+6xdffXVKigoiOi4ubm5fmv5+fnq1atXyMcaOXKkrr76ap+1hx9+WCdPngx7PrSMDahAmFauXClJGjJkiM/68uXLdfbZZ+vWW2/VjTfeqM8++0yPPvpo0n0T77/+9S9JgS8SiaZHjx6Svn3Oia64uNjIYyczetUyepW46JV56FXL6FXiolfmoVcto1eJi16Zh161jF4lLnplHnrVMnqVuOiVeehVy+hV4qJX5qFXLaNXiYtexdbGjRtVVlbms3bHHXdEdMzi4mJVVlb6rW/dujXsY86aNcvnfmlpqV588cWwj4eWpbf+K3ATy7JUU1Pj9Bhx5/V6HX380tJS3XPPPZKkY8eOafv27XrzzTeVnZ2tBx980Od3s7OztWzZMo0ePVobN25UQUGBJkyY4MDUjbxer44dOxbXx2xoaFBtba2kxn+z8Xr87z5OPJ+zZVmSpOPHj6u6ulqpqYm7t9/r9Wrnzp0xO/7OnTv1zTff+HwSzzT0Knz0KvboVfTQq8jRq9DQK3oVLnoVOXoVGnpFr8JFryJHr0JDr+hVuOhV5OhVaOgVvQoXvYocvQoNvaJX4aJXkaNXoaFX9Cpc9Epat26dz/38/HxdfvnlYR/PsiwNHjzYb33RokXKzMwM+7g//vGPdckll6ikpKR57dlnn9WoUaPCPiZaYCWRoqIiS5K1atUqp0cJ29GjRy1JSX+bOnVqXF7v/fv3B53hnHPOsfbt2xf0bwcOHGhJsvbs2ROXWZtMnTrV8f99uHHj9u2NXgVHr7hxc9eNXgVHr7hxc9eNXgVHr7hxc9eNXgVHr7hxc9eNXgVHr7hxc9eNXgVHr7hxc9eNXgVHr7hxc9ct1F51797d5++feOKJiJowd+7cgHNFw+OPP+5zzJycnJD+/tRexavtJkrcbe1AFF111VWyLEuWZengwYN68MEHdfDgQRUUFOjo0aMB/6Zt27Y+/wkA8UCvAJiCXgEwBb0CYAp6BcAU9AqAKegVAFPQKwDx8OWXX+rAgQM+a0OGDAn7eNXV1SoqKvJb37t3b9jH/K5TZysvL1dFRUVUjg1f5n4ncJJq165d0DcIiez222/XihUrnB5DktSpUyfdcccd+uabb3T//ffr17/+tR599FGnxwqqsLBQjzzySFwfs6GhQR07dpQklZWVKTs7Oy6Pe+zYsebHqqioUPv27ePyuBUVFcrNzZUkHTlyJOG/sj47O1snTpyIyfE9Ho8qKiqM/sp6ehU+ehV79Cp66FV00avW0St6FS56FV30qnX0il6Fi15FF71qHb2iV+GiV9FFr1pHr+hVuOhVdNGr1tErehUuehVd9Kp19IpehSvZe/Xuu+/63D/ttNN00UUXhT1L07/L78rPz1evXr3CPuZ35eXlqUOHDj777N59910VFBRE5fj4lrlnRJJKSUmJ20XITTIyMpwewc9dd92lp556So8//rhmzpypnJwcp0cKKCMjw5F/M23atFFtba1j/2bbt28ft8dNSUmR1PjpsNNOOy0uj+mkPn36aNu2bTE79umnnx6TY8cLvQofvYo9ehXdY9Or6KNXLaNXiYtetYxehY9exR69iu6x6VX00auW0avERa9aRq/CR69ij15F99j0KvroVcvoVeKiVy2jV+GjV7FHr6J77GTu1QcffOBzf8CAAUpLSwvrWMXFxaqsrPRb37p1a1jHCyQtLU0DBgzQm2++2bxWUlLCBtQYSNxt7UCMtW3bVrNnz5bX69Vvf/tbp8dxnXPPPVdS4yeGEl1paamkb59zohs0aJCRx05m9Kpl9Cpx0Svz0KuW0avERa/MQ69aRq8SF70yD71qGb1KXPTKPPSqZfQqcdEr89CrltGrxEWvzEOvWkavEhe9ip3q6mqf+926dQvrOJZlafDgwX7rixYtUmZmZljHDObUGZPx/3U8HhJ+A+rKlSt144036sYbb9T69ev91lauXOnwhDDZzTffrHPPPVdr1qxJijcmoejXr58kafv27Q5PEntNz7HpOSe6iRMnGnnsZEevgqNXiYtemYleBUevEhe9MhO9Co5eJS56ZSZ6FRy9Slz0ykz0Kjh6lbjolZnoVXD0KnHRKzPRq+DoVeKiV7HTt29f3XDDDRo5cqRGjBihiy++OKzjzJs3L+D6jBkzIhkvoD59+mjEiBEaOXKkbrjhBvXt2zfqj4Ek2ID697//XX/605/0pz/9STt27JAkvfPOO81rf//73x2eECZr06aN5s6dq/r6et17771O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1JO4pqbGoUnc79TXxk0BbNOmjVatWqWMjAxt3LhRt9xyiyzLcnqsVlmWpVtuuUUbN25UZmYmX1WPFtEr++hV9NErhIJe2Uevoo9eIRT0yj56FX30CqGgV/bRq+ijVwgFvbKPXkUfvUIo6JV99Cr66BVCQa/so1fRR68Qilj36uDBg/roo4981s4880zNmDEjqo8TD27ulduwARVGOPvss33uf/rppw5N4n6fffaZz/2srCyHJgls4MCBWrt2rVJTU/Xkk0/q9ttvd/WbNsuydPvtt+vJJ59Uamqq1q5dy1fVo0X0yj56FV30CqGiV/bRq+iiVwgVvbKPXkUXvUKo6JV99Cq66BVCRa/so1fRRa8QKnplH72KLnqFUNEr++hVdNErhCrWvcrOztaePXs0f/58eTwetW/fXjt37ozqY8SL23vlJmxAhRF69Ojhc7+0tNShSdxv3759Pvd79uzp0CTBjR49WitXrpTU+DXbhYWFrvz6+qavqV+0aJEk6cknn9T111/v8FRwO3plH72KHnqFcNAr++hV9NArhINe2UevoodeIRz0yj56FT30CuGgV/bRq+ihVwgHvbKPXkUPvUI46JV99Cp66BXCEY9etW3bVvfee692796tNWvWqGvXrlF/jHgwoVduwQZUGOHUk7iiokJHjhxxaBr3OnLkiA4ePOiz5tYATpgwQU899VTzJ4dGjx6tqqoqp8dqdujQIY0ePbp5xlWrVunGG290eiwYgF7ZQ6+ih14hXPTKHnoVPfQK4aJX9tCr6KFXCBe9sodeRQ+9QrjolT30KnroFcJFr+yhV9FDrxAuemUPvYoeeoVwxbNXubm5xm6KNqlXbsAGVBjh/PPPV0pKis/aqTvN4f+apKam6rzzznNomtZNmDBB69atU0ZGhjZu3Ki8vDw9//zzTo+l559/Xj/4wQ+0ceNGZWRkaP369bxZg230yh56FR30CpGgV/bQq+igV4gEvbKHXkUHvUIk6JU99Co66BUiQa/soVfRQa8QCXplD72KDnqFSNAre+hVdNArRIJe2WNar5zGBlQYwePxqHv37j5rmzdvdmga93r99dd97nfv3l0ej8ehaewZPXq0/v73v+uiiy7SwYMHdf311+sXv/iFI58eqqqq0vjx43X99dfr4MGDysvL0zvvvGPsJzLgDHplD72KDL1CNNAre+hVZOgV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B3HBBRc4f1RbDjLqBz/4Qa6uri4XEXmXMWPG5JYsWZJrbW1NesSKa2lpyS1ZsiQ3ZsyYPs+7rq4u94Mf/CDpERO1d+/e3tdj7969SY+TKOvD+iDd9OowvdIr0k2vDtMrvSLd9OowvdIr0k2vDtMrvSLd9OowvdIr0k2vDtMrvSLd9Iq0Gknnj3379uX+83/+z73P4Ve/+lW/t3P+qCwbUMmkRx99tN/4zZ49O7dly5akx6u6LVu25GbPnt1vBB999NGkx0uMN2zdrA/rg/TTq256pVekn1510yu9Iv30qpte6RXpp1fd9EqvSD+96qZXekX66VU3vdIr0k+vSKORdP749a9/nZs1a1bvc2hoaBjyd5w/KqMml8vlAjJk37590dTUFC+//HLe8YULF8by5cujtrY2ocmGV1dXVyxatChWrlyZd7yhoSG2bdsWEyZMSGiy5OzZs6f3a753794d7373uxOeaPhZH92sD9JOr/Sqh16RdnqlVz30irTTK73qoVeknV7pVQ+9Iu30Sq966BVpp1d61UOvSDu9Im1G0vlj69at8clPfjLvuVxyySXx/e9/f8jfdf4oX13SA0Cxbr311hERv3LV1tbG8uXLIyLyItjW1ha33npr3HTTTUmNVnW/+c1vYvPmzfH888/Hpk2bYtOmTfHqq6/GgQMHem8zceLEGD9+fBxzzDExc+bMOOOMM2LmzJlx+umnx3ve854Ep68u66PbaF4fpIteDUyvuukVaaFXA9OrbnpFWujVwPSqm16RFno1ML3qplekhV4NTK+66RVpoVcD06tuekVa6BVZMVLOHxs2bIj58+fH7t27845/8IMfLOj3nT/K5xtQyZSWlpY47bTToqOjo/fY7Nmz48knn8xU/Cqpq6sr5syZExs3buw9Vl9fH1u3bo3GxsYEJ6usF198MZYtWxYPPvhg/OxnPyvrvk444YSYO3duLF68OE466aQKTZg866Ov0bI+SBe9Gppe9aVXJEGvhqZXfekVSdCroelVX3pFEvRqaHrVl16RBL0aml71pVckQa+Gpld96RVJ0CuyZqScP+6+++5YvHhxHDx4sM/PfvKTn8QZZ5xR8H05f5TOBlQyZfHixb27ziMixowZEy+88EKcdtppCU6VvC1btkRzc3McOnSo99iiRYti2bJlCU5VvoMHD8YDDzwQd955ZzzxxBN5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WaJXULrvfve78cYbb+Qdu+++++LYY48t+T737NkTt9xyS5/j27dvL+p+pk2bFvfee2/esfb29vgf/+N/lDwbQxvRG1AH0tXVFY888khERJx22mkJT0PW/e4/B7BgwYKYN29erF27NlavXh1vvvlmXH755TFx4sS47777oqamJsFJh1fPm5fR8Ikhb9gGZn2QBXpFhF6RDXpFhF6RDXpFhF6RDXpFhF6RDXpFhF6RDXpFhF6RDXoFpTl06FB8+9vfzjv2iU98IubNm1fW/TY2NvY51tzcHCeffHLR93X++efHJz7xibxj3/72t+PQoUMlz8fg6oa+Sfa9/fbbcfPNN0cul4v29vZ44okn4qc//WksWLAgPvrRjyY9Hhl19913R0TE2WefnXd8xYoV8X/+z/+JP/3TP43Zs2fHK6+8Evfee29Mnz49iTET8+qrr0ZE/yeJkebEE0+MiMPPGeuDbNGr0U2vyBK9Gt30iizRq9FNr8gSvRrd9Ios0avRTa/IEr0a3fSKLNErKM369eujtbU179i1115b1n0+/fTTsWvXrj7Hn3nmmZLv85prromHH36493pLS0s88MADvf9iOpU1ajag3nTTTb3Xa2pq4tprr+33q3vTLpfLxb59+5IeY9h1dnYm+vgtLS3x1a9+NSIi3nrrrdi0aVM8+eSTMXXq1PjmN7+Zd9upU6fGXXfdFfPnz4/169fHvHnzYsGCBQlM3a2zszPeeuutYX3Mrq6uOHDgQER0/80O1+P/7uMM53PO5XIREbF///7Ys2dP1NYO75dLWx+lS2J9kC56pVd6RVbolV7pFVmhV3qlV2SFXumVXpEVeqVXekVW6JVe6RVZoVej8h/L5v+v3PPHmjVr8q43NzfHH/zBH5R8f7lcLs4666w+x++4444YN25cyff7kY98JP79v//38cILL/Qe+/u//3sbUKslN4ocOnQo94tf/CJ355135o466qjchz70odxvf/vbpMcqyt69e3MRMeovV1555bC83i+99NKAM7zvfe/L7dixY8DfnTVrVi4ictu2bRuWWXtceeWVif/3cUn2Yn0MzPpwcUnXRa8GplcuLum66NXA9MrFJV0XvRqYXrm4pOuiVwPTKxeXdF30amB65eKSroteDUyvXFxcXAa+FHv+mD59et7vL1u2rKxGL126tN+5KuHOO+/Mu8+Ghoai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",
      "text/plain": [
       "<Figure size 2700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# test aae_encoder\n",
    "rand_param = torch.normal(0, 0.5, (num_encoder_layer, n_qubits))\n",
    "qml.draw_mpl(aae_encoder, expansion_strategy=\"device\")(None, rand_param)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0.6798+0.j, -0.5494+0.j,  0.0366+0.j,  0.1712+0.j, -0.1708+0.j,  0.0049+0.j,\n",
       "         0.2377+0.j,  0.0530+0.j,  0.0591+0.j,  0.0097+0.j,  0.1316+0.j,  0.0643+0.j,\n",
       "         0.0193+0.j, -0.0712+0.j, -0.2391+0.j,  0.1712+0.j],\n",
       "       dtype=torch.complex128)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# test aae_encoder\n",
    "aae_encoder(None, rand_param)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MMD(x, y, kernel=\"rbf\"):\n",
    "    \"\"\"Emprical maximum mean discrepancy. The lower the result\n",
    "       the more evidence that distributions are the same.\n",
    "\n",
    "    Args:\n",
    "        x: first sample, distribution P\n",
    "        y: second sample, distribution Q\n",
    "        kernel: kernel type such as \"multiscale\" or \"rbf\"\n",
    "    \"\"\"\n",
    "    xx, yy, zz = torch.mm(x, x.t()), torch.mm(y, y.t()), torch.mm(x, y.t())\n",
    "    rx = (xx.diag().unsqueeze(0).expand_as(xx))\n",
    "    ry = (yy.diag().unsqueeze(0).expand_as(yy))\n",
    "\n",
    "    dxx = rx.t() + rx - 2. * xx # Used for A in (1)\n",
    "    dyy = ry.t() + ry - 2. * yy # Used for B in (1)\n",
    "    dxy = rx.t() + ry - 2. * zz # Used for C in (1)\n",
    "\n",
    "    XX, YY, XY = (torch.zeros(xx.shape).to(device),\n",
    "                  torch.zeros(xx.shape).to(device),\n",
    "                  torch.zeros(xx.shape).to(device))\n",
    "\n",
    "    if kernel == \"multiscale\":\n",
    "\n",
    "        bandwidth_range = [0.2, 0.5, 0.9, 1.3]\n",
    "        for a in bandwidth_range:\n",
    "            XX += a**2 * (a**2 + dxx)**-1\n",
    "            YY += a**2 * (a**2 + dyy)**-1\n",
    "            XY += a**2 * (a**2 + dxy)**-1\n",
    "\n",
    "    if kernel == \"rbf\":\n",
    "\n",
    "        bandwidth_range = [10, 15, 20, 50]\n",
    "        for a in bandwidth_range:\n",
    "            XX += torch.exp(-0.5*dxx/a)\n",
    "            YY += torch.exp(-0.5*dyy/a)\n",
    "            XY += torch.exp(-0.5*dxy/a)\n",
    "\n",
    "\n",
    "\n",
    "    return torch.mean(XX + YY - 2. * XY)\n",
    "\n",
    "\n",
    "def tqLoss(result_state, target_state):\n",
    "    return 1 - torch.dot(result_state, target_state).abs() ** 2   # result_state.norm()==1 so dot() is fine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MMD result of X and Y is 0.6277784109115601\n"
     ]
    }
   ],
   "source": [
    "# MMD example\n",
    "\n",
    "%matplotlib inline\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import multivariate_normal\n",
    "from scipy.stats import dirichlet\n",
    "from torch.distributions.multivariate_normal import MultivariateNormal\n",
    "\n",
    "\n",
    "m = 20 # sample size\n",
    "x_mean = torch.zeros(2)+1\n",
    "y_mean = torch.zeros(2)\n",
    "x_cov = 2*torch.eye(2) # IMPORTANT: Covariance matrices must be positive definite\n",
    "y_cov = 3*torch.eye(2) - 1\n",
    "\n",
    "px = MultivariateNormal(x_mean, x_cov)\n",
    "qy = MultivariateNormal(y_mean, y_cov)\n",
    "x = px.sample([m]).to(device)\n",
    "y = qy.sample([m]).to(device)\n",
    "\n",
    "result = MMD(x, y, kernel=\"multiscale\")\n",
    "\n",
    "print(f\"MMD result of X and Y is {result.item()}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0011)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# test of MMD\n",
    "n_sample = 1000\n",
    "X = torch.randn((n_sample, 2))\n",
    "Y = torch.randn((n_sample, 2))\n",
    "criterion = MMD\n",
    "criterion(X, Y)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# data in AAE paper\n",
    "stock = torch.tensor([\n",
    "    [84.80, 90.10, 88.09, 87.87, 80.55],\n",
    "    [53.19, 58.20, 57.41, 56.00, 58.75],\n",
    "    [70.41, 67.03, 65.92, 60.55, 65.73],\n",
    "    [28.83, 28.50, 28.24, 27.27, 25.92],\n",
    "])\n",
    "\n",
    "# qSVD utils\n",
    "\n",
    "def log_return(stock):\n",
    "    return torch.log(stock[:, 1:]) -  torch.log(stock[:, :-1])\n",
    "\n",
    "def norm_return(stock):\n",
    "    n_s, n_t = stock.shape\n",
    "    \n",
    "    ret = log_return(stock)\n",
    "    avg_ret = ret.mean(dim=1)\n",
    "    # std_ret = ret.std(dim=1)\n",
    "    std_ret = torch.sqrt(((ret - avg_ret)**2).mean(dim=1))\n",
    "    \n",
    "    norm_ret = (ret - avg_ret) / std_ret / (n_s*n_t)**0.5\n",
    "    return norm_ret / norm_ret.norm(2)\n",
    "\n",
    "def corr_mat(stock):\n",
    "\n",
    "    norm_ret = norm_return(stock)\n",
    "    corr_matrix = torch.matmul(norm_ret, norm_ret.T)\n",
    "\n",
    "    return corr_matrix\n",
    "\n",
    "ret = norm_return(stock)\n",
    "(ret**2).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "d:\\software\\Anaconda\\envs\\Quantum\\lib\\site-packages\\pennylane\\qnn\\torch.py:432: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at ..\\aten\\src\\ATen\\native\\Copy.cpp:299.)\n",
      "  return res.type(x.dtype)\n"
     ]
    }
   ],
   "source": [
    "# test tqLoss\n",
    "samples = next(iter(train_loader))\n",
    "weight_shapes = {\n",
    "    \"weights\": (num_encoder_layer, n_qubits)\n",
    "    }\n",
    "# Quantum net as a TorchLayer\n",
    "encoder = qml.qnn.TorchLayer(aae_encoder, weight_shapes)\n",
    "# sample\n",
    "loss = tqLoss(encoder(torch.tensor([0.0])), torch.randn((16,)))\n",
    "# encoder(torch.tensor([0.0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter containing:\n",
      "tensor([[4.7370, 1.2268, 0.0317, 1.9278],\n",
      "        [0.7319, 5.7194, 4.0465, 4.4429],\n",
      "        [4.1352, 3.0869, 5.6002, 0.9094],\n",
      "        [3.3394, 0.9973, 4.1103, 2.0597],\n",
      "        [4.1042, 2.4871, 5.7472, 1.2796],\n",
      "        [1.2680, 1.2678, 5.9673, 4.1885],\n",
      "        [6.1646, 0.5489, 0.0255, 0.6837],\n",
      "        [1.0283, 4.4141, 4.2665, 5.7520]], requires_grad=True)\n"
     ]
    }
   ],
   "source": [
    "for p in encoder.parameters():\n",
    "    print(p)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## train and test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def resize_and_norm(image):\n",
    "    image = F.avg_pool2d(image, kernel_size=(7, 7)) # (1, 1, 28, 28) -> (1, 1, 4, 4)\n",
    "    image = image.view(-1) # (1, 1, 4, 4) -> (16, )\n",
    "    image = image/image.norm(2)  # normalize the image to norm(2) == 1 as quamtum state did\n",
    "    return image\n",
    "\n",
    "\n",
    "def train_encoder(sample, encoder, criterion, optimizer, n_step=100, verbose=True):\n",
    "\n",
    "    image = sample[\"images\"]  # assume only one image in this sample, image.shape==(1,C,H,W)\n",
    "    image = resize_and_norm(image)\n",
    "    _ = torch.zeros((1, ), dtype=torch.float32) # inputs doesn't matter, But TorchLayer need it\n",
    "    \n",
    "    # scheduler = CosineAnnealingLR(optimizer, T_max=n_step)\n",
    "\n",
    "    for t in range(n_step):\n",
    "        encoding = encoder(_)        \n",
    "        loss = criterion(encoding, image)\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "\n",
    "        optimizer.step()\n",
    "        # scheduler.step()\n",
    "        \n",
    "        if verbose:\n",
    "            if t % 10 == 0:\n",
    "                print(f\"loss: {loss.item()}\", end='\\r')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# criterion = tqLoss\n",
    "criterion = nn.MSELoss()\n",
    "\n",
    "weight_shapes = {\n",
    "    \"weights\": (num_encoder_layer, n_qubits)\n",
    "    }\n",
    "\n",
    "\n",
    "# Quantum net as a TorchLayer\n",
    "encoder = qml.qnn.TorchLayer(aae_encoder, weight_shapes, init_method = nn.init.uniform_)\n",
    "\n",
    "# Optimizer\n",
    "optimizer = optim.Adam(encoder.parameters(), lr=1e-2)\n",
    "\n",
    "\n",
    "\n",
    "train_loader = DataLoader(train_ds, 1, False)\n",
    "sample = next(iter(train_loader))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "d:\\software\\Anaconda\\envs\\Quantum\\lib\\site-packages\\pennylane\\qnn\\torch.py:432: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at ..\\aten\\src\\ATen\\native\\Copy.cpp:299.)\n",
      "  return res.type(x.dtype)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss: 1.4257464499678463e-05\r"
     ]
    }
   ],
   "source": [
    "train_encoder(sample, encoder, criterion, optimizer, n_step=100)\n",
    "\n",
    "# cpu: AMD R7 5700U, gpu: None\n",
    "# log: MSELoss, 100 steps, 5.6s loss: 0.00013334548566490412\n",
    "# very fast converge\n",
    "# tqLoss converge slightly faster than MSELoss \n",
    "# how about using 16,16 data? take 8 qubits, still fast enough?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OrderedDict([('weights', tensor([[ 0.4847,  0.3867,  1.0314,  0.5042],\n",
      "        [ 0.1791,  0.2833,  0.3132,  0.7110],\n",
      "        [ 1.1980,  0.4885,  0.8691, -0.1068],\n",
      "        [ 0.9438,  0.9482,  0.3994,  0.3256],\n",
      "        [-0.3896,  0.0293, -0.0051,  1.0180],\n",
      "        [ 0.1277,  1.1590,  0.5424,  0.8352],\n",
      "        [ 0.5973, -0.2313,  1.0820, -0.0882],\n",
      "        [ 1.0890,  0.4290,  0.1867,  0.6976]]))])\n"
     ]
    }
   ],
   "source": [
    "sample_index = sample[\"index\"].item()\n",
    "train_ds.save_encoder_params(sample_index, encoder)\n",
    "print(train_ds.data[\"encoder_params\"][sample_index])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([-0.1500,  0.0420,  0.1117, -0.1500, -0.1500,  0.4223,  0.1247, -0.1281,\n",
      "        -0.1478,  0.6348,  0.4751,  0.1081, -0.1500,  0.0170,  0.0232, -0.1500])\n",
      "tensor([-0.1467,  0.0423,  0.1142, -0.1456, -0.1523,  0.4198,  0.1219, -0.1275,\n",
      "        -0.1496,  0.6348,  0.4784,  0.1093, -0.1499,  0.0188,  0.0233, -0.1495],\n",
      "       grad_fn=<ToCopyBackward0>)\n"
     ]
    }
   ],
   "source": [
    "print(resize_and_norm(sample[\"images\"]))\n",
    "print(encoder(torch.tensor(0.0)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x106f55077c0>"
      ]
     },
     "execution_count": 15,
     "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": [
    "fig, axes = plt.subplots(1, 2)\n",
    "axes[0].imshow(resize_and_norm(sample[\"images\"]).view(1, 4, 4).permute(1,2,0))\n",
    "axes[1].imshow(encoder(torch.tensor(0.0)).detach().view(1, 4, 4).permute(1,2,0))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "def train_encoders_for_dataset(dataset, criterion, optimizer, n_step=100):\n",
    "\n",
    "    loader = DataLoader(dataset, 1, False)\n",
    "\n",
    "    for sample in tqdm(loader, leave=False):\n",
    "\n",
    "        weight_shapes = {\n",
    "            \"weights\": (num_encoder_layer, n_qubits)\n",
    "        }\n",
    "        encoder = qml.qnn.TorchLayer(aae_encoder, weight_shapes, init_method = nn.init.uniform_)\n",
    "        train_encoder(sample, encoder, criterion, optimizer, n_step, verbose=False)\n",
    "\n",
    "        sample_index = sample[\"index\"].item()\n",
    "        dataset.save_encoder_params(sample_index, encoder)\n",
    "\n",
    "    dataset.save_dataset_to_disk()\n",
    "    print(\"Encoder params saved to disk\")\n",
    "\n",
    "    return dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# encoder.load_state_dict()\n",
    "# encoder.requires_grad_(False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Results\n",
    "\n"
   ]
  },
  {
   "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": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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
}
