{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "30e40ef2",
   "metadata": {},
   "source": [
    "# Amplitude Encoding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8e97f1d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/pan/SuperEncoder\n"
     ]
    }
   ],
   "source": [
    "%cd ../..\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "import pennylane as qml\n",
    "from pennylane import math\n",
    "from pennylane.ops import QubitStateVector\n",
    "from pennylane.wires import Wires, WireError\n",
    "from pennylane.operation import AnyWires, Operation, StatePrep\n",
    "from pennylane.templates import AmplitudeEmbedding\n",
    "from pennylane.templates.state_preparations import MottonenStatePreparation\n",
    "\n",
    "from qiskit import QuantumCircuit, transpile\n",
    "from qiskit_aer import AerSimulator\n",
    "from qiskit.visualization import plot_histogram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "20b8a44c",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_qubits_list = [4, 6, 8, 10, 12]\n",
    "inputs = []\n",
    "for n_qubits in n_qubits_list:\n",
    "    # If you don't have the inputs, uncomment these two lines\n",
    "    # inputs.append(np.random.rand(2**n_qubits))\n",
    "    # np.save(f\"{n_qubits}qubits\", inputs)\n",
    "\n",
    "    # Load the inputs from the saved files\n",
    "    inputs.append(np.load(f\"scripts/eval_on_real_devices/{n_qubits}qubits.npy\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dfeff379",
   "metadata": {},
   "source": [
    "# Load Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d7f8adcd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def model(device, n_qubits: int, mode: str):\n",
    "    @qml.qnode(device)\n",
    "    def opcir(inputs):\n",
    "        data = inputs/np.linalg.norm(inputs)\n",
    "        MottonenStatePreparation.compute_decomposition(data, wires=range(n_qubits))\n",
    "        if mode == \"prob\":\n",
    "            return qml.probs(wires=range(n_qubits))\n",
    "        elif mode == \"shadow\":\n",
    "            return qml.classical_shadow(wires=range(n_qubits))\n",
    "        elif mode == \"state\":\n",
    "            return qml.state()\n",
    "        else:\n",
    "            raise ValueError(\"Invalid mode. Choose one of 'prob', 'shadow', 'state'.\")\n",
    "    return opcir"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "583f5c90",
   "metadata": {},
   "source": [
    "## KL Divergence\n",
    "\n",
    "Compare the *KL Divergence* of the probilities between the ideal stimulator and the real device."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "258d1998",
   "metadata": {},
   "outputs": [],
   "source": [
    "state = []\n",
    "for i in range(len(inputs)):\n",
    "    dev = qml.device('default.qubit', wires=n_qubits_list[i])\n",
    "    opcir = model(dev, n_qubits_list[i], \"prob\")\n",
    "    state.append(opcir(inputs[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "4952b611",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "json_decoder.target_from_server_data:WARNING:2024-05-12 16:46:13,278: Definition of instruction switch_case is not found in the Qiskit namespace and GateConfig is not provided by the BackendConfiguration payload. Qiskit Gate model cannot be instantiated for this instruction and this instruction is silently excluded from the Target. Please add new gate class to Qiskit or provide GateConfig for this name.\n"
     ]
    }
   ],
   "source": [
    "state_ibmq = []\n",
    "for i in range(len(inputs)):\n",
    "    # Use the following line to run on a real quantum device\n",
    "    dev = qml.device(name='qiskit.ibmq', backend='ibm_osaka', wires=n_qubits_list[i])\n",
    "\n",
    "    # Use the following line to run on a qiskit simulator\n",
    "    # dev = qml.device(name='qiskit.aer', wires=n_qubits_list[i])\n",
    "\n",
    "    opcir = model(dev, n_qubits_list[i], \"prob\") \n",
    "    state_ibmq.append(opcir(inputs[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9917aed8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# If you have the result csv file from IBMQ, \n",
    "# you can load it and compare the results\n",
    "\n",
    "# import csv\n",
    "# import numpy as np\n",
    "\n",
    "# with open('scripts/4qubits.csv', 'r') as file:\n",
    "#     reader = csv.reader(file)\n",
    "#     next(reader)  \n",
    "#     data = [int(row[0]) for row in reader]\n",
    "\n",
    "# state_ibmq_raw = np.array(data)\n",
    "# state_ibmq = [state_ibmq / state_ibmq.sum()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0a4b4f98",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.3815138254643998,\n",
       " 1.1624995666710198,\n",
       " 1.5615645810521213,\n",
       " 2.0671454166945913,\n",
       " 3.062701092124031]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from scipy import stats\n",
    "\n",
    "entropy = []\n",
    "for i in range(len(state)):\n",
    "    # NOTE: Please check the item in the state list to make sure it is a one dimensional array or tensor.\n",
    "    # NOTE: The returned value may be different from the device choosed.\n",
    "    entropy.append(stats.entropy(state[i][0],inputs[i][0]))\n",
    "entropy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "993adbfe",
   "metadata": {},
   "source": [
    "# Fidelity\n",
    "\n",
    "We can also use [classical shadows](https://pennylane.ai/qml/demos/tutorial_classical_shadows/) to reconstruct the density matrix for the real device so that we can calculate the *Fidelity* of the density matrix between the ideal stimulator and the real device."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a3d041c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# The functions we need to use to calculate the shadow.\n",
    "# Citation: https://pennylane.ai/qml/demos/tutorial_classical_shadows/\n",
    "\n",
    "def snapshot_state(b_list, obs_list):\n",
    "    \"\"\"\n",
    "    Helper function for `shadow_state_reconstruction` that reconstructs\n",
    "     a state from a single snapshot in a shadow.\n",
    "\n",
    "    Implements Eq. (S44) from https://arxiv.org/pdf/2002.08953.pdf\n",
    "\n",
    "    Args:\n",
    "        b_list (array): The list of classical outcomes for the snapshot.\n",
    "        obs_list (array): Indices for the applied Pauli measurement.\n",
    "\n",
    "    Returns:\n",
    "        Numpy array with the reconstructed snapshot.\n",
    "    \"\"\"\n",
    "    num_qubits = len(b_list)\n",
    "\n",
    "    # computational basis states\n",
    "    zero_state = np.array([[1, 0], [0, 0]])\n",
    "    one_state = np.array([[0, 0], [0, 1]])\n",
    "\n",
    "    # local qubit unitaries\n",
    "    phase_z = np.array([[1, 0], [0, -1j]], dtype=complex)\n",
    "    hadamard = qml.matrix(qml.Hadamard(0))\n",
    "    identity = qml.matrix(qml.Identity(0))\n",
    "\n",
    "    # undo the rotations that were added implicitly to the circuit for the Pauli measurements\n",
    "    unitaries = [hadamard, hadamard @ phase_z, identity]\n",
    "\n",
    "    # reconstructing the snapshot state from local Pauli measurements\n",
    "    rho_snapshot = [1]\n",
    "    for i in range(num_qubits):\n",
    "        state = zero_state if b_list[i] == 1 else one_state\n",
    "        U = unitaries[int(obs_list[i])]\n",
    "\n",
    "        # applying Eq. (S44)\n",
    "        local_rho = 3 * (U.conj().T @ state @ U) - identity\n",
    "        rho_snapshot = np.kron(rho_snapshot, local_rho)\n",
    "\n",
    "    return rho_snapshot\n",
    "\n",
    "\n",
    "def shadow_state_reconstruction(shadow):\n",
    "    \"\"\"\n",
    "    Reconstruct a state approximation as an average over all snapshots in the shadow.\n",
    "\n",
    "    Args:\n",
    "        shadow (tuple): A shadow tuple obtained from `calculate_classical_shadow`.\n",
    "\n",
    "    Returns:\n",
    "        Numpy array with the reconstructed quantum state.\n",
    "    \"\"\"\n",
    "    num_snapshots, num_qubits = shadow[0].shape\n",
    "\n",
    "    # classical values\n",
    "    b_lists, obs_lists = shadow\n",
    "\n",
    "    # Averaging over snapshot states.\n",
    "    shadow_rho = np.zeros((2 ** num_qubits, 2 ** num_qubits), dtype=complex)\n",
    "    for i in range(num_snapshots):\n",
    "        shadow_rho += snapshot_state(b_lists[i], obs_lists[i])\n",
    "\n",
    "    return shadow_rho / num_snapshots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "91d9c624",
   "metadata": {},
   "outputs": [],
   "source": [
    "rho=[]\n",
    "for i in range(len(inputs)):\n",
    "    dev = qml.device('default.mixed', wires=n_qubits_list[i])\n",
    "    opcir = model(dev, n_qubits_list[i], \"state\")\n",
    "    rho.append(opcir(inputs[i]))\n",
    "\n",
    "# NOTE: Using the classical shadows algorithm above, two returned states have opposite sequences.\n",
    "rho_transform = np.array([np.real(rho[0])])[0]\n",
    "matrix_ud = rho_transform[::-1]\n",
    "matrix_ud_lr = np.array([row[::-1] for row in matrix_ud])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "65448c80",
   "metadata": {},
   "outputs": [],
   "source": [
    "rho_aer = []\n",
    "for i in range(len(inputs)):\n",
    "    # dev = qml.device(name='qiskit.ibmq', backend='ibm_osaka', wires=n_qubits_list[i], shots=1024)\n",
    "    dev = qml.device(name='qiskit.aer', wires=n_qubits_list[i], shots=1024)\n",
    "    opcir = model(dev, n_qubits_list[i], \"shadow\")\n",
    "    rho_aer.append(opcir(inputs[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "5b89a981",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.955144867719652"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shadow_rho_aer = shadow_state_reconstruction(rho_aer[0])\n",
    "shadow_rho_aer = np.abs(np.real(shadow_rho_aer))\n",
    "\n",
    "# NOTE: Due to the numerical error, the trace of the matrix may not be 1.\n",
    "trace = np.trace(shadow_rho_aer)\n",
    "shadow_rho_aer = shadow_rho_aer / trace\n",
    "\n",
    "qml.math.fidelity(shadow_rho_aer, matrix_ud_lr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "f4984ec0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2022/1225017438.py:29: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCkAAAHqCAYAAAApshTaAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB5IUlEQVR4nO3dd3hUZdrH8d+kTUJCAkhJ6L1JNQgLCLFEQFwgFhBkpaioLLgCC2osIKJGFBULC1bEgmBBRF8FEcGyIi0ioIB0kBJKJNFE0ua8f2BmGVJIOXPOMPl+rutcmnPOPPdz0u7hzlMchmEYAgAAAAAAsFmA3R0AAAAAAACQKFIAAAAAAAAfQZECAAAAAAD4BIoUAAAAAADAJ1CkAAAAAAAAPoEiBQAAAAAA8AkUKQAAAAAAgE+gSAEAAAAAAHwCRQoAAAAAAOATKFIAFciTTz6pxo0bKzAwUB06dCh3e6tWrZLD4dD7779f/s6dw4gRI9SwYUOvxzkf7d27Vw6HQ6+//rrdXQEAnIPZudjuHHDppZfq0ksvtSV2UV5//XU5HA7t3bvX7q6UCe95UNFRpIBt8hPI+vXrC71+6aWXqk2bNl7tw6effqqHHnrIqzF8xeeff667775b3bt319y5c/XYY48Ve//HH3+suLg41axZU5UqVVLjxo01aNAgLV261KIe+yaHwyGHw6Fbb7210Ov333+/+57jx4+Xuv2K9D0JwH7kYmuRi/8nMzNTDz30kFatWmVbHx566CE5HA4FBATowIEDBa6np6crLCxMDodDY8eOLXX7vvCMwPmIIgUqtE8//VRTp061uxuW+PLLLxUQEKBXX31Vw4YNU9++fYu8d8aMGerfv78cDocSExP1zDPP6LrrrtOOHTu0YMECC3vtm0JDQ/XBBx8oOzu7wLV33nlHoaGhZW67LN+TDRo00J9//qmbbrqpzHEBwC7k4sKVNBefrzkgMzNTU6dO9Yl/wDudTr3zzjsFzi9atKhc7Zb1GV9++WVt3769XLGB81mQ3R0AYI2jR48qLCxMISEhxd6Xm5uradOm6corr9Tnn39eaDsVXZ8+fbRkyRJ99tlnGjBggPv8d999pz179ui6667TBx984PV+5ObmyuVyKSQkpFyFEQCANbyRix0OBzmgnPr27at33nlHd999t8f5+fPn6+qrr7Ykp0tSRkaGwsPDFRwcbEk8wFcxkgLnnbfeekuxsbEKCwtTtWrVNHjw4AJD9L755hsNHDhQ9evXl9PpVL169TR+/Hj9+eef7ntGjBihWbNmSfrfEH6HwyHpf/M7Z8yYoVmzZqlx48aqVKmSevXqpQMHDsgwDE2bNk1169ZVWFiYBgwYoNTUVI8+fPTRR7r66qtVu3ZtOZ1ONWnSRNOmTVNeXp7HfflDaTds2KBu3bopLCxMjRo10pw5c0r0+ch/I9OkSRM5nU41bNhQ9913n7Kystz3OBwOzZ07VxkZGe7nLGru6vHjx5Wenq7u3bsXer1mzZoFzrlcLj366KOqW7euQkNDdcUVV2jnzp0e95Tka5Jv8eLFatOmjUJDQ9WmTRt9+OGHhfYlIyND//73v1WvXj05nU61aNFCM2bMkGEY7nuuvfZaXXTRRR6v69evnxwOh5YsWeI+t2bNGjkcDn322WeFxjpTnTp11LNnT82fP9/j/Ntvv622bdsWOjTazO/JmTNnur/eP//8c4H5yEePHlWNGjV06aWXenwudu7cqfDwcN1www3nfEYAKA652JOdubiwNSlGjBihiIgI7d+/X3//+98VERGhOnXquD/Xmzdv1uWXX67w8HA1aNCgQD7LnwZxtpKs9ZCdna3JkycrNjZWUVFRCg8PV48ePbRy5UqPPteoUUOSNHXqVPfn48xpP9u2bdP111+vatWqKTQ0VJ06dfLI2/l++uknXX755QoLC1PdunX1yCOPyOVyFdm/wtx4443auHGjtm3b5j535MgRffnll7rxxhu98oz5X6Ndu3apb9++qly5soYOHeq+duaaFFOmTFFAQIBWrFjh0Y/bbrtNISEh+vHHH0v1vICvYyQFbJeWllbo3P2cnJwC5x599FE9+OCDGjRokG699VYdO3ZMzz//vHr27KkffvhBVapUkSS99957yszM1OjRo3XBBRdo7dq1ev755/Xrr7/qvffekyTdfvvtOnTokJYvX64333yz0L69/fbbys7O1p133qnU1FQ98cQTGjRokC6//HKtWrVK99xzj3bu3Knnn39eEydO1GuvveZ+7euvv66IiAhNmDBBERER+vLLLzV58mSlp6frySef9Ijz22+/qW/fvho0aJCGDBmid999V6NHj1ZISIhuvvnmYj9/t956q+bNm6frr79e//73v7VmzRolJSVp69at7n/c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WJgSEhL01ltv6aqrrlL16tULvc+u78mlS5fqlVde0d133623335bw4cP15o1axgaCqDMyMUFnS+5uDTyR0SePHnSo7hdklEh77//vho3bqxFixZ5fG2nTJnicV9RX/fGjRtLOj0qJz4+vthYDRo0KNF7hpK68cYbNXnyZB0+fLjIhVyl8j9jWeQvgB0ZGalx48bpscce0/XXX+9ekBPwJ6xJgfPGtddeq8DAQE2dOtWj2i+drv6fOHFC0v/+QnDmPYZh6Nlnny3QZv4bkZMnT5ra18L6kJ2dXeSuCrm5uXrxxRc97n3xxRdVo0YNxcbGFhmnb9++kqSZM2d6nH/66aclqdAVqc8lMzNTq1evLvRa/joPpR1GWdKvSUxMjDp06KB58+Z5DMNdvny5fv75Z497+/btq7y8PL3wwgse55955hk5HA5dddVV7nNdunRRcHCwpk+frmrVqunCCy+UdLp48f333+urr74q9SiKfBMnTtSUKVOKHJIq2fM9efLkSd16663q3LmzHnvsMb3yyitKTk7WY489Vq52AVRs5OKCzpdcXBpNmjSRJPd6TtLpdUXmzZt3ztcW9nlfs2ZNgefJ38ni7K97zZo1demll+rFF18stBBz7Ngx9//37dtX33//vdauXetx/e233z5nPwvTpEkTzZw5U0lJSR7rXJytvM9YFk8//bS+++47vfTSS5o2bZq6deum0aNHF7orD3C+489pOG80adJEjzzyiBITE7V3714lJCSocuXK2rNnjz788EPddtttmjhxolq2bKkmTZpo4sSJOnjwoCIjI/XBBx8UOtcy/03Hv/71L/Xu3VuBgYEaPHhwufvarVs3Va1aVcOHD9e//vUvORwOvfnmmwXe0OWrXbu2pk+frr1796p58+ZauHChNm7cqJdeesljfu/Z2rdvr+HDh+ull15yD2tdu3at5s2bp4SEBF122WWl7ntmZqa6deumv/3tb+rTp4/q1aunkydPavHixfrmm2+UkJCgjh07lqrN0nxNkpKSdPXVV+uSSy7RzTffrNTUVD3//PO68MIL9ccff7jv69evny677DLdf//92rt3r9q3b6/PP/9cH330kcaNG+d+gyWdfpMQGxur77//Xv369XP/ZaNnz57KyMhQRkZGmYsU7du3P+fWX3Z8T9511106ceKEvvjiCwUGBqpPnz669dZb9cgjj2jAgAFsVwagTMjFBZ0vubg0evXqpfr16+uWW27RpEmTFBgYqNdee001atTQ/v37i33t3//+dy1atEjXXHONrr76au3Zs0dz5sxR69atPfJ4WFiYWrdurYULF6p58+aqVq2a2rRpozZt2mjWrFm65JJL1LZtW40aNUqNGzdWSkqKVq9erV9//VU//vijJOnuu+/Wm2++qT59+uiuu+5yb0HaoEEDbdq0qUzPftddd53zHjOesTS2bt2qBx98UCNGjFC/fv0knd5et0OHDvrnP/+pd999t3QPCfg6r+8fAhQhfxurdevWFXo9Li7OY9uzfB988IFxySWXGOHh4UZ4eLjRsmVLY8yYMcb27dvd9/z8889GfHy8ERERYVSvXt0YNWqU8eOPPxbYois3N9e48847jRo1ahgOh8O93Vb+dl5PPvmkR+z8LTffe++9cz7Lf//7X+Nvf/ubERYWZtSuXdu4++67jWXLlhmSjJUrVxZ4zvXr1xtdu3Y1QkNDjQYNGhgvvPBCiT6POTk5xtSpU41GjRoZwcHBRr169YzExESPbbsMo+TbnuXk5Bgvv/yykZCQYDRo0MBwOp1GpUqVjI4dOxpPPvmkx5ZbRX0+CtsOraRfE8M4/TVu1aqV4XQ6jdatWxuLFi0qdDuu33//3Rg/frxRu3ZtIzg42GjWrJnx5JNPGi6Xq8BzTZo0yZBkTJ8+3eN806ZNDUnGrl27zvm5MYyC25AVprAtSL31PXnmtfx2PvroowJb6RmGYaSnpxsNGjQw2rdvX+x2egAqDnKx53Oej7m4qC1IC4tT1NezQYMGxtVXX+1xbsOGDUaXLl2MkJAQo379+sbTTz9doi1IXS6X8dhjj7n73bFjR+OTTz4pNI9/9913RmxsrBESElJgq85du3YZw4YNM6Kjo43g4GCjTp06xt///nfj/fff92hj06ZNRlxcnBEaGmrUqVPHmDZtmvHqq6+WegvS4pyd+814xuK+F85sJzc317j44ouNunXremzFaxj/2/J94cKFxfYfON84DKOIcjIAS1x66aU6fvy4tmzZYndXAACokMjFAOA7WJMCAAAAAAD4BIoUAAAAAADAJ1CkAAAAAAAAPoE1KQAAAAAAgE9gJAUAAAAAAPAJFCkAAAAAAIBPoEgBAAAAAAB8QpDdHfCGUx88Y1msKSfusCyWJO366bBlsS6IqWJZrEu6VbMs1vzXNlkWq//gdpbFunHLXZbFGp9xv2WxJOk/rd+0LFZym9ssi3XRrrcsi/WiYd3vqriWxy2LFezItSzWAzP/sCyWJH34QjNL49llU99LLYv18wMrLYs15+nvLYvV6Yr2lsW6vEuwZbEWfGjd7xJJiu0cbVmsUdUWWRZrxt4BlsW6YkYXy2I1XPi6ZbEu2L3Gslh3Jl9jWSxJemzATstiZQdXsizWoh1tLIt159UOy2JVFIykAAAAAAAAPoEiBQAAAAAA8AkUKQAAAAAAgE+gSAEAAAAAAHwCRQoAAAAAAOATKFIAAAAAAACfQJECAAAAAAD4BIoUAAAAAADAJ1CkAAAAAAAAPiHIzuDHjx/Xa6+9ptWrV+vIkSOSpOjoaHXr1k0jRoxQjRo17OweAAD4CzkbAABYwbaRFOvWrVPz5s313HPPKSoqSj179lTPnj0VFRWl5557Ti1bttT69evt6h4AAPgLORsAAFjFtpEUd955pwYOHKg5c+bI4XB4XDMMQ3fccYfuvPNOrV69uth2srKylJWV5fn6nFw5g20dJAIAgN/wZs7OznMpJJDZpwAA4DTb3hX8+OOPGj9+fIE3O5LkcDg0fvx4bdy48ZztJCUlKSoqyuN4ctEXXugxAAAVkzdz9qu793uhxwAA4HxlW5EiOjpaa9euLfL62rVrVatWrXO2k5iYqLS0NI9j0rXxZnYVAIAKzZs5+5bG9c3sKgAAOM/ZNidi4sSJuu2227RhwwZdccUV7jc3KSkpWrFihV5++WXNmDHjnO04nU45nU6Pc6eY6gEAgGm8mbOZ6gEAAM5k27/mx4wZo+rVq+uZZ57Rf/7zH+Xl5UmSAgMDFRsbq9dff12DBg2yq3sAAOAv5GwAAGAVW4cc3HDDDbrhhhuUk5Oj48ePS5KqV6+u4OBgO7sFAADOQs4GAABW8Il5EcHBwYqJibG7GwAA4BzI2QAAwJuYCAoAAAAAAHwCRQoAAAAAAOATKFIAAAAAAACfQJECAAAAAAD4BIoUAAAAAADAJ1CkAAAAAAAAPoEiBQAAAAAA8AkOwzAMuzthtnte+tOyWPt3HrMsliQd3n3QslhVo6tbFuu3I8ctixVVo5plseo2qWVZrCbNoiyLtfzDzZbFkqTL+rWxLNaq//vJslgDBre1LNaqL/ZbFuvPP05ZFuu2WxtZFutgarBlsSRpVLyl4Wyz4Dvr3oZ8tjTFsli7f9xhWaxqtWtaFqtG3Qssi3Xgl18tiyVJVWpUtSxWu051LYu14bs9lsX6xz8aWxZr7Y/ZlsWqVi3EslhWvg+RpI6XNLcsVl6edb/v92y37vf9whkNLItVUTCSAgAAAAAA+ASKFAAAAAAAwCdQpAAAAAAAAD6BIgUAAAAAAPAJFCkAAAAAAIBPoEgBAAAAAAB8AkUKAAAAAADgEyhSAAAAAAAAn0CRAgAAAAAA+ASKFAAAAAAAwCcE2d2B4hw4cEBTpkzRa6+9VuQ9WVlZysrK8jiXm+NSULDT290DAAB/KWvOzskOUXAIORsAUPGcOnVK2dnZprUXEhKi0NBQ09qzi0+PpEhNTdW8efOKvScpKUlRUVEex/dLn7SohwAAQCp7zv7ozSSLeggAgO84deqUaodFFMiL5TkaNWqkU6dO2f1o5WbrSIolS5YUe3337t3nbCMxMVETJkzwODf1TVe5+gUAADx5K2d/lBxSrn4BAHA+ys7O1m/K07zQxqpkwtiBTLk0/MhuZWdnn/ejKWwtUiQkJMjhcMgwjCLvcTgcxbbhdDrldHoOEw0K/tOU/gEAgNO8lbODQ4puDwAAf1dJAarkCCx/Q36UTm2d7hETE6NFixbJ5XIVeiQnJ9vZPQAA8BdyNgAA5nMEORRgwuEIKv4PBecTW4sUsbGx2rBhQ5HXz/UXGwAAYA1yNgAA5nMEB5h2+Atbn2TSpEnq1q1bkdebNm2qlStXWtgjAABQGHI2AADmCwg0ZyRFQGDZRlLMmjVLDRs2VGhoqLp06aK1a9cWee/LL7+sHj16qGrVqqpatari4+ML3D9ixAg5HA6Po0+fPqXqk61rUvTo0aPY6+Hh4YqLi7OoNwAAoCjkbAAA/MvChQs1YcIEzZkzR126dNHMmTPVu3dvbd++XTVr1ixw/6pVqzRkyBB169ZNoaGhmj59unr16qWffvpJderUcd/Xp08fzZ071/3x2etRnYv/jAkBAAAAAOA84gh2mHaU1tNPP61Ro0Zp5MiRat26tebMmaNKlSrptddeK/T+t99+W//85z/VoUMHtWzZUq+88opcLpdWrFjhcZ/T6VR0dLT7qFq1aqn6RZECAAAAAAAbmDLV46+jNLKzs7VhwwbFx8f/ry8BAYqPj9fq1atL1EZmZqZycnJUrVo1j/OrVq1SzZo11aJFC40ePVonTpwoVd9sne4BAAAAAADMkZ6e7vFxYdt/S9Lx48eVl5enWrVqeZyvVauWtm3bVqJY99xzj2rXru1R6OjTp4+uvfZaNWrUSLt27dJ9992nq666SqtXr1ZgYMm2WqVIAQAAAACADRzBDjkCyr99qMN1uo169ep5nJ8yZYoeeuihcrd/tscff1wLFizQqlWrFBoa6j4/ePBg9/+3bdtW7dq1U5MmTbRq1SpdccUVJWqbIgUAAAAAADYICCz7zhwe7eSdbuPAgQOKjIx0ny9q0crq1asrMDBQKSkpHudTUlIUHR1dbKwZM2bo8ccf1xdffKF27doVe2/jxo1VvXp17dy5s8RFCtakAAAAAADABo5Ah2mHJEVGRnocRRUpQkJCFBsb67HoZf4imF27di2yv0888YSmTZumpUuXqlOnTud8vl9//VUnTpxQTExMiT8nfjmSYtdPhy2LdfxgyrlvMlHtpvXOfZNJUvYesixWjXrFV+vM1Kl7A8tiJX9/wLJYh/YesyxWRlr6uW8y0YEDf1gWq3qd6pbFeve1ovehNlvDCxtZFqtKjchz32SSZd+csixWQGCWZbEkSfER1sazyZynv7csVl5OrmWxDJfLslgnfj1iWazUQ0cti2Xl51CSMk/+blmsI7sPWhbLlZdnWaznZ5RucbzyyMvJsSyWw2Hd33WtfC5J+ubjdZbGs4rhMiyMZt2/Lcw2YcIEDR8+XJ06dVLnzp01c+ZMZWRkaOTIkZKkYcOGqU6dOkpKSpIkTZ8+XZMnT9b8+fPVsGFDHTlyOv9EREQoIiJCf/zxh6ZOnarrrrtO0dHR2rVrl+6++241bdpUvXv3LnG//LJIAQAAAACArzNtuodK38YNN9ygY8eOafLkyTpy5Ig6dOigpUuXuhfT3L9/vwIC/lekmz17trKzs3X99dd7tJO/7kVgYKA2bdqkefPm6eTJk6pdu7Z69eqladOmFTmiozAUKQAAAAAAsIEjwKSFM42ytTF27FiNHTu20GurVq3y+Hjv3r3FthUWFqZly5aVqR9nokgBAAAAAIANHIEBcgSWf0qRQ1ZOcfEuFs4EAAAAAAA+gZEUAAAAAADYwM41KXwVRQoAAAAAAGzgcJi0JoXLf4oUTPcAAAAAAAA+gZEUAAAAAADYwBEoU6Z7OPxn3UyKFAAAAAAA2MER6JDDlCKF/0z3oEgBAAAAAIANHAEBcgSYsAWpCW34Ctuf5M8//9S3336rn3/+ucC1U6dO6Y033rChVwAA4EzkawAAYAVbixS//PKLWrVqpZ49e6pt27aKi4vT4cOH3dfT0tI0cuTIYtvIyspSenq6x5GXm+XtrgMAUGGYka+lwnO2Ky/bm10HAMCnOQIcph3+wtYixT333KM2bdro6NGj2r59uypXrqzu3btr//79JW4jKSlJUVFRHsf29XO82GsAACoWM/K1VHjO3r+dERgAgIorINBh2uEvbC1SfPfdd0pKSlL16tXVtGlTffzxx+rdu7d69Oih3bt3l6iNxMREpaWleRwtOt3h5Z4DAFBxmJGvpcJzdv0Ww7zYcwAAfBsjKQqytUjx559/Kijof2t3OhwOzZ49W/369VNcXJx++eWXc7bhdDoVGRnpcQQGOb3ZbQAAKhQz8rVUeM4OCAzxVrcBAMB5yNbdPVq2bKn169erVatWHudfeOEFSVL//v3t6BYAADgD+RoAAO9wOEza3cNh+54YprH1Sa655hq98847hV574YUXNGTIEBmGYXGvAADAmcjXAAB4B9M9CrK1SJGYmKhPP/20yOv/+c9/5HK5LOwRAAA4G/kaAADvYOHMgvxnTAgAAAAAADiv2bomBQAAAAAAFZVZUzX8aboHRQoAAAAAAGzgCDBp4UwT2vAV/vMkAAAAAADgvMZICgAAAAAAbMB0j4IoUgAAAAAAYAOKFAX5ZZHigpgqlsXKy8uzLJYkpew9ZFmsTpe3tSzW3l+OWhZr8w9HLIt14uAxy2IZhnXb/7W4uJVlsSRp16Z9lsUKjQizLFaHnhdaFiszI8eyWL3iKlsW67VXf7EsljPUaVms0yIsjmePTle0tyzWjk0HLIt14lfrck1YpHXfKxFVIy2LdfJoqmWxJCksopJlsaIb1LIs1sHd1r137NC9hWWxft1j3fdHWIR1v//3bN5tWSxJimlS17JYhsuwLNbJY79ZFqu8KFIUxJoUAAAAAADAJ/jlSAoAAAAAAHzd6ZEUZuzu4T8jKShSAAAAAABgA0eAQwGBJkz3yKNIAQAAAAAAyoE1KQpiTQoAAAAAAOATGEkBAAAAAIANHAEBJq1J4T/jDyhSAAAAAABgA6Z7FESRAgAAAAAAG1CkKMh/xoQAAAAAAIDzGiMpAAAAAACwAWtSFGT7k2zdulVz587Vtm3bJEnbtm3T6NGjdfPNN+vLL7+0uXcAAEAiXwMA4A350z3MOPyFrSMpli5dqgEDBigiIkKZmZn68MMPNWzYMLVv314ul0u9evXS559/rssvv7zINrKyspSVleVxLi83S4FBTm93HwCACsGMfC0VnrNzc/IUFEzOBgAAp9k6kuLhhx/WpEmTdOLECc2dO1c33nijRo0apeXLl2vFihWaNGmSHn/88WLbSEpKUlRUlMfxw6qZ1jwAAAAVgBn5Wio8Z69dNsOCJwAAwDflT/cw4/AXtj7JTz/9pBEjRkiSBg0apN9//13XX3+9+/rQoUO1adOmYttITExUWlqax9Hx0nFe7DUAABWLGflaKjxnd+490VvdBgDA9zkc5h1+wvaFMx1/fTIDAgIUGhqqqKgo97XKlSsrLS2t2Nc7nU45nZ7DRAODcs3vKAAAFVh587VUeM4OCs40t6MAAJxHHA6TtiD1oyKFrSMpGjZsqB07drg/Xr16terXr+/+eP/+/YqJibGjawAA4C/kawAAYBVbR1KMHj1aeXl57o/btGnjcf2zzz475yJcAADAu8jXAAB4B1uQFmRrkeKOO+4o9vpjjz1mUU8AAEBRyNcAAHiHWduHsgUpAAAAAAAoF0ZSFOQ/TwIAAAAAAM5rjKQAAAAAAMAGjgBzpmo4/Gj4AUUKAAAAAABswJoUBflRvQUAAAAAAJzPGEkBAAAAAIAdAgJOH2a04yf8skhxSbdqlsV69bntlsWSpBr1oi2LtfeXo5bFqtu4umWxgoL85wf4TBf/LcayWKuW7bQsliT97YpWlsXaviXFsli7fz5kWaxa9az7GcvKte5nrPeAlpbFWvbRNstiVSSXdwm2LNbJ1Assi5V6yLocGlE10rJY0Q1qWBbr1B9/WhZLkqrWsu79Y5sO1n0e/0jPtCxWfBfrfv9/V6mmZbEuqGbdP5kO7zliWSxJatHGus9jbo5hWSxr36mWj8PhkMNhwnQPE9rwFX5ZpAAAAAAAwNexBWlB/vMkAAAAAADgvMZICgAAAAAAbMDuHgVRpAAAAAAAwA4OkxbOdPjPJAmKFAAAAAAA2MGkkRTyo5EU/lNuAQAAAAAA5zVGUgAAAAAAYAOHI0AOE6ZqmNGGr6BIAQAAAACAHQIc5kzV8KPpHj5XpDAMQw6H/3yCAQDwV+RsAADKxxEQIIcJC2ea0Yav8LkncTqd2rp1q93dAAAA50DOBgDg/DZr1iw1bNhQoaGh6tKli9auXVvkvS+//LJ69OihqlWrqmrVqoqPjy9wv2EYmjx5smJiYhQWFqb4+Hjt2LGjVH2ybSTFhAkTCj2fl5enxx9/XBdccIEk6emnn7ayWwAA4CzkbAAAvMNh0u4eZWlj4cKFmjBhgubMmaMuXbpo5syZ6t27t7Zv366aNWsWuH/VqlUaMmSIunXrptDQUE2fPl29evXSTz/9pDp16kiSnnjiCT333HOaN2+eGjVqpAcffFC9e/fWzz//rNDQ0BL1y7YixcyZM9W+fXtVqVLF47xhGNq6davCw8NLNIQ0KytLWVlZHudysp0KDnGa2V0AACos7+bsAHI2AKDicjgkMxa9LMP0y6efflqjRo3SyJEjJUlz5szR//3f/+m1117TvffeW+D+t99+2+PjV155RR988IFWrFihYcOGyTAMzZw5Uw888IAGDBggSXrjjTdUq1YtLV68WIMHDy5Rv2yb7vHYY48pLS1NDz74oFauXOk+AgMD9frrr2vlypX68ssvz9lOUlKSoqKiPI6P306y4AkAAKgYvJmz35073YInAAAAZ8rOztaGDRsUHx/vPhcQEKD4+HitXr26RG1kZmYqJydH1apVkyTt2bNHR44c8WgzKipKXbp0KXGbko1FinvvvVcLFy7U6NGjNXHiROXk5JSpncTERKWlpXkc/YYmmtxbAAAqLm/m7EEj7zG5twAAnD/yp3uYcUhSenq6x3H2CMZ8x48fV15enmrVquVxvlatWjpy5EiJ+n7PPfeodu3a7qJE/uvK06Zk88KZF198sTZs2KBjx46pU6dO2rJlS6lXCXc6nYqMjPQ4GDYKAIC5yNkAAHhBQIB5h6R69ep5jFhMSvLOLIPHH39cCxYs0IcffljitSZKyvYtSCMiIjRv3jwtWLBA8fHxysvLs7tLAACgEORsAADM5XA4TNnOO7+NAwcOKDIy0n3e6Sz8jwHVq1dXYGCgUlJSPM6npKQoOjq62FgzZszQ448/ri+++ELt2rVzn89/XUpKimJiYjza7NChQ4mfxWe2IB08eLDWr1+vRYsWqUGDBnZ3BwAAFIGcDQCAbzp7xGJRRYqQkBDFxsZqxYoV7nMul0srVqxQ165di2z/iSee0LRp07R06VJ16tTJ41qjRo0UHR3t0WZ6errWrFlTbJtns30kxZnq1q2runXr2t0NAABwDuRsAABM4PjfVI1yt1NKEyZM0PDhw9WpUyd17txZM2fOVEZGhnu3j2HDhqlOnTruKSPTp0/X5MmTNX/+fDVs2NC9zkRERIQiIiLkcDg0btw4PfLII2rWrJl7C9LatWsrISGhxP3yqSIFAAAAAAAVxZmLXpa3ndK64YYbdOzYMU2ePFlHjhxRhw4dtHTpUvfCl/v371fAGQWU2bNnKzs7W9dff71HO1OmTNFDDz0kSbr77ruVkZGh2267TSdPntQll1yipUuXlmrdCooUAAAAAADYwRFQplEQhbZTBmPHjtXYsWMLvbZq1SqPj/fu3Xvubjgcevjhh/Xwww+XqT+SD61JAQAAAAAAKjZGUgAAAAAAYIcAx+nDjHb8BEUKAAAAAABs4HAEyGHCdA8z2vAV/vMkAAAAAADgvMZICgAAAAAA7MB0jwL8skgx/7VNlsWKqlHNsliS1Kl7A8tibf7hiGWxgoKsG9TzwzfbLIvlys2zLNZXv2daFqtZm7qWxZLMWfC4pPZt2WlZrOr1YiyLlXo0zbJYs2dstSyWldpecqHdXfBLCz48blmslP0plsUyXC7LYp08mmpZrFN//GlZrMz0PyyLJUk5WdmWxfo2w7rPY5qF3x9vfVDyLQbL6+Qx6/JacEiwZbEyTv5uWSxJ2vDNbstiGYZhWSxrf3/UKderHQEBcgSYMN3DhDZ8hV8WKQAAAAAA8HkOx+nDjHb8hP+UWwAAAAAAwHmNkRQAAAAAANghwCGZMVWDNSkAAAAAAEC5MN2jAIoUAAAAAADYgIUzC/KfJwEAAAAAAOc1RlIAAAAAAGAHR8Dpw4x2/ARFCgAAAAAA7OBwmLPoJWtSAAAAAACA8nA4AuQwYRSEGW34Cv95EgAAAAAAcF7zqZEUGRkZevfdd7Vz507FxMRoyJAhuuCCC4p9TVZWlrKysjzOufKyFRAY4s2uAgBQYZUlX0uF5+y83CwFBjm91VUAAHxbgEnTPcxow0fYOpKidevWSk1NlSQdOHBAbdq00fjx47V8+XJNmTJFrVu31p49e4ptIykpSVFRUR7Hrs2vWtF9AAAqBDPytVR4zt7y3+e93X0AAHxX/sKZZhx+wtYn2bZtm3JzcyVJiYmJql27tvbt26e1a9dq3759ateune6///5i20hMTFRaWprH0aTtLVZ0HwCACsGMfJ3/2rNzdpvud3q7+wAA4DziM9M9Vq9erTlz5igqKkqSFBERoalTp2rw4MHFvs7pdMrp9BwmylQPAAC8o6z5Wio8ZwcGZXilnwAAnBccDnN25mB3D/M4/vpknjp1SjExMR7X6tSpo2PHjtnRLQAAcAbyNQAAXhAQcPowox0/YXuR4oorrlBQUJDS09O1fft2tWnTxn1t3759JVqICwAAeBf5GgAALzBrPQk/WpPC1iLFlClTPD6OiIjw+Pjjjz9Wjx49rOwSAAA4C/kaAABYxaeKFGd78sknLeoJAAAoCvkaAAAvYQvSAmyf7gEAAAAAQIXkcJg03YMiBQAAAAAAKA929yjAf1bXAAAAAAAA5zVGUgAAAAAAYAe2IC2AIgUAAAAAAHZgukcBFCkAAAAAALCDI8CkhTMZSeHT+g9uZ1msLVtOWhZLkpK/P2BZrBMHj1kWy0qu3DzLYtVsEG1ZLCv9uHq7pfEqVQ63LFbDds0si3V0f4plsX47ctyyWKPGd7Us1tYd2ZbFWrfyZ8tindbR4nj2iO1s3e/J7/607vsl8+TvlsUKi6hkWayqtapZFisny7qvlyRVviDKsliNW9W2LNb2rBzLYnXuat3P888/hVoWq3KUdbHSU9MsiyVJ9Zpb9zVz5bosi3V4f6BlsWA+vyxSAAAAAADg8xwmrUnBSAoAAAAAAFAurElRgP+UWwAAAAAAwHmNkRQAAAAAANiBhTMLoEgBAAAAAIAdmO5RAEUKAAAAAADsEGDSwplmtOEj/OdJAAAAAADAeY2RFAAAAAAA2MBwOGSYMFXDjDZ8BUUKAAAAAADs4HCYtHAmRQoAAAAAAFAe7O5RgK1PkpycrD179rg/fvPNN9W9e3fVq1dPl1xyiRYsWGBj7wAAgES+BgAA1rG1SDFy5Ejt2rVLkvTKK6/o9ttvV6dOnXT//ffr4osv1qhRo/Taa68V20ZWVpbS09M9jpzsLCu6DwBAhWBGvpYKz9m5OeRsAEDFlb8mhRmHv7B1useOHTvUrFkzSdJ//vMfPfvssxo1apT7+sUXX6xHH31UN998c5FtJCUlaerUqR7n+g6dor//4yGv9BkAgIrGjHwtFZ6zew+erKtufMj0PgMAcF5gukcBtj5JpUqVdPz4cUnSwYMH1blzZ4/rXbp08RheWpjExESlpaV5HL0HJXqtzwAAVDRm5Gup8Jx95UByNgAA+B9bixRXXXWVZs+eLUmKi4vT+++/73H93XffVdOmTYttw+l0KjIy0uMIDnF6rc8AAFQ0ZuRrqfCcHRRMzgYAVGAOh3mHn7B1usf06dPVvXt3xcXFqVOnTnrqqae0atUqtWrVStu3b9f333+vDz/80M4uAgBQ4ZGvAQDwkoCA04cZ7fgJW5+kdu3a+uGHH9S1a1ctXbpUhmFo7dq1+vzzz1W3bl3997//Vd++fe3sIgAAFR75GgAA72DhzIJsHUkhSVWqVNHjjz+uxx9/3O6uAACAIpCvAQCAFWwvUgAAAAAAUCGxu0cBFCkAAAAAALCB4QiQYUKBwYw2fAVFCgAAAAAA7GDWzhx+tCaF/5RbAAAAAADAeY2RFAAAAAAA2MCQSdM9/Gj8AUUKAAAAAADswHSPAvyySHHjlrssi/Vqs5mWxZKkQ3uPWRbLMFyWxbr4bzGWxfrq90zLYlmpe1xdy2I5Q6yLJUm96m+1LNbra2taFuupfxy2LNbIJytbFqtKeJ5lsY4fzbAsVqXK4ZbFqkhGVVtkWaw/OiVYFuvI7oOWxYpuUMuyWG061LAs1rcZf1oWS5Iat6ptWaxBl+VYFmtehnXvsW4JecOyWF9cfqNlsRpEnrAs1p7t1SyLJUn9L3NaFisrL9CyWF+vte65ys3hMGl3D/8pUvjPmBAAAAAAAHBeo0gBAAAAAIANDIfDtKMsZs2apYYNGyo0NFRdunTR2rVri7z3p59+0nXXXaeGDRvK4XBo5syZBe556KGH5HA4PI6WLVuWqk8UKQAAAAAAsIMjwLyjlBYuXKgJEyZoypQpSk5OVvv27dW7d28dPXq00PszMzPVuHFjPf7444qOji6y3QsvvFCHDx92H99++22p+kWRAgAAAACACubpp5/WqFGjNHLkSLVu3Vpz5sxRpUqV9NprrxV6/8UXX6wnn3xSgwcPltNZ9LofQUFBio6Odh/Vq1cvVb8oUgAAAAAAYANDDtOO0sjOztaGDRsUHx/vPhcQEKD4+HitXr26XM+0Y8cO1a5dW40bN9bQoUO1f//+Ur3eL3f3AAAAAADA1xmOABkm7O6R30Z6errHeafTWeioh+PHjysvL0+1annuEFWrVi1t27atzP3o0qWLXn/9dbVo0UKHDx/W1KlT1aNHD23ZskWVK5dstzlGUgAAAAAAYAeT16SoV6+eoqKi3EdSUpKlj3PVVVdp4MCBateunXr37q1PP/1UJ0+e1LvvvlviNhhJAQAAAACAHzhw4IAiIyPdHxe1dkT16tUVGBiolJQUj/MpKSnFLopZWlWqVFHz5s21c+fOEr+GkRQAAAAAANjA7C1IIyMjPY6iihQhISGKjY3VihUr3OdcLpdWrFihrl27mvZ8f/zxh3bt2qWYmJgSv4aRFAAAAAAA2MDsNSlKY8KECRo+fLg6deqkzp07a+bMmcrIyNDIkSMlScOGDVOdOnXcU0ays7P1888/u///4MGD2rhxoyIiItS0aVNJ0sSJE9WvXz81aNBAhw4d0pQpUxQYGKghQ4aUuF+mjKRIT0/X4sWLtXXr1lK97s4779Q333xjRhcAAEAJlCVnk68BAPASh8O8o5RuuOEGzZgxQ5MnT1aHDh20ceNGLV261L2Y5v79+3X48GH3/YcOHVLHjh3VsWNHHT58WDNmzFDHjh116623uu/59ddfNWTIELVo0UKDBg3SBRdcoO+//141atQocb/KNJJi0KBB6tmzp8aOHas///xTnTp10t69e2UYhhYsWKDrrruuRO3MmjVL//nPf9SkSRPdcsstGj58eKnnv2RlZSkrK8vzXG6unEEMEgEAwIycbUa+lgrP2XnZOXKGBJe6LQAAUH5jx47V2LFjC722atUqj48bNmwowzCKbW/BggXl7lOZRlJ8/fXX6tGjhyTpww8/lGEYOnnypJ577jk98sgjpWrr888/V9++fTVjxgzVr19fAwYM0CeffCKXy1Wi1yclJXmsXhoVFaWnv1xf6mcCAMAfmZWzy5uvpcJz9ow3F5X6mQAA8Bt/Tfco7yETpoz4ijI9SVpamqpVqyZJWrp0qa677jpVqlRJV199tXbs2FGqttq2bauZM2fq0KFDeuutt5SVlaWEhATVq1dP999//zlXAU1MTFRaWprHMeHyTmV5LAAA/I5ZObu8+VoqPGdPvOnaMj8bAADnO0MO0w5/UaYiRb169bR69WplZGRo6dKl6tWrlyTpt99+U2hoaJk6EhwcrEGDBmnp0qXavXu3Ro0apbffflstWrQo9nVOp7PgCqZM9QAAQJL5Obus+VoqImcz1QMAUIGZMYrCrMU3fUWZnmTcuHEaOnSo6tatq9q1a+vSSy+VdHpIadu2bcvdqfr16+uhhx7Snj17tHTp0nK3BwBAReXNnE2+BgAAZivTkIN//vOf6ty5sw4cOKArr7xSAQGnax2NGzcu1fzWBg0aKDAwsMjrDodDV155ZVm6CAAAZE7OJl8DAOAlDpVpZ45C2/ETZSpS7N69W506dVKnTp5rP1x99dWlamfPnj1lCQ8AAErIjJxNvgYAwDsMBcgo2wSHAu34izIVKZo2baq6desqLi5Ol156qeLi4tS0aVOz+wYAAMqJnA0AAM4nZSq3HDhwQElJSQoLC9MTTzyh5s2bq27duho6dKheeeUVs/sIAADKiJwNAIDvMhwO0w5/UaYiRZ06dTR06FC99NJL2r59u7Zv3674+Hi9++67uv32283uIwAAKCNyNgAAvovdPQoq03SPzMxMffvtt1q1apVWrVqlH374QS1bttTYsWPdq4YDAAD7kbMBAPBdhhwyTFj10ow2fEWZihRVqlRR1apVNXToUN17773q0aOHqlatanbfAABAOZGzAQDA+aRMRYq+ffvq22+/1YIFC3TkyBEdOXJEl156qZo3b252/wAAQDmQswEA8F1mTdXwp+keZXqSxYsX6/jx41q6dKm6du2qzz//XD169HDPewUAAL6BnA0AgO9i4cyCyjSSIl/btm2Vm5ur7OxsnTp1SsuWLdPChQv19ttvm9W/Mhmfcb9lsQ5/uNmyWJKUkZZuWawWF7eyLNaqZTsti9WsTV3LYv24ertlsZwh1j3X8s/2WRZLkmJvr2FZrF9+PmpZrIcPN7EsVsbJny2LtfdIoGWxgkOsi3Xy6AnLYnmDr+bsGXsHWBZr45o9lsVy5eVZFuvg7kOWxfojPdOyWGlHUy2LJUnbs3IsizUvI8ayWHu3/WpZrKfrWVf43PWddd8flSqHWRYr9bB1Xy9JWvhJuGWxDJdhWayjvx63LJZUvn8zsSZFQWUaSfH000+rf//+uuCCC9SlSxe98847at68uT744AMdO3bM7D4CAIAyImcDAIDzSZlGUrzzzjuKi4vTbbfdph49eigqKsrsfgEAABOQswEA8F2sSVFQmYoU69atM7sfAADAC8jZAAD4LqZ7FFTmNSlOnjypV199VVu3bpUktW7dWrfccgt/oQEAwMeQswEAwPmiTGNC1q9fryZNmuiZZ55RamqqUlNT9cwzz6hJkyZKTk42u48AAKCMyNkAAPguQwHuKR/lOsr2T3ufVKaRFOPHj1f//v318ssvKyjodBO5ubm69dZbNW7cOH399demdhIAAJQNORsAAN/FdI+CylSkWL9+vcebHUkKCgrS3XffrU6dOpnWOQAAUD7kbAAAfJfhcJi0cKb/FCnK9NmIjIzU/v37C5w/cOCAKleuXO5OAQAAc5CzAQDA+aRMRYobbrhBt9xyixYuXKgDBw7owIEDWrBggW655RYNHjzY7D4CAIAyImcDAOC78qd7mHH4izJN95gxY4YcDoeGDRum3NxcGYahkJAQ/fOf/9Sjjz5qdh8BAEAZkbMBAPBdp6d7mLAmRUWf7hESEqJnn31Wv/32mzZu3Kgff/xRqampqlOnjho1alSqtl544QUNGzZMCxYskCS9+eabat26tVq2bKn77rtPubm5xb4+KytL6enpHkdeblZZHgsAAL9jVs4ub76WCs/ZuTnkbABAxWUYDtMOf1GqIkVWVpYSExPVqVMnde/eXZ9//rnatm2r9evXq1mzZnr22Wc1fvz4Erf3yCOP6L777lNmZqbGjx+v6dOna/z48Ro6dKiGDx+uV155RdOmTSu2jaSkJEVFRXkcm755rjSPBQCA3zEzZ5uRr6XCc/Y3S6aX91EBAIAfKdV0j8mTJ+vFF19UfHy8vvvuOw0cOFAjR47U999/r6eeekoDBw5UYGBgidt7/fXX9frrr+vaa6/Vjz/+qNjYWM2bN09Dhw6VJLVs2VJ33323pk6dWmQbiYmJmjBhgse5O59MK81jAQDgd8zM2Wbka6nwnD1jUcnfNwAA4H8CZJRtgkOBdvxFqYoU7733nt544w31799fW7ZsUbt27ZSbm6sff/xRjjLMgTl06JB7+7P27dsrICBAHTp0cF+/6KKLdOjQoWLbcDqdcjqdHucCg06Vui8AAPgTM3O2GflaKjxnBwWfe5oIAAD+yqxFL/1p4cxSlVt+/fVXxcbGSpLatGkjp9Op8ePHl6lAIUnR0dH6+eefJUk7duxQXl6e+2NJ+umnn1SzZs0ytQ0AQEVmZs4mXwMA4B3s7lFQqUZS5OXlKSQk5H8vDgpSREREmYMPHTpUw4YN04ABA7RixQrdfffdmjhxok6cOCGHw6FHH31U119/fZnbBwCgojIzZ5OvAQCAVUpVpDAMQyNGjHAP1Tx16pTuuOMOhYeHe9y3aNGiErU3depUhYWFafXq1Ro1apTuvfdetW/fXnfffbcyMzPVr1+/Ei3EBQAAPJmZs8nXAAB4B9M9CipVkWL48OEeH//jH/8oV/CAgADdd999HucGDx6swYMHl6tdAAAqOjNzNvkaAADvoEhRUKmKFHPnzvVWPwAAgInI2QAA4HxUqiIFAAAAAAAwh2E4ZBgmjKQwoQ1fQZECAAAAAAAbMN2jIIoUAAAAAADYgCJFQQF2dwAAAAAAAEBiJAUAAAAAALZgJEVBflmk+E/rNy2L9Vyb8ZbFkqQDB/6wLNauTfssi/W3K1pZFsth4fihSpXDLYvVq/5Wy2LF3l7DsliSdKh1d8ti3fFjsmWx2p5abVmsdzvEWxare8NDlsUaWmeHZbEm/XmhZbEqkitmdLEsVpsX11kW6/kZJyyL1aF7C8tixXexLom+9UGoZbEkqXPXaMti3RLyhmWxnq431LJY7f/R2rJYo3607v1+5a3/tSzWXaeGn/smE03vs8myWDkhlSyL9f7+zpbFKi9DJi2cSZECAAAAAACUh0sOuUwoMJjRhq9gTQoAAAAAAOATGEkBAAAAAIANWJOiIIoUAAAAAADYwDBMWpPChDZ8BdM9AAAAAACAT2AkBQAAAAAANjBkzlQNo/xd8RkUKQAAAAAAsAHTPQqiSAEAAAAAgA1YOLMg1qQAAAAAAAA+wdaRFIcPH9bs2bP17bff6vDhwwoICFDjxo2VkJCgESNGKDAw0M7uAQCAv5CzAQAwH9M9CrJtJMX69evVqlUrffrpp8rJydGOHTsUGxur8PBwTZw4UT179tTvv/9+znaysrKUnp7ucWTl5FrwBAAAVAzezNnZLpcFTwAAgG8yJLlMOPxp4UzbihTjxo3T+PHjtX79en3zzTd6/fXX9csvv2jBggXavXu3MjMz9cADD5yznaSkJEVFRXkcT364woInAACgYvBmzn4z5YgFTwAAgG/KH0lhxuEvbCtSJCcn66abbnJ/fOONNyo5OVkpKSmqWrWqnnjiCb3//vvnbCcxMVFpaWkex6RrrvBm1wEAqFC8mbNvqhXtza4DAIDzjG1rUtSsWVOHDx9W48aNJUkpKSnKzc1VZGSkJKlZs2ZKTU09ZztOp1NOp9Pj3KlgNi0BAMAs3szZIQGs4Q0AqLjY3aMg294ZJCQk6I477tDSpUu1cuVKDR06VHFxcQoLC5Mkbd++XXXq1LGrewAA4C/kbAAAvIPpHgXZNuTgkUce0eHDh9WvXz/l5eWpa9eueuutt9zXHQ6HkpKS7OoeAAD4CzkbAADvYCRFQbYVKSIiIrRw4UKdOnVKubm5ioiI8Ljeq1cvm3oGAADORM4GAABWsX3xhtDQULu7AAAASoCcDQCAuVzG6cOMdvwFq1UBAAAAAGCD/OkeZhxlMWvWLDVs2FChoaHq0qWL1q5dW+S9P/30k6677jo1bNhQDodDM2fOLHebhaFIAQAAAABABbNw4UJNmDBBU6ZMUXJystq3b6/evXvr6NGjhd6fmZmpxo0b6/HHH1d0dOFbiJe2zcJQpAAAAAAAwAZ27u7x9NNPa9SoURo5cqRat26tOXPmqFKlSnrttdcKvf/iiy/Wk08+qcGDBxfYUrysbRaGIgUAAAAAADYwDPOO0sjOztaGDRsUHx/vPhcQEKD4+HitXr26TM9iVpu2L5wJAAAAAEBF5JJDLhO2D81vIz093eO80+ksdNTD8ePHlZeXp1q1anmcr1WrlrZt21amPpjVJiMpAAAAAADwA/Xq1VNUVJT7SEpKsrtLpeaXIymS29xmWaxVT/5kWSxJql6numWxQiPCLIu1fUuKZbH2bdlpWayG7ZpZFuv1tTUti/XLzyVf+MYMd/yYbFmsrzdbt8Xio59Z9zW7+LJsy2Kl1YmwLNbuvO6Wxdqz2brvw9Os+31vp4YLX7cs1sdfWfdzkJeTY1msX/ekWhbru0rW/d46eSzNsliS9PNP1v3+/+LyGy2Ltes7674/Rv34pmWxPjvW2bJYdZq3syzWsa9+tSyWJH2WEWdZrJy08o8WKKktW05aFkt9qpTr5WVdT6KwdiTpwIEDioyMdJ8vau2I6tWrKzAwUCkpnv8OS0lJKXJRzHMxq01GUgAAAAAAYAOz16SIjIz0OIoqUoSEhCg2NlYrVqxwn3O5XFqxYoW6du1apmcxq02/HEkBAAAAAICvM+SQYcKaFGVpY8KECRo+fLg6deqkzp07a+bMmcrIyNDIkSMlScOGDVOdOnXcU0ays7P1888/u///4MGD2rhxoyIiItS0adMStVkSFCkAAAAAAKhgbrjhBh07dkyTJ0/WkSNH1KFDBy1dutS98OX+/fsVEPC/yReHDh1Sx44d3R/PmDFDM2bMUFxcnFatWlWiNkuCIgUAAAAAADZwGacPM9opi7Fjx2rs2LGFXssvPORr2LChjBLsdVpcmyVBkQIAAAAAADuYtHCmzGjDR1CkAAAAAADABmcuelnedvwFu3sAAAAAAACfYPtIiuzsbC1evFirV6/WkSNHJEnR0dHq1q2bBgwYoJCQEJt7CAAAJHI2AABmc8khlwm7e5jRhq+wdSTFzp071apVKw0fPlw//PCDXC6XXC6XfvjhBw0bNkwXXnihdu7caWcXAQCAyNkAAHhD/nQPMw5/YetIitGjR6tt27b64YcfFBkZ6XEtPT1dw4YN05gxY7Rs2TKbeggAACRyNgAAsIatRYr//ve/Wrt2bYE3O5IUGRmpadOmqUuXLjb0DAAAnImcDQCA+QyTdvcwZYcQH2FrkaJKlSrau3ev2rRpU+j1vXv3qkqVKsW2kZWVpaysLI9z2dnZCglxmtVNAAAqPG/l7KzsbDlZywIAUEG5jNOHGe34C1vXpLj11ls1bNgwPfPMM9q0aZNSUlKUkpKiTZs26ZlnntGIESN02223FdtGUlKSoqKiPI43X3rKoicAAKBi8FbOfuHFVyx6AgAAfA9rUhRk60iKhx9+WOHh4XryySf173//Ww7H6SEqhmEoOjpa99xzj+6+++5i20hMTNSECRM8ziXvyfZanwEAqIi8lbOP79/htT4DAIDzj+1bkN5zzz265557tGfPHo/tzBo1alSi1zudTjmdnlM7QkJ+N72fAABUdN7I2b8z1QMAUIEZcsgwYftQM9rwFbZO9zhTo0aN1LVrV3Xt2tX9ZufAgQO6+eabbe4ZAAA4EzkbAABzuPS/dSnKddj9ICbymSJFYVJTUzVv3jy7uwEAAM6BnA0AQOmxJkVBtk73WLJkSbHXd+/ebVFPAABAccjZAADACrYWKRISEuRwOGQUU/bJX5gLAADYh5wNAID5zBoF4U8jKWyd7hETE6NFixbJ5XIVeiQnJ9vZPQAA8BdyNgAA5nMZDtMOf2FrkSI2NlYbNmwo8vq5/mIDAACsQc4GAABWsHW6x6RJk5SRkVHk9aZNm2rlypUW9ggAABSGnA0AgPmY7lGQrUWKHj16FHs9PDxccXFxFvUGAAAUhZwNAID5KFIUZGuRAgAAAACAisowJBdFCg9+WaS4aNdblsUaMHi0ZbEk6d3X1loWq0PPCy2LtfvnQ5bFql4vxrJYR/enWBbrqX8ctizWw4ebWBZLktqeWm1ZrEc/q2lZrAFD2lkWa+XyfZbFat2svmWxcnKtWySq/9CLLYtVkVywe41lsapVsy6vORzWLfsVFuG0LNYF1ax76xgcEmxZLEmqHBVqWawGkScsi1WpcphlsSpv/a9lseo0ty6HNqhk3Xus0ErWfR9KUr2qmZbFysoLtCxWVFXrvu9hPr8sUgAAAAAA4OsMwyHDhJ05zGjDV1CkAAAAAADABqxJURBFCgAAAAAAbOAyaU0KM9rwFdZNmAQAAAAAACgGIykAAAAAALAB0z0KokgBAAAAAIANKFIURJECAAAAAAAbsCZFQT69JkVKSooefvhhu7sBAADOgZwNAADM4NNFiiNHjmjq1Kl2dwMAAJwDORsAgNLLn+5hxuEvbJ3usWnTpmKvb9++3aKeAACA4pCzAQAwn8t1+jCjHX9ha5GiQ4cOcjgcMgop++SfdzgcNvQMAACciZwNAACsYGuRolq1anriiSd0xRVXFHr9p59+Ur9+/YptIysrS1lZWR7njJwcOYODTesnAAAVnddydnaOnCHkbABAxcTuHgXZWqSIjY3VoUOH1KBBg0Kvnzx5stC/2JwpKSmpwBzY+4f01QM3/t20fgIAUNF5LWcP7acH/tHftH4CAHA+oUhRkK1FijvuuEMZGRlFXq9fv77mzp1bbBuJiYmaMGGCxzljxetmdA8AAPzFazl71dum9A8AgPORSyZtQVr+JnyGrUWKa665ptjrVatW1fDhw4u9x+l0yul0epw7xVQPAABM5bWczVQPAABwBp/egvTAgQO6+eab7e4GAAA4B3I2AAClZxiGaYe/8OkiRWpqqubNm2d3NwAAwDmQswEAKL38NSnMOPyFrdM9lixZUuz13bt3W9QTAABQHHI2AADmM1ySy4QFJQw/WpTC1iJFQkJCkXuu52PPdQAA7EfOBgAAVrB1ukdMTIwWLVokl8tV6JGcnGxn9wAAwF/I2QAAmI/pHgXZWqSIjY3Vhg0birx+rr/YAAAAa5CzAQAwn8sw7/AXtk73mDRpUrF7rjdt2lQrV660sEcAAKAw5GwAAGAFW4sUPXr0KPZ6eHi44uLiLOoNAAAoCjkbAADzmTVVw58GM9papAAAAAAAoKIyXIYME+ZqmNGGr6BIAQAAAACADcxaT8KPahRyGH64ytWzH1v3SN9/c8CyWJJUqXKYZbFCQoMti2Vl5S/1aJplsVL2HLIsVniVypbFyjj5u2WxJOkf/+xmWawDB7Mti7V982HLYgUGBVoWKzcn17JYWZlZlsUKDQ+1LJYkLZzRwNJ4dhn12AnLYh3cad3v5PRjqZbFcoZb994gNKKSZbGszjUhYdb9jFetVc2yWKmHj1sWq3HbRpbFOnbIup+x0ErWfW8c2mntvy2q16llWSyX4bIs1h+/Wff74/M3O5bpdenp6YqKitLUN35TaKXIcvfjVGa6pgyrqrS0NEVGlr89OzGSAgAAAAAAG7AmRUEUKQAAAAAAsIHLZchlwqhyM9rwFRQpAAAAAACwASMpCgqwuwMAAAAAAAASIykAAAAAALAFIykKokgBAAAAAIANXIYhlwkVBjPa8BU+Md3j119/1R9//FHgfE5Ojr7++msbegQAAApDzgYAwDyGy7zDX9hapDh8+LA6d+6sBg0aqEqVKho2bJjHG5/U1FRddtllNvYQAABI5GwAAGANW4sU9957rwICArRmzRotXbpUP//8sy677DL99ttv7nsMPxq2AgDA+YqcDQCA+QwZMgwTDvlPDra1SPHFF1/oueeeU6dOnRQfH6///ve/iomJ0eWXX67U1FRJksPhsLOLAABA5GwAALzBcEkuEw6me5gkLS1NVatWdX/sdDq1aNEiNWzYUJdddpmOHj16zjaysrKUnp7uceTmZHmz2wAAVDjeytl5ueRsAADsMmvWLDVs2FChoaHq0qWL1q5dW+z97733nlq2bKnQ0FC1bdtWn376qcf1ESNGyOFweBx9+vQpVZ9sLVI0btxYmzZt8jgXFBSk9957T40bN9bf//73c7aRlJSkqKgoj2P5e0ne6jIAABWSt3L2xq9meqnHAAD4PlOmevx1lNbChQs1YcIETZkyRcnJyWrfvr169+5d5B8evvvuOw0ZMkS33HKLfvjhByUkJCghIUFbtmzxuK9Pnz46fPiw+3jnnXdK1S9bixRXXXWVXnrppQLn89/0dOjQ4Zyf7MTERKWlpXkcVw5M9FaXAQCokLyVszvEjfNSjwEA8H0uw7yjtJ5++mmNGjVKI0eOVOvWrTVnzhxVqlRJr732WqH3P/vss+rTp48mTZqkVq1aadq0abrooov0wgsveNzndDoVHR3tPs4ciVkSQaV/FPM8+uijyszMLPRaUFCQPvjgAx08eLDYNpxOp5xOp+drg/1n0RAAAHyBt3J2YFCOaX0EAOB8Y7gMGWWpMBTSTmlkZ2drw4YNSkz83x/4AwICFB8fr9WrVxf6mtWrV2vChAke53r37q3Fixd7nFu1apVq1qypqlWr6vLLL9cjjzyiCy64oMR9s3UkRVBQkCIjI4u8fvjwYU2dOtXCHgEAgMKQswEA8H1nr/2UlVX42k/Hjx9XXl6eatWq5XG+Vq1aOnLkSKGvOXLkyDnv79Onj9544w2tWLFC06dP11dffaWrrrpKeXl5JX4GW4sU55Kamqp58+bZ3Q0AAHAO5GwAAErPMMw7JKlevXoeaz8lJVm7XuPgwYPVv39/tW3bVgkJCfrkk0+0bt06rVq1qsRt2DrdY8mSJcVe3717t0U9AQAAxSFnAwBgPpfLkMuE6R75bRw4cMBj5OPZ0yzzVa9eXYGBgUpJSfE4n5KSoujo6EJfEx0dXar7pdMLb1evXl07d+7UFVdcUaJnsbVIkZCQIIfDUexCW+y5DgCA/cjZAACYr6w7cxTWjiRFRkYWOz0zX0hIiGJjY7VixQolJCRIklwul1asWKGxY8cW+pquXbtqxYoVGjdunPvc8uXL1bVr1yLj/Prrrzpx4oRiYmJK/Cy2TveIiYnRokWL5HK5Cj2Sk5Pt7B4AAPgLORsAAP8yYcIEvfzyy5o3b562bt2q0aNHKyMjQyNHjpQkDRs2zGNhzbvuuktLly7VU089pW3btumhhx7S+vXr3UWNP/74Q5MmTdL333+vvXv3asWKFRowYICaNm2q3r17l7hfthYpYmNjtWHDhiKvn+svNgAAwBrkbAAAzGe4zDtK64YbbtCMGTM0efJkdejQQRs3btTSpUvdi2Pu379fhw8fdt/frVs3zZ8/Xy+99JLat2+v999/X4sXL1abNm0kSYGBgdq0aZP69++v5s2b65ZbblFsbKy++eabIqedFMbW6R6TJk1SRkZGkdebNm2qlStXWtgjAABQGHI2AADmcxmGXCYU+cvaxtixY4uc3lHYYpcDBw7UwIEDC70/LCxMy5YtK1M/zmRrkaJHjx7FXg8PD1dcXJxFvQEAAEUhZwMAYD6z16TwBz69BSkAAAAAAKg4bB1JAQAAAABARWX2FqT+wC+LFHEtj1sWa+VnpyyLJUlVapx7Oxmz9IqrbFmsrFzrBvXMnrHVslijxhe9HY/ZqoTnWRZr75FAy2JJUveGhyyLlVYnwrJYrZvVtyzWog/2WRbrwo51LIvVrW0ZVokqoxdfO2hZrIrksQE7LYs1c00Hy2J98/E6y2LFNKlrWawWbWpaFmvDN7stiyVJ9ZpHWxar/2UlX0CuvBZ+Em5ZrOl9NlkW67MM66aX1auaaVmsmS9mWxZLkgbf2NCyWDm51m1T/d263y2LVV6Gcfowox1/wXQPAAAAAADgE/xyJAUAAAAAAL7OMAwZJkzV8KeFMylSAAAAAABgA8OkLUgpUgAAAAAAgHIxXCaNpPCjhTNZkwIAAAAAAPgERlIAAAAAAGADRlIUZHuR4sSJE9q0aZPat2+vatWq6fjx43r11VeVlZWlgQMHqlWrVnZ3EQAAiJwNAIDZXMbpw4x2/IWtRYq1a9eqV69eSk9PV5UqVbR8+XINHDhQQUFBcrlcevzxx/Xtt9/qoosusrObAABUeORsAADMx0iKgmxdk+L+++/XwIEDlZaWpvvuu08JCQm64oor9Msvv2jnzp0aPHiwpk2bZmcXAQCAyNkAAMAathYpNmzYoAkTJqhy5cq66667dOjQIY0aNcp9fezYsVq3bp2NPQQAABI5GwAAbzAMw7TDX9g63SM7O1thYWGSpODgYFWqVEnVq1d3X69evbpOnDhhV/cAAMBfyNkAAJjP5ZJcJkzVcLlM6IyPsLVIUa9ePe3evVsNGzaUJC1YsEAxMTHu64cPH/Z4A1SYrKwsZWVleZzLzs5SSIjT9P4CAFBReStnZ2VnyxkSYnp/AQDA+cnW6R6DBw/W0aNH3R9fffXV7r/SSNKSJUvUuXPnYttISkpSVFSUx/HanGe91mcAACoib+XsZ1+e57U+AwDg65juUZCtIymmTJlS7PX7779fgYGBxd6TmJioCRMmeJzbdiC93H0DAAD/462cnb7rx3L3DQCA8xW7exRk60iKczlx4oRGjx5d7D1Op1ORkZEeB1M9AACwVllzNlM9AAAVWX6RwozDX/h0kSI1NVXz5jEMFAAAX0fOBgAAZrB1useSJUuKvb57926LegIAAIpDzgYAwHwuGXKZsJ6ES/4zksLWIkVCQoIcDkexi3w4HA4LewQAAApDzgYAwHysSVGQrdM9YmJitGjRIrlcrkKP5ORkO7sHAAD+Qs4GAMB87O5RkK1FitjYWG3YsKHI6+f6iw0AALAGORsAAFjB1ukekyZNUkZGRpHXmzZtqpUrV1rYIwAAUBhyNgAA5jNchlxM9/Bga5GiR48exV4PDw9XXFycRb0BAABFIWcDAGA+1qQoyNYiBQAAAAAAFZVZ60n405RLW9ekAAAAAAAAyOeXIymCHbmWxbrt1kaWxZKkZd+csizWa6/+Ylms3gNaWhbLSlt3ZFsW6/jRoueKmy04JNCyWJI0tM4Oy2LtzutuWaycXOu2a8zKzLIsVre2LstiJe8ItixWvWY1LYtVkWQHV7IsVl6e//yV6UxWDvHNzbEultV/FXTlWve7KyvPujxq5fdHToh1P885aRbmUAu/Xi7Duu9DyeL3IjnWxbLy57m8DJdLhqv8/TWjDV/hl0UKAAAAAAB8ncukhTPNaMNXMN0DAAAAAAD4BEZSAAAAAABgAxbOLIgiBQAAAAAANmAL0oIoUgAAAAAAYAOKFAWxJgUAAAAAAPAJjKQAAAAAAMAGLrlM2XrWJf/ZgtQnR1I0btxYO3bssLsbAADgHMjZAACUneH635SP8h12P4l5bB1J8dxzzxV6fv/+/Zo7d66io6MlSf/617+s7BYAADgLORsAAPOxJkVBthYpxo0bpzp16igoyLMbLpdLb7zxhoKDg+VwOHjDAwCAzcjZAADACrYWKW677TatWbNG8+fPV6tWrdzng4OD9fnnn6t169Y29g4AAOQjZwMAYD7DMGQYJoykMKENX2HrmhRz5szR5MmT1bt3b73wwgtlaiMrK0vp6ekeR3ZWlsk9BQCgYvNWzs7Kzja5pwAAnD9cLpdph7+wfeHMa665RqtXr9aHH36oq666SkeOHCnV65OSkhQVFeVxvPzi817qLQAAFZc3cvYLL77ipd4CAOD7zFk005x1LXyF7UUKSapTp46++OIL9ezZUx07dizVUJXExESlpaV5HKNuv9OLvQUAoOIyO2ePvf1WL/YWAACcb2xdk+JMDodDiYmJ6tWrl7799lvFxMSU6HVOp1NOp9PjXIgzwxtdBAAAMjdn/x4S4o0uAgBwXjAMlwwT9g81ow1f4RMjKc4UGxuru+66S1WrVtWBAwd08803290lAABQCHI2AADlw3SPgnyuSHGm1NRUzZs3z+5uAACAcyBnAwAAM9g63WPJkiXFXt+9e7dFPQEAAMUhZwMA4AVmjYLwo5EUthYpEhIS5HA4il10y+FwWNgjAABQGHI2AADmcxkuuUxYT8KMNnyFrdM9YmJitGjRoiL3eU1OTrazewAA4C/kbAAAzMeaFAXZWqSIjY3Vhg0birx+rr/YAAAAa5CzAQCAFWyd7jFp0iRlZBS9XWjTpk21cuVKC3sEAAAKQ84GAMB8huGS4WIL0jPZWqTo0aNHsdfDw8MVFxdnUW8AAEBRyNkAAJjPrKka/jTdw9YiBQAAAAAAFZVhuEwZBcFICh/3wMw/LIvVNyHGsliSFBCYZVksZ6jTsljLPtpmWay2l1xoWax1K3+2LFalyuGWxTp59IRlsSRp0p/Wfc32bLZu8b/+Qy+2LFZoeKhlsV587aBlseo1q2lZrL3bDlsW67RmFsezx6IdbSyLtWf7fstiWfkXrZPHfrMs1k7LIkmZ6da9n5Okw/sDLYv19Vrr3mMd/fW4ZbHe39/Zslhbtpy0LFZU1TDLYv3x2++WxZKk79ZZF8+Va90/og/vt+77XqpiYayKwS+LFAAAAAAA+DqXS3KZUNg2YVkLn0GRAgAAAAAAGxgukxbO9KMqha1bkAIAAAAAAORjJAUAAAAAADZgd4+CGEkBAAAAAIAN8nf3MOMoi1mzZqlhw4YKDQ1Vly5dtHbt2mLvf++999SyZUuFhoaqbdu2+vTTT896HkOTJ09WTEyMwsLCFB8frx07dpSqTxQpAAAAAACwQf5ICjOO0lq4cKEmTJigKVOmKDk5We3bt1fv3r119OjRQu//7rvvNGTIEN1yyy364YcflJCQoISEBG3ZssV9zxNPPKHnnntOc+bM0Zo1axQeHq7evXvr1KlTJe4XRQoAAAAAACqYp59+WqNGjdLIkSPVunVrzZkzR5UqVdJrr71W6P3PPvus+vTpo0mTJqlVq1aaNm2aLrroIr3wwguSTo+imDlzph544AENGDBA7dq10xtvvKFDhw5p8eLFJe6XT61JYRiGVq1apZ07dyomJka9e/dWcHCw3d0CAABnIWcDAFB+udm/m7IzR15uhiQpPT3d47zT6ZTT6Sxwf3Z2tjZs2KDExET3uYCAAMXHx2v16tWFxli9erUmTJjgca53797uAsSePXt05MgRxcfHu69HRUWpS5cuWr16tQYPHlyiZ7G1SNG3b1+98847ioqKUmpqqvr27au1a9eqevXqOnHihJo3b66vv/5aNWrUsLObAABUeORsAADMExISoujoaK1fMci0NiMiIlSvXj2Pc1OmTNFDDz1U4N7jx48rLy9PtWrV8jhfq1Ytbdu2rdD2jxw5Uuj9R44ccV/PP1fUPSVha5Fi6dKlysrKkiQ98MAD+v3337Vr1y41atRIv/76qxISEjR58mTNnj3bzm4CAFDhkbMBADBPaGio9uzZo+zsbNPaNAxDDofD41xhoyh8nc9M9/jyyy/1xBNPqFGjRpKkunXravr06Ro1apTNPQMAAGciZwMAUH6hoaEKDQ21JXb16tUVGBiolJQUj/MpKSmKjo4u9DXR0dHF3p//35SUFMXExHjc06FDhxL3zfaFM/MrPb/99puaNGnica1p06Y6dOhQsa/PyspSenq6x5GXZ141CgAAnOaNnJ2Tk+W1/gIAgMKFhIQoNjZWK1ascJ9zuVxasWKFunbtWuhrunbt6nG/JC1fvtx9f6NGjRQdHe1xT3p6utasWVNkm4WxvUgxYsQIXXvttcrJydGePXs8rh05ckRVqlQp9vVJSUmKioryOH7ZMMeLPQYAoGLyRs5e/m6SF3sMAACKMmHCBL388suaN2+etm7dqtGjRysjI0MjR46UJA0bNsxjYc277rpLS5cu1VNPPaVt27bpoYce0vr16zV27FhJp/+YMW7cOD3yyCNasmSJNm/erGHDhql27dpKSEgocb9sne4xfPhw9/8PGDBAmZmZHtc/+OCDcw4LSUxMLLDC6D/uOWBaHwEAgPdy9itfhpjWRwAAUHI33HCDjh07psmTJ+vIkSPq0KGDli5d6l74cv/+/QoI+N+4hm7dumn+/Pl64IEHdN9996lZs2ZavHix2rRp477n7rvvVkZGhm677TadPHlSl1xyiZYuXVqqaS22Finmzp1b7PUpU6YoMDCw2HsK21IlMJA3PAAAmMlbOTs42Ch33wAAQNmMHTvWPRLibKtWrSpwbuDAgRo4cGCR7TkcDj388MN6+OGHy9wn26d7FCc1NVX//Oc/7e4GAAA4B3I2AAAwg88XKebNm2d3NwAAwDmQswEAgBlsne6xZMmSYq/v3r3bop4AAIDikLMBAIAVbC1SJCQkyOFwyDCKno+av90ZAACwDzkbAABYwdbpHjExMVq0aJFcLlehR3Jysp3dAwAAfyFnAwAAK9hapIiNjdWGDRuKvH6uv9gAAABrkLMBAIAVbJ3uMWnSJGVkZBR5vWnTplq5cqWFPQIAAIUhZwMAACvYWqTo0aNHsdfDw8MVFxdnUW8AAEBRyNkAAMAKPr0FKQAAAAAAqDgoUgAAAAAAAN9gwDAMwzh16pQxZcoU49SpU8Qilq3xiEUsX4hldTxioaT8+evnr89GLGL5SjxiEcsXYuHcHIbBUtySlJ6erqioKKWlpSkyMpJYxLItHrGI5QuxrI5HLJSUP3/9/PXZiEUsX4lHLGL5QiycG9M9AAAAAACAT6BIAQAAAAAAfAJFCgAAAAAA4BMoUvzF6XRqypQpcjqdxCKWrfGIRSxfiGV1PGKhpPz56+evz0YsYvlKPGIRyxdi4dxYOBMAAAAAAPgERlIAAAAAAACfQJECAAAAAAD4BIoUAAAAAADAJ1CkkDRr1iw1bNhQoaGh6tKli9auXeuVOF9//bX69eun2rVry+FwaPHixV6JI0lJSUm6+OKLVblyZdWsWVMJCQnavn27V2LNnj1b7dq1U2RkpCIjI9W1a1d99tlnXol1tscff1wOh0Pjxo0zve2HHnpIDofD42jZsqXpcfIdPHhQ//jHP3TBBRcoLCxMbdu21fr1670Sq2HDhgWezeFwaMyYMabHysvL04MPPqhGjRopLCxMTZo00bRp0+St5XB+//13jRs3Tg0aNFBYWJi6deumdevWlbvdc/38GoahyZMnKyYmRmFhYYqPj9eOHTu8EmvRokXq1auXLrjgAjkcDm3cuLFsD3WOWDk5ObrnnnvUtm1bhYeHq3bt2ho2bJgOHTrkled66KGH1LJlS4WHh6tq1aqKj4/XmjVrvPJsZ7vjjjvkcDg0c+ZMr8QaMWJEgZ+3Pn36lClWRedvOZt8bQ5/zdnk69KzMl+XJB45u/yxzkS+rhgqfJFi4cKFmjBhgqZMmaLk5GS1b99evXv31tGjR02PlZGRofbt22vWrFmmt322r776SmPGjNH333+v5cuXKycnR7169VJGRobpserWravHH39cGzZs0Pr163X55ZdrwIAB+umnn0yPdaZ169bpxRdfVLt27bwW48ILL9Thw4fdx7fffuuVOL/99pu6d++u4OBgffbZZ/r555/11FNPqWrVql6Jt27dOo/nWr58uSRp4MCBpseaPn26Zs+erRdeeEFbt27V9OnT9cQTT+j55583PZYk3XrrrVq+fLnefPNNbd68Wb169VJ8fLwOHjxYrnbP9fP7xBNP6LnnntOcOXO0Zs0ahYeHq3fv3jp16pTpsTIyMnTJJZdo+vTppW67NLEyMzOVnJysBx98UMnJyVq0aJG2b9+u/v37mx5Lkpo3b64XXnhBmzdv1rfffquGDRuqV69eOnbsmFfi5fvwww/1/fffq3bt2mWKU9JYffr08fi5e+edd8ocr6Lyx5xNvjaPP+Zs8nXpWZmvSxKPnF3+WPnI1xWIUcF17tzZGDNmjPvjvLw8o3bt2kZSUpJX40oyPvzwQ6/GONPRo0cNScZXX31lSbyqVasar7zyitfa//33341mzZoZy5cvN+Li4oy77rrL9BhTpkwx2rdvb3q7hbnnnnuMSy65xJJYhbnrrruMJk2aGC6Xy/S2r776auPmm2/2OHfttdcaQ4cONT1WZmamERgYaHzyySce5y+66CLj/vvvNy3O2T+/LpfLiI6ONp588kn3uZMnTxpOp9N45513TI11pj179hiSjB9++KFcMUoSK9/atWsNSca+ffu8HistLc2QZHzxxRflilVcvF9//dWoU6eOsWXLFqNBgwbGM88845VYw4cPNwYMGFDutiu6ipCzyddlU1FyNvm6dKzM14XFOxM5u3yxyNcVS4UeSZGdna0NGzYoPj7efS4gIEDx8fFavXq1jT0zX1pamiSpWrVqXo2Tl5enBQsWKCMjQ127dvVanDFjxujqq6/2+Np5w44dO1S7dm01btxYQ4cO1f79+70SZ8mSJerUqZMGDhyomjVrqmPHjnr55Ze9Euts2dnZeuutt3TzzTfL4XCY3n63bt20YsUK/fLLL5KkH3/8Ud9++62uuuoq02Pl5uYqLy9PoaGhHufDwsK89hc1SdqzZ4+OHDni8f0YFRWlLl26+OXvEofDoSpVqng1TnZ2tl566SVFRUWpffv2Xonhcrl00003adKkSbrwwgu9EuNMq1atUs2aNdWiRQuNHj1aJ06c8HpMf1JRcjb5uuz8PWeTr8uvIuVryX9yNvm64gmyuwN2On78uPLy8lSrVi2P87Vq1dK2bdts6pX5XC6Xxo0bp+7du6tNmzZeibF582Z17dpVp06dUkREhD788EO1bt3aK7EWLFig5ORkU+YtFqdLly56/fXX1aJFCx0+fFhTp05Vjx49tGXLFlWuXNnUWLt379bs2bM1YcIE3XfffVq3bp3+9a9/KSQkRMOHDzc11tkWL16skydPasSIEV5p/95771V6erpatmypwMBA5eXl6dFHH9XQoUNNj1W5cmV17dpV06ZNU6tWrVSrVi298847Wr16tZo2bWp6vHxHjhyRpEJ/l+Rf8wenTp3SPffcoyFDhigyMtIrMT755BMNHjxYmZmZiomJ0fLly1W9enWvxJo+fbqCgoL0r3/9yyvtn6lPnz669tpr1ahRI+3atUv33XefrrrqKq1evVqBgYFej+8PKkLOJl+XXUXI2eTr8qso+Vryr5xNvq54KnSRoqIYM2aMtmzZ4tXKdIsWLbRx40alpaXp/fff1/Dhw/XVV1+Z/sbnwIEDuuuuu7R8+fIC1XeznfmXg3bt2qlLly5q0KCB3n33Xd1yyy2mxnK5XOrUqZMee+wxSVLHjh21ZcsWzZkzx+tFildffVVXXXVVueb3Fefdd9/V22+/rfnz5+vCCy/Uxo0bNW7cONWuXdsrz/bmm2/q5ptvVp06dRQYGKiLLrpIQ4YM0YYNG0yPVZHk5ORo0KBBMgxDs2fP9lqcyy67TBs3btTx48f18ssva9CgQVqzZo1q1qxpapwNGzbo2WefVXJyslf+Inm2wYMHu/+/bdu2ateunZo0aaJVq1bpiiuu8Hp8nB/I12VXEXI2+Rol5U85m3xdMVXo6R7Vq1dXYGCgUlJSPM6npKQoOjrapl6Za+zYsfrkk0+0cuVK1a1b12txQkJC1LRpU8XGxiopKUnt27fXs88+a3qcDRs26OjRo7rooosUFBSkoKAgffXVV3ruuecUFBSkvLw802Pmq1Klipo3b66dO3ea3nZMTEyBN4itWrXy2lDVfPv27dMXX3yhW2+91WsxJk2apHvvvVeDBw9W27ZtddNNN2n8+PFKSkrySrwmTZroq6++0h9//KEDBw5o7dq1ysnJUePGjb0ST5L794W//i7Jf7Ozb98+LV++3Gt/kZGk8PBwNW3aVH/729/06quvKigoSK+++qrpcb755hsdPXpU9evXd/8u2bdvn/7973+rYcOGpsc7W+PGjVW9enWv/D7xV/6es8nX5vK3nE2+Noe/52vJ/3I2+bpiqtBFipCQEMXGxmrFihXucy6XSytWrPDq/EwrGIahsWPH6sMPP9SXX36pRo0aWRrf5XIpKyvL9HavuOIKbd68WRs3bnQfnTp10tChQ7Vx40avDsP6448/tGvXLsXExJjedvfu3QtsOffLL7+oQYMGpsc609y5c1WzZk1dffXVXouRmZmpgADPXzWBgYFyuVxeiymdTpwxMTH67bfftGzZMg0YMMBrsRo1aqTo6GiP3yXp6elas2bNef+7JP/Nzo4dO/TFF1/oggsusDS+t36X3HTTTdq0aZPH75LatWtr0qRJWrZsmenxzvbrr7/qxIkTXvl94q/8NWeTr73D33I2+doc/pyvJf/M2eTriqnCT/eYMGGChg8frk6dOqlz586aOXOmMjIyNHLkSNNj/fHHHx5VuD179mjjxo2qVq2a6tevb2qsMWPGaP78+froo49UuXJl9zy7qKgohYWFmRorMTFRV111lerXr6/ff/9d8+fP16pVq7zyi6Ny5coF5umGh4frggsuMH3+7sSJE9WvXz81aNBAhw4d0pQpUxQYGKghQ4aYGkeSxo8fr27duumxxx7ToEGDtHbtWr300kt66aWXTI+Vz+Vyae7cuRo+fLiCgrz3q6Bfv3569NFHVb9+fV144YX64Ycf9PTTT+vmm2/2Srxly5bJMAy1aNFCO3fu1KRJk9SyZcty/0yf6+d33LhxeuSRR9SsWTM1atRIDz74oGrXrq2EhATTY6Wmpmr//v3uvc/z3yxHR0eX+i9BxcWKiYnR9ddfr+TkZH3yySfKy8tz/y6pVq2aQkJCTIt1wQUX6NFHH1X//v0VExOj48ePa9asWTp48GCZt9o71+fx7DdvwcHBio6OVosWLUyNVa1aNU2dOlXXXXedoqOjtWvXLt19991q2rSpevfuXaZnq6j8MWeTr83hzzmbfF06VubrksQjZ5cvFvm6grJzaxFf8fzzzxv169c3QkJCjM6dOxvff/+9V+KsXLnSkFTgGD58uOmxCosjyZg7d67psW6++WajQYMGRkhIiFGjRg3jiiuuMD7//HPT4xTFW1ua3XDDDUZMTIwREhJi1KlTx7jhhhuMnTt3mh4n38cff2y0adPGcDqdRsuWLY2XXnrJa7EMwzCWLVtmSDK2b9/u1Tjp6enGXXfdZdSvX98IDQ01GjdubNx///1GVlaWV+ItXLjQaNy4sRESEmJER0cbY8aMMU6ePFnuds/18+tyuYwHH3zQqFWrluF0Oo0rrriizJ/bc8WaO3duodenTJliaqz87dIKO1auXGlqrD///NO45pprjNq1axshISFGTEyM0b9/f2Pt2rWljlOSeIUpz5ZmxcXKzMw0evXqZdSoUcMIDg42GjRoYIwaNco4cuRImZ+tIvO3nE2+Noc/52zydelYma9LEo+cXb5YhSFf+z+HYRhGUQUMAAAAAAAAq1ToNSkAAAAAAIDvoEgBAAAAAAB8AkUKAAAAAADgEyhSAAAAAAAAn0CRAgAAAAAA+ASKFAAAAAAAwCdQpAAAAAAAAD6BIgUAAAAAAPAJFCkASJIeeughdejQwe5uAACAcyBnA/BnFCkAP3HkyBHdeeedaty4sZxOp+rVq6d+/fppxYoVdncNAACcgZwNAEULsrsDAMpv79696t69u6pUqaInn3xSbdu2VU5OjpYtW6YxY8Zo27ZtdncRAACInA0A58JICsAP/POf/5TD4dDatWt13XXXqXnz5rrwwgs1YcIEff/995Kk/fv3a8CAAYqIiFBkZKQGDRqklJSUItu89NJLNW7cOI9zCQkJGjFihPvjhg0b6pFHHtGwYcMUERGhBg0aaMmSJTp27Jg7Vrt27bR+/Xr3a15//XVVqVJFy5YtU6tWrRQREaE+ffro8OHD7ntWrVqlzp07Kzw8XFWqVFH37t21b98+cz5ZAADYiJwNAMWjSAGc51JTU7V06VKNGTNG4eHhBa5XqVJFLpdLAwYMUGpqqr766istX75cu3fv1g033FDu+M8884y6d++uH374QVdffbVuuukmDRs2TP/4xz+UnJysJk2aaNiwYTIMw/2azMxMzZgxQ2+++aa+/vpr7d+/XxMnTpQk5ebmKiEhQXFxcdq0aZNWr16t2267TQ6Ho9x9BQDATuRsADg3pnsA57mdO3fKMAy1bNmyyHtWrFihzZs3a8+ePapXr54k6Y033tCFF16odevW6eKLLy5z/L59++r222+XJE2ePFmzZ8/WxRdfrIEDB0qS7rnnHnXt2lUpKSmKjo6WJOXk5GjOnDlq0qSJJGns2LF6+OGHJUnp6elKS0vT3//+d/f1Vq1albl/AAD4CnI2AJwbIymA89yZf+0oytatW1WvXj33mx1Jat26tapUqaKtW7eWK367du3c/1+rVi1JUtu2bQucO3r0qPtcpUqV3G9mJCkmJsZ9vVq1ahoxYoR69+6tfv366dlnn/UYVgoAwPmKnA0A50aRAjjPNWvWTA6Hw/SFtgICAgq8mcrJySlwX3BwsPv/84d3FnbO5XIV+pr8e86MNXfuXK1evVrdunXTwoUL1bx5c/c8XQAAzlfkbAA4N4oUwHmuWrVq6t27t2bNmqWMjIwC10+ePKlWrVrpwIEDOnDggPv8zz//rJMnT6p169aFtlujRg2Pv4bk5eVpy5Yt5j9AETp27KjExER99913atOmjebPn29ZbAAAvIGcDQDnRpEC8AOzZs1SXl6eOnfurA8++EA7duzQ1q1b9dxzz6lr166Kj49X27ZtNXToUCUnJ2vt2rUaNmyY4uLi1KlTp0LbvPzyy/V///d/+r//+z9t27ZNo0eP1smTJ73+LHv27FFiYqJWr16tffv26fPPP9eOHTuY4woA8AvkbAAoHgtnAn6gcePGSk5O1qOPPqp///vfOnz4sGrUqKHY2FjNnj1bDodDH330ke6880717NlTAQEB6tOnj55//vki27z55pv1448/atiwYQoKCtL48eN12WWXef1ZKlWqpG3btmnevHk6ceKEYmJiNGbMGPdCXwAAnM/I2QBQPIdRkhV8AAAAAAAAvIzpHgAAAAAAwCdQpAAAAAAAAD6BIgUAAAAAAPAJFCkAAAAAAIBPoEgBAAAAAAB8AkUKAAAAAADgEyhSAAAAAAAAn0CRAgAAAAAA+ASKFAAAAAAAwCdQpAAAAAAAAD6BIgUAAAAAAPAJFCkAAAAAAIBP+H/9H7EHsWHQEQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# We can draw the heatmaps of the shadow matrix and the simulated matrix to compare them.\n",
    "\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(10, 5))\n",
    "\n",
    "cmap = 'coolwarm'\n",
    "\n",
    "ax1 = plt.subplot(1, 2, 1)\n",
    "sns.heatmap(np.abs(shadow_rho_aer), cmap=cmap, annot=False, fmt='.2f', cbar=False)\n",
    "plt.title('Heatmap of Shadow Matrix')\n",
    "plt.xlabel('Columns')\n",
    "plt.ylabel('Rows')\n",
    "\n",
    "ax2 = plt.subplot(1, 2, 2, sharex=ax1, sharey=ax1)\n",
    "sns.heatmap(np.abs(matrix_ud_lr), cmap=cmap, annot=False, fmt='.2f', cbar=False)\n",
    "plt.title('Heatmap of Simulated Matrix')\n",
    "plt.xlabel('Columns')\n",
    "plt.ylabel('Rows')\n",
    "\n",
    "cbar_ax = plt.gcf().add_axes([1, 0.15, 0.02, 0.7])  # 设置颜色条的位置\n",
    "plt.colorbar(ax1.collections[0], cax=cbar_ax)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5cf9f36",
   "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
