{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import paddle\n",
    "from paddle_quantum.utils import Hamiltonian\n",
    "from paddle_quantum.circuit import UAnsatz\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def uni_2_design(N,D):\n",
    "    theta = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N,3]))\n",
    "    theta = paddle.to_tensor(theta, stop_gradient=True, dtype='float64')\n",
    "    cir = UAnsatz(N)    \n",
    "    cir.weak_superposition_layer()\n",
    "\n",
    "    for d in range(D):\n",
    "        for i in range(N):\n",
    "            cir.rz(theta[d][i][0], i)\n",
    "            cir.ry(theta[d][i][1], i)\n",
    "            cir.rz(theta[d][i][2], i)\n",
    "\n",
    "    return cir.U.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def uni_2_design_vec(N,D):\n",
    "    theta = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N,3]))\n",
    "    theta = paddle.to_tensor(theta, stop_gradient=True, dtype='float64')\n",
    "    cir = UAnsatz(N)    \n",
    "    cir.weak_superposition_layer()\n",
    "\n",
    "    for d in range(D):\n",
    "        for i in range(N):\n",
    "            cir.rz(theta[d][i][0], i)\n",
    "            cir.ry(theta[d][i][1], i)\n",
    "            cir.rz(theta[d][i][2], i)\n",
    "\n",
    "    return cir.run_state_vector()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def WriteJson(list_write, json_file_name):\n",
    "    with open(json_file_name + '.json', 'w') as file_save:\n",
    "        json_data = json.dumps(list_write, indent=4)\n",
    "        file_save.write(json_data)\n",
    "        file_save.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class StateNet_max(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_max, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    # loss function\n",
    "    def forward(self, N, rand_rho, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "        \n",
    "        rho_luo = cir.run_state_vector()\n",
    "        \n",
    "        # max_luo\n",
    "        loss = - (rho_luo.conj().t() @ H @ rho_luo).real()\n",
    "        return loss\n",
    "\n",
    "class StateNet_min(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_min, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    def forward(self, N, rand_rho, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "        \n",
    "        rho_luo = cir.run_state_vector()\n",
    "        \n",
    "        # min_luo\n",
    "        loss = (rho_luo.conj().t() @ H @ rho_luo).real()\n",
    "\n",
    "        return loss\n",
    "\n",
    "def train_loss(N, rand_rho, Herm):\n",
    "\n",
    "    ITR = 100  # 设置训练的总迭代次数\n",
    "    LR = 0.1   # 设置学习速率\n",
    "    net_max = StateNet_max()\n",
    "    net_min = StateNet_min()\n",
    "    opt_max = paddle.optimizer.Adam(learning_rate=LR, parameters=net_max.parameters())\n",
    "    opt_min = paddle.optimizer.Adam(learning_rate=LR, parameters=net_min.parameters())\n",
    "\n",
    "    # optimization interation\n",
    "    for itr in range(1, ITR + 1):\n",
    "\n",
    "        # max_opt\n",
    "        loss_max = net_max(N, rand_rho, Herm)\n",
    "\n",
    "        loss_max.backward()\n",
    "        opt_max.minimize(loss_max)\n",
    "        opt_max.clear_grad()\n",
    "\n",
    "        # min_opt\n",
    "        loss_min = net_min(N, rand_rho,  Herm)\n",
    "\n",
    "        loss_min.backward()\n",
    "        opt_min.minimize(loss_min)\n",
    "        opt_min.clear_grad()\n",
    "\n",
    "        # max - min\n",
    "        loss = -loss_max.numpy()[0] - loss_min.numpy()[0]\n",
    "        \n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/envs/paddle_quantum_dev/lib/python3.8/site-packages/paddle/fluid/framework.py:731: DeprecationWarning: `np.bool` is a deprecated alias for the builtin `bool`. To silence this warning, use `bool` by itself. Doing this will not modify any behavior and is safe. If you specifically wanted the numpy scalar type, use `np.bool_` here.\n",
      "Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations\n",
      "  elif dtype == np.bool:\n",
      "/opt/anaconda3/envs/paddle_quantum_dev/lib/python3.8/site-packages/paddle/tensor/creation.py:125: DeprecationWarning: `np.object` is a deprecated alias for the builtin `object`. To silence this warning, use `object` by itself. Doing this will not modify any behavior and is safe. \n",
      "Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations\n",
      "  if data.dtype == np.object:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.10687439673164109\n",
      "num_qubits = 2,     vC = 0.8986760178700646\n",
      "num_qubits = 2,     vC = 0.2816267741602338\n",
      "num_qubits = 2,     vC = 0.801019019332108\n",
      "num_qubits = 2,     vC = 0.0402586573908976\n",
      "num_qubits = 2,     vC = 0.48831832284807686\n",
      "num_qubits = 2,     vC = 0.776330766507565\n",
      "num_qubits = 2,     vC = 0.4668817276794224\n",
      "num_qubits = 2,     vC = 0.0018899984824010704\n",
      "num_qubits = 2,     vC = 0.9405784580758666\n",
      "num_qubits = 2,     vC = 0.8527734760633985\n",
      "num_qubits = 2,     vC = 0.5228138660309114\n",
      "num_qubits = 2,     vC = 0.7051681108607853\n",
      "num_qubits = 2,     vC = 0.5684220627630432\n",
      "num_qubits = 2,     vC = 0.5341309039084108\n",
      "num_qubits = 2,     vC = 0.7361920412555141\n",
      "num_qubits = 2,     vC = 0.34885342713288126\n",
      "num_qubits = 2,     vC = 0.8468367047704425\n",
      "num_qubits = 2,     vC = 0.9825331500044114\n",
      "num_qubits = 2,     vC = 0.4770653551201599\n",
      "num_qubits = 2,     vC = 0.8920876513735061\n",
      "num_qubits = 2,     vC = 0.7184958494934515\n",
      "num_qubits = 2,     vC = 0.8014030598827716\n",
      "num_qubits = 2,     vC = 0.4151548067867173\n",
      "num_qubits = 2,     vC = 0.8102185410517351\n",
      "num_qubits = 2,     vC = 0.7057102142155903\n",
      "num_qubits = 2,     vC = 0.6580287622825686\n",
      "num_qubits = 2,     vC = 0.4916199296057862\n",
      "num_qubits = 2,     vC = 0.400420227644689\n",
      "num_qubits = 2,     vC = 0.49366033084979594\n",
      "num_qubits = 2,     vC = 0.8764112863784462\n",
      "num_qubits = 2,     vC = 0.736805739989261\n",
      "num_qubits = 2,     vC = 0.4133431623395235\n",
      "num_qubits = 2,     vC = 0.4008374521451533\n",
      "num_qubits = 2,     vC = 0.12414006475198108\n",
      "num_qubits = 2,     vC = 0.543228021906108\n",
      "num_qubits = 2,     vC = 0.8757590472521285\n",
      "num_qubits = 2,     vC = 0.2523872236869463\n",
      "num_qubits = 2,     vC = 0.23082302968540366\n",
      "num_qubits = 2,     vC = 0.9500785103345147\n",
      "num_qubits = 2,     vC = 0.8755294333876794\n",
      "num_qubits = 2,     vC = 0.531411761337235\n",
      "num_qubits = 2,     vC = 0.24264635447245925\n",
      "num_qubits = 2,     vC = 0.947646091836055\n",
      "num_qubits = 2,     vC = 0.2457176514379907\n",
      "num_qubits = 2,     vC = 0.23531632979636474\n",
      "num_qubits = 2,     vC = 0.12222011484060258\n",
      "num_qubits = 2,     vC = 0.21231811874495268\n",
      "num_qubits = 2,     vC = 0.7986616122559198\n",
      "num_qubits = 2,     vC = 0.6488328051547798\n",
      "num_qubits = 3,     vC = 0.3994959769667563\n",
      "num_qubits = 3,     vC = 0.11851630686273226\n",
      "num_qubits = 3,     vC = 0.037479952574680675\n",
      "num_qubits = 3,     vC = 0.8123268575802584\n",
      "num_qubits = 3,     vC = 0.09048505030731462\n",
      "num_qubits = 3,     vC = 0.03349764265150379\n",
      "num_qubits = 3,     vC = 0.09824874492610298\n",
      "num_qubits = 3,     vC = 0.025466599036341755\n",
      "num_qubits = 3,     vC = 0.696021555972991\n",
      "num_qubits = 3,     vC = 0.81613742330875\n",
      "num_qubits = 3,     vC = 0.12730754323363838\n",
      "num_qubits = 3,     vC = 0.22095432080319152\n",
      "num_qubits = 3,     vC = 0.4017014770610826\n",
      "num_qubits = 3,     vC = 0.4138982658553161\n",
      "num_qubits = 3,     vC = 0.7966193376135331\n",
      "num_qubits = 3,     vC = 0.2251032375235272\n",
      "num_qubits = 3,     vC = 0.4835958679553577\n",
      "num_qubits = 3,     vC = 0.6755602980920714\n",
      "num_qubits = 3,     vC = 0.1002980063581623\n",
      "num_qubits = 3,     vC = 0.339166629613919\n",
      "num_qubits = 3,     vC = 0.027404589390464803\n",
      "num_qubits = 3,     vC = 0.19692315083073986\n",
      "num_qubits = 3,     vC = 0.0025443206358122224\n",
      "num_qubits = 3,     vC = 0.04127371497543718\n",
      "num_qubits = 3,     vC = 0.1058001457184395\n",
      "num_qubits = 3,     vC = 0.5471929014318632\n",
      "num_qubits = 3,     vC = 0.26385073293325384\n",
      "num_qubits = 3,     vC = 0.6701443976073025\n",
      "num_qubits = 3,     vC = 0.8457117529920261\n",
      "num_qubits = 3,     vC = 0.3965587974973959\n",
      "num_qubits = 3,     vC = 0.1264192549229814\n",
      "num_qubits = 3,     vC = 0.3288209196317954\n",
      "num_qubits = 3,     vC = 0.1597282671100604\n",
      "num_qubits = 3,     vC = 0.19152826231499445\n",
      "num_qubits = 3,     vC = 0.11243448794102966\n",
      "num_qubits = 3,     vC = 0.35299777577557223\n",
      "num_qubits = 3,     vC = 0.41706996658279505\n",
      "num_qubits = 3,     vC = 0.8183076617701335\n",
      "num_qubits = 3,     vC = 0.36379577529674\n",
      "num_qubits = 3,     vC = 0.2373740552952546\n",
      "num_qubits = 3,     vC = 0.021377271117181088\n",
      "num_qubits = 3,     vC = 0.15522703652827033\n",
      "num_qubits = 3,     vC = 0.03973417462456381\n",
      "num_qubits = 3,     vC = 0.025369533133849625\n",
      "num_qubits = 3,     vC = 0.08645157195524215\n",
      "num_qubits = 3,     vC = 0.014084902251699569\n",
      "num_qubits = 3,     vC = 0.33735496620426864\n",
      "num_qubits = 3,     vC = 0.1000484276005656\n",
      "num_qubits = 3,     vC = 0.02440221577779164\n",
      "num_qubits = 3,     vC = 0.1335967004176377\n",
      "num_qubits = 4,     vC = 0.004358693309249046\n",
      "num_qubits = 4,     vC = 0.05937316029672662\n",
      "num_qubits = 4,     vC = 0.017150183626664272\n",
      "num_qubits = 4,     vC = 0.1768316056181767\n",
      "num_qubits = 4,     vC = 0.1560942627652425\n",
      "num_qubits = 4,     vC = 0.3069007836219259\n",
      "num_qubits = 4,     vC = 0.03936459230552476\n",
      "num_qubits = 4,     vC = 0.18631169001646913\n",
      "num_qubits = 4,     vC = 0.06118238928027248\n",
      "num_qubits = 4,     vC = 0.49068081379492384\n",
      "num_qubits = 4,     vC = 0.005330195679923548\n",
      "num_qubits = 4,     vC = 0.03814386622458948\n",
      "num_qubits = 4,     vC = 0.2810119949917983\n",
      "num_qubits = 4,     vC = 0.3847175163151521\n",
      "num_qubits = 4,     vC = 0.025704880666402516\n",
      "num_qubits = 4,     vC = 0.25725935847557313\n",
      "num_qubits = 4,     vC = 0.05421045978464365\n",
      "num_qubits = 4,     vC = 0.0009052540131849294\n",
      "num_qubits = 4,     vC = 0.003936990525178315\n",
      "num_qubits = 4,     vC = 0.000728449196078829\n",
      "num_qubits = 4,     vC = 0.045039809800902296\n",
      "num_qubits = 4,     vC = 0.0388247182866397\n",
      "num_qubits = 4,     vC = 0.0009218983971074073\n",
      "num_qubits = 4,     vC = 0.09147234556429196\n",
      "num_qubits = 4,     vC = 0.00890341389690598\n",
      "num_qubits = 4,     vC = 0.11032036799462662\n",
      "num_qubits = 4,     vC = 0.2231664152990224\n",
      "num_qubits = 4,     vC = 0.05073347484455986\n",
      "num_qubits = 4,     vC = 0.030339526824402347\n",
      "num_qubits = 4,     vC = 0.0781984732935489\n",
      "num_qubits = 4,     vC = 0.6172901275967246\n",
      "num_qubits = 4,     vC = 0.020701006560312506\n",
      "num_qubits = 4,     vC = 0.007876022292933896\n",
      "num_qubits = 4,     vC = 0.07273884106060963\n",
      "num_qubits = 4,     vC = 0.0024010720308081436\n",
      "num_qubits = 4,     vC = 0.13216766791922566\n",
      "num_qubits = 4,     vC = 0.09075772522442252\n",
      "num_qubits = 4,     vC = 0.460660525323282\n",
      "num_qubits = 4,     vC = 0.0737819050017409\n",
      "num_qubits = 4,     vC = 0.05362729719027\n",
      "num_qubits = 4,     vC = 0.0860353588335844\n",
      "num_qubits = 4,     vC = 0.012430811474854368\n",
      "num_qubits = 4,     vC = 0.011277565442353324\n",
      "num_qubits = 4,     vC = 0.04611237386939041\n",
      "num_qubits = 4,     vC = 0.0986327791003933\n",
      "num_qubits = 4,     vC = 0.522653679761203\n",
      "num_qubits = 4,     vC = 0.00325391156186344\n",
      "num_qubits = 4,     vC = 0.13493170841845833\n",
      "num_qubits = 4,     vC = 0.41411575111955445\n",
      "num_qubits = 4,     vC = 0.2116279679559646\n",
      "num_qubits = 5,     vC = 0.0009843766970903897\n",
      "num_qubits = 5,     vC = 0.09666670289583848\n",
      "num_qubits = 5,     vC = 0.018595762495662145\n",
      "num_qubits = 5,     vC = 5.808126638418081e-05\n",
      "num_qubits = 5,     vC = 0.006037545413376494\n",
      "num_qubits = 5,     vC = 0.0001874338076196853\n",
      "num_qubits = 5,     vC = 0.04966451116650915\n",
      "num_qubits = 5,     vC = 0.02466294477793405\n",
      "num_qubits = 5,     vC = 0.018097851704791734\n",
      "num_qubits = 5,     vC = 0.027712001734850875\n",
      "num_qubits = 5,     vC = 0.0006105106853728242\n",
      "num_qubits = 5,     vC = 0.0006139854961982882\n",
      "num_qubits = 5,     vC = 0.10721199946033753\n",
      "num_qubits = 5,     vC = 0.04517995489824465\n",
      "num_qubits = 5,     vC = 0.009907341541312117\n",
      "num_qubits = 5,     vC = 0.02139799968497073\n",
      "num_qubits = 5,     vC = 0.16599821438740833\n",
      "num_qubits = 5,     vC = 0.0027517263693953237\n",
      "num_qubits = 5,     vC = 0.000813073025455399\n",
      "num_qubits = 5,     vC = 0.01144659548736003\n",
      "num_qubits = 5,     vC = 0.17582814969498467\n",
      "num_qubits = 5,     vC = 3.714163934134297e-05\n",
      "num_qubits = 5,     vC = 0.01749595652539904\n",
      "num_qubits = 5,     vC = 0.05496787403596906\n",
      "num_qubits = 5,     vC = 0.011122208872019403\n",
      "num_qubits = 5,     vC = 0.007096378088809154\n",
      "num_qubits = 5,     vC = 0.015429746240956523\n",
      "num_qubits = 5,     vC = 0.03823685513269407\n",
      "num_qubits = 5,     vC = 0.010041957027989233\n",
      "num_qubits = 5,     vC = 0.011885715795485932\n",
      "num_qubits = 5,     vC = 0.0057914053185663126\n",
      "num_qubits = 5,     vC = 0.009253765995056076\n",
      "num_qubits = 5,     vC = 0.0029428332982679153\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.02316694076702216\n",
      "num_qubits = 5,     vC = 0.0029893015569040565\n",
      "num_qubits = 5,     vC = 0.0635580364305496\n",
      "num_qubits = 5,     vC = 0.020247534392887998\n",
      "num_qubits = 5,     vC = 0.00018526840944677663\n",
      "num_qubits = 5,     vC = 0.004393925338269096\n",
      "num_qubits = 5,     vC = 0.006226970285881752\n",
      "num_qubits = 5,     vC = 0.019007252974414527\n",
      "num_qubits = 5,     vC = 0.08093418350698439\n",
      "num_qubits = 5,     vC = 2.1211358431801706e-05\n",
      "num_qubits = 5,     vC = 0.024310301514618993\n",
      "num_qubits = 5,     vC = 0.13899818729106675\n",
      "num_qubits = 5,     vC = 0.0005676714697854538\n",
      "num_qubits = 5,     vC = 0.0005562092208482261\n",
      "num_qubits = 5,     vC = 0.023959914264452646\n",
      "num_qubits = 5,     vC = 0.018002154550543117\n",
      "num_qubits = 5,     vC = 0.0538624765609527\n",
      "num_qubits = 6,     vC = 0.015504022270674246\n",
      "num_qubits = 6,     vC = 0.005177033002746359\n",
      "num_qubits = 6,     vC = 0.003949203212754059\n",
      "num_qubits = 6,     vC = 0.01716969946011111\n",
      "num_qubits = 6,     vC = 0.1622083587499864\n",
      "num_qubits = 6,     vC = 0.020880389568379454\n",
      "num_qubits = 6,     vC = 0.027776804906681336\n",
      "num_qubits = 6,     vC = 0.09744717499196721\n",
      "num_qubits = 6,     vC = 0.005076484716660442\n",
      "num_qubits = 6,     vC = 0.0026321484431091613\n",
      "num_qubits = 6,     vC = 0.012454123281048033\n",
      "num_qubits = 6,     vC = 0.001679965118756445\n",
      "num_qubits = 6,     vC = 0.0060809558623530656\n",
      "num_qubits = 6,     vC = 0.02250870543649153\n",
      "num_qubits = 6,     vC = 0.07079300475008561\n",
      "num_qubits = 6,     vC = 0.06304247159852087\n",
      "num_qubits = 6,     vC = 0.02381706758844179\n",
      "num_qubits = 6,     vC = 0.009677490963224159\n",
      "num_qubits = 6,     vC = 0.024169777313421865\n",
      "num_qubits = 6,     vC = 0.04868086181066954\n",
      "num_qubits = 6,     vC = 0.0033157576623033566\n",
      "num_qubits = 6,     vC = 0.01724626909299513\n",
      "num_qubits = 6,     vC = 0.0010404942598486531\n",
      "num_qubits = 6,     vC = 0.034251479823421735\n",
      "num_qubits = 6,     vC = 0.01452176089954253\n",
      "num_qubits = 6,     vC = 0.006261702668414029\n",
      "num_qubits = 6,     vC = 0.008371137300008458\n",
      "num_qubits = 6,     vC = 0.0037172954918949274\n",
      "num_qubits = 6,     vC = 0.012273234215403188\n",
      "num_qubits = 6,     vC = 0.0006143742224171496\n",
      "num_qubits = 6,     vC = 0.012713663416147433\n",
      "num_qubits = 6,     vC = 0.0029084193418156368\n",
      "num_qubits = 6,     vC = 0.0348837444630845\n",
      "num_qubits = 6,     vC = 0.16908644142689264\n",
      "num_qubits = 6,     vC = 0.0016320649634983288\n",
      "num_qubits = 6,     vC = 0.006132367925465704\n",
      "num_qubits = 6,     vC = 0.05842719977425138\n",
      "num_qubits = 6,     vC = 0.0022269833085862317\n",
      "num_qubits = 6,     vC = 0.002113589165801882\n",
      "num_qubits = 6,     vC = 0.2711741777709579\n",
      "num_qubits = 6,     vC = 0.012259817626695623\n",
      "num_qubits = 6,     vC = 0.006903353603723251\n",
      "num_qubits = 6,     vC = 0.006605755350537338\n",
      "num_qubits = 6,     vC = 0.0206640247269392\n",
      "num_qubits = 6,     vC = 0.020254234198291594\n",
      "num_qubits = 6,     vC = 0.0005626681184282364\n",
      "num_qubits = 6,     vC = 0.023221483110058568\n",
      "num_qubits = 6,     vC = 0.0022118885456351234\n",
      "num_qubits = 6,     vC = 0.0029053434334125484\n",
      "num_qubits = 6,     vC = 0.009060524671874673\n",
      "num_qubits = 7,     vC = 1.913859087079093e-05\n",
      "num_qubits = 7,     vC = 0.033230816168388244\n",
      "num_qubits = 7,     vC = 0.0011811003710778438\n",
      "num_qubits = 7,     vC = 0.0259226501723413\n",
      "num_qubits = 7,     vC = 0.012451288762840018\n",
      "num_qubits = 7,     vC = 0.00016614375880341726\n",
      "num_qubits = 7,     vC = 1.222853382745273e-05\n",
      "num_qubits = 7,     vC = 0.003970318394799276\n",
      "num_qubits = 7,     vC = 0.01771691367209093\n",
      "num_qubits = 7,     vC = 0.00782945376011741\n",
      "num_qubits = 7,     vC = 0.025269221559997827\n",
      "num_qubits = 7,     vC = 0.0003007030056451713\n",
      "num_qubits = 7,     vC = 0.06392589848309135\n",
      "num_qubits = 7,     vC = 0.00393612864624452\n",
      "num_qubits = 7,     vC = 0.0021537716495364286\n",
      "num_qubits = 7,     vC = 0.0006593062316062097\n",
      "num_qubits = 7,     vC = 0.0008202242594850809\n",
      "num_qubits = 7,     vC = 0.0003544084798942237\n",
      "num_qubits = 7,     vC = 0.0007140278672782671\n",
      "num_qubits = 7,     vC = 0.0010005859247145443\n",
      "num_qubits = 7,     vC = 0.021444248347833112\n",
      "num_qubits = 7,     vC = 0.0007135858699944805\n",
      "num_qubits = 7,     vC = 0.00022235359582346007\n",
      "num_qubits = 7,     vC = 0.0013382163130006995\n",
      "num_qubits = 7,     vC = 0.00013750002715457227\n",
      "num_qubits = 7,     vC = 0.040303371107926506\n",
      "num_qubits = 7,     vC = 2.888425889819441e-05\n",
      "num_qubits = 7,     vC = 0.0021739477381311997\n",
      "num_qubits = 7,     vC = 6.287903097431028e-05\n",
      "num_qubits = 7,     vC = 0.06453880949166906\n",
      "num_qubits = 7,     vC = 0.0008070195815652254\n",
      "num_qubits = 7,     vC = 0.033028543296935935\n",
      "num_qubits = 7,     vC = 0.0016514329646339337\n",
      "num_qubits = 7,     vC = 0.00133609560852891\n",
      "num_qubits = 7,     vC = 0.002862865427273743\n",
      "num_qubits = 7,     vC = 0.09134451688852796\n",
      "num_qubits = 7,     vC = 0.012180147296613007\n",
      "num_qubits = 7,     vC = 0.00016052832595716643\n",
      "num_qubits = 7,     vC = 0.007860666765052001\n",
      "num_qubits = 7,     vC = 0.007555136184147729\n",
      "num_qubits = 7,     vC = 0.00954467322246507\n",
      "num_qubits = 7,     vC = 0.03227483967006392\n",
      "num_qubits = 7,     vC = 0.00014681202931526256\n",
      "num_qubits = 7,     vC = 0.0023737156841633234\n",
      "num_qubits = 7,     vC = 0.006431004130145069\n",
      "num_qubits = 7,     vC = 0.18806747832729315\n",
      "num_qubits = 7,     vC = 0.004472722116624546\n",
      "num_qubits = 7,     vC = 0.0012434113995598078\n",
      "num_qubits = 7,     vC = 0.003838296937225115\n",
      "num_qubits = 7,     vC = 0.0425972349399032\n",
      "num_qubits = 8,     vC = 0.02641865023934881\n",
      "num_qubits = 8,     vC = 0.0006268846542648596\n",
      "num_qubits = 8,     vC = 9.117611798352418e-05\n",
      "num_qubits = 8,     vC = 0.0005599212781940617\n",
      "num_qubits = 8,     vC = 0.010621571993101302\n",
      "num_qubits = 8,     vC = 0.01559867823473301\n",
      "num_qubits = 8,     vC = 0.004304699711523114\n",
      "num_qubits = 8,     vC = 0.0006915648283678547\n",
      "num_qubits = 8,     vC = 5.851611884112207e-05\n",
      "num_qubits = 8,     vC = 0.01623816156821005\n",
      "num_qubits = 8,     vC = 0.0005826701267833735\n",
      "num_qubits = 8,     vC = 1.0860541301861737e-06\n",
      "num_qubits = 8,     vC = 0.023290310189135768\n",
      "num_qubits = 8,     vC = 0.004545536410709635\n",
      "num_qubits = 8,     vC = 1.3349000027577922e-07\n",
      "num_qubits = 8,     vC = 0.08060044606507755\n",
      "num_qubits = 8,     vC = 0.0044958856601793025\n",
      "num_qubits = 8,     vC = 0.013178011130639584\n",
      "num_qubits = 8,     vC = 0.0001814134576951208\n",
      "num_qubits = 8,     vC = 0.0008941158952606978\n",
      "num_qubits = 8,     vC = 0.008651015192224441\n",
      "num_qubits = 8,     vC = 0.00029820646804976976\n",
      "num_qubits = 8,     vC = 0.002026420480588002\n",
      "num_qubits = 8,     vC = 0.002749174647915953\n",
      "num_qubits = 8,     vC = 0.0029798951619598914\n",
      "num_qubits = 8,     vC = 0.13849911519603356\n",
      "num_qubits = 8,     vC = 0.02773820824279481\n",
      "num_qubits = 8,     vC = 0.004499061979925757\n",
      "num_qubits = 8,     vC = 0.006156293361173572\n",
      "num_qubits = 8,     vC = 0.00202496696353988\n",
      "num_qubits = 8,     vC = 8.31820734798238e-05\n",
      "num_qubits = 8,     vC = 0.00024403488141158368\n",
      "num_qubits = 8,     vC = 0.002026373384117833\n",
      "num_qubits = 8,     vC = 0.0005984413263917069\n",
      "num_qubits = 8,     vC = 0.00034814088377962374\n",
      "num_qubits = 8,     vC = 0.004019676046740676\n",
      "num_qubits = 8,     vC = 0.00027003372747715857\n",
      "num_qubits = 8,     vC = 5.780639044946272e-05\n",
      "num_qubits = 8,     vC = 0.005989178133156066\n",
      "num_qubits = 8,     vC = 0.00011592119304657454\n",
      "num_qubits = 8,     vC = 0.00018123719366032606\n",
      "num_qubits = 8,     vC = 0.0025471553590345137\n",
      "num_qubits = 8,     vC = 0.0011792448062686975\n",
      "num_qubits = 8,     vC = 0.043386468118011515\n",
      "num_qubits = 8,     vC = 0.00038054539964920455\n",
      "num_qubits = 8,     vC = 0.003587497651655403\n",
      "num_qubits = 8,     vC = 0.0020487319011970252\n",
      "num_qubits = 8,     vC = 0.01131394485434781\n",
      "num_qubits = 8,     vC = 8.554632262160827e-05\n",
      "num_qubits = 8,     vC = 0.014127837429877055\n",
      "num_qubits = 9,     vC = 3.8409970532481565e-06\n",
      "num_qubits = 9,     vC = 0.06401479431496054\n",
      "num_qubits = 9,     vC = 4.7912172240922525e-05\n",
      "num_qubits = 9,     vC = 0.005187359344241293\n",
      "num_qubits = 9,     vC = 0.00023850900905186289\n",
      "num_qubits = 9,     vC = 2.2012357933629468e-05\n",
      "num_qubits = 9,     vC = 0.000270821363296236\n",
      "num_qubits = 9,     vC = 2.3988848890416754e-06\n",
      "num_qubits = 9,     vC = 0.003668917921009339\n",
      "num_qubits = 9,     vC = 6.422270490187012e-05\n",
      "num_qubits = 9,     vC = 0.000628314108945808\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 0.00016737039006606814\n",
      "num_qubits = 9,     vC = 0.00015215676500142345\n",
      "num_qubits = 9,     vC = 1.2215966876306402e-05\n",
      "num_qubits = 9,     vC = 0.005001278081701202\n",
      "num_qubits = 9,     vC = 6.50812635357344e-05\n",
      "num_qubits = 9,     vC = 3.940521907827637e-05\n",
      "num_qubits = 9,     vC = 0.0521582656982018\n",
      "num_qubits = 9,     vC = 0.00033858397586562387\n",
      "num_qubits = 9,     vC = 7.75056639243338e-05\n",
      "num_qubits = 9,     vC = 0.003565168128734382\n",
      "num_qubits = 9,     vC = 0.0011859594144502962\n",
      "num_qubits = 9,     vC = 0.0022013819882289597\n",
      "num_qubits = 9,     vC = 0.005471575519464579\n",
      "num_qubits = 9,     vC = 0.0002603272137646153\n",
      "num_qubits = 9,     vC = 0.040487375584961405\n",
      "num_qubits = 9,     vC = 2.942436549440475e-06\n",
      "num_qubits = 9,     vC = 4.427526276794278e-07\n",
      "num_qubits = 9,     vC = 0.010685359729797322\n",
      "num_qubits = 9,     vC = 0.0030165980073486483\n",
      "num_qubits = 9,     vC = 0.009406431577998116\n",
      "num_qubits = 9,     vC = 9.49077112146772e-05\n",
      "num_qubits = 9,     vC = 0.00019691666004302216\n",
      "num_qubits = 9,     vC = 0.00017959516910493451\n",
      "num_qubits = 9,     vC = 3.7196677384569376e-06\n",
      "num_qubits = 9,     vC = 0.0003003321195625951\n",
      "num_qubits = 9,     vC = 0.006526651769152382\n",
      "num_qubits = 9,     vC = 0.0005734740179745962\n",
      "num_qubits = 9,     vC = 2.7505178407455945e-06\n",
      "num_qubits = 9,     vC = 1.0660627962698003e-05\n",
      "num_qubits = 9,     vC = 0.00030395899114929524\n",
      "num_qubits = 9,     vC = 0.0001108374550028071\n",
      "num_qubits = 9,     vC = 0.011126728435807606\n",
      "num_qubits = 9,     vC = 0.022092599424103927\n",
      "num_qubits = 9,     vC = 0.002806061827770306\n",
      "num_qubits = 9,     vC = 5.882736786797998e-07\n",
      "num_qubits = 9,     vC = 0.008673025420661193\n",
      "num_qubits = 9,     vC = 0.0004566158834328148\n",
      "num_qubits = 9,     vC = 0.0004839622148069549\n",
      "num_qubits = 9,     vC = 9.553117368089527e-07\n"
     ]
    }
   ],
   "source": [
    "loss_change = []\n",
    "\n",
    "for N in range(2,10):\n",
    "\n",
    "    temp = []\n",
    "\n",
    "    # heisenberg model\n",
    "    H = np.zeros((2**N, 2**N))\n",
    "    H[0][0] = 1\n",
    "    # spectral width of H = 1\n",
    "\n",
    "    for _ in range(500):\n",
    "        \n",
    "        V = uni_2_design(N, 10*N)\n",
    "        rand_H = paddle.to_tensor(V @ H @ V.conjugate().T)\n",
    "        rand_rho = uni_2_design_vec(N, 10*N)\n",
    "        \n",
    "        Delta_C = train_loss(N, rand_rho, Herm=rand_H)\n",
    "\n",
    "        temp.append(Delta_C)\n",
    "        if _ % 10 == 0:\n",
    "            print(f'num_qubits = {N},     vC = {Delta_C}')\n",
    "\n",
    "    WriteJson(temp,  'sample_vC_QSL_inside_Adam_'+str(N)+'qubit')\n",
    "\n",
    "    loss_change.append(np.average(temp))\n",
    "\n",
    "WriteJson(loss_change, \"QSL_inside_Adam_1design\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Th127dpFlSpVqFChAk899RTHjx93HUtEREQyiIAqadbaRdbazvny5XMdBYDs2bPTp08fduzYwc6dO4mIiODdd991HUtEREQygIAqaX51zTXXMG/ePMaMGUP37t1p1qwZX375petYIiIiznz99dfUrFmTsLAwwsPDGT169N++P3PmTLJly8bTTz/9r9fu2LGDjh07nvN9v/jiCypWrEjJkiVp2bIlJ06c+NfP7Nu3jxw5chAVFUVUVBRdunS54PxPPPEEV1999b/24hs7dixTpky54Pc7F5W0dNSgQQPi4uIoV64c0dHRPPfcc+f8wyMiIhLosmTJwsiRI0lISGDjxo289NJLJCQkALBy5UqGDRtGQkICK1as4NVXX/3bawcPHsxDDz10zvd9/PHH6dGjB59++ikFChRg8uTJ5/y5EiVKsHPnTnbu3MmECRMuOH9sbCybN2/+1/MdOnRgzJgxF/x+56KSls5CQkJ48skn2bx5M+vXr6d06dKsWLHCdSwREZF0VaRIEcqVKwd4szdDQ0M5cOAAe/bsoV+/fixdupSSJUuyZMkSZs6cydKlSwFvg9ndu3dTpkyZf72ntZaVK1fSokULANq1a8eCBQsuKFfu3Ll54oknKFOmDLVq1eL7778/589VqlSJIkWK/Ov5nDlzUrx48XMWuAulkubI9ddfz6JFixg+fDj33XcfLVu2ZP/+/a5jiYhIJmSMSfXHhdi3bx87duygYsWKREZGsn79egoXLgxArly5WLp0KfXq1QNg69atREREnPN9Dh48SP78+cmSxdu8olixYhw4cO598b/44gvKli1L9erV/zZU/dixY1SqVIldu3ZRtWpVXnnllQv6XQDKly+fKoPaVdIci42NJT4+nlKlShEVFcWIESM4efKk61giIpKJWGtT/ZFSR48epXnz5rzwwgvkzZv3vD//7bffcsUVV1zKr0uRIkX46quv2LFjB88//zx33XUXhw8fBiBbtmw0atQIgKioKPbt23fB71+oUCG++eabS8oIKmm+kDNnTp5++mk2bNjAihUriIqKYvXq1a5jiYiIpKmTJ0/SvHlz2rRpw+23356i1+TIkeNvW1rVq1ePqKgoOnXqRMGCBfn11185deoUAPv37+eqq67613tkz56dggULAhAdHU2JEiX45JNPAG9z+j/PBAYHB3Pq1ClOnz79100G/fv3P2/G48ePkyNHjhT9Psnx/YD1C2GMiQViS5Ys6TrKRbnhhht49913mTdvHvfccw8xMTGMGDGCK6+80nU0ERGRVGWtpWPHjoSGhvLoo4+m+HWhoaGMHDnyr6//vFbtTzVr1mTu3Lm0atWKV199lSZNmvzrPX788Ucuu+wygoOD+fzzz9m7d2+ym84HBwezc+fOFGf85JNPqFq1aop//r8E1Jk0v+2TdjGMMTRv3pzExESKFStGZGQko0eP/uu/CkRERALBhx9+yPTp01m5cuVfZ6mWLDn/0KGbbrqJQ4cOceTIkXN+f+jQoTz//POULFmSgwcP/rVVx8KFC/86C7ZmzRpKly5NVFQULVq0YMKECVx22WUXlL9Xr14UK1aM3377jWLFijFw4MC//W633nrrBb3fuQTUmbRAkitXLoYMGUK7du3o1q0bU6ZMYdy4canSzEVERFy75ZZbLujatbN16NCBOXPm0KlTp3997/rrrz/nnZWNGzemcePGADRv3pzmzZuf872PHj361983bdqUtm3bnvPnhg0bxrBhw/71/I4dOwgPD/9rOfVSBNSZtEAUGhrKihUr6Nu3Ly1btuTee+/lhx9+cB1LRETEma5du5I9e3bXMc7pp59+OucGvBdDJS0DMMbQsmVLEhMTKViwIBEREYwbN47Tp0+7jiYiIhnUxZ7F8oOQkJD/PMPl2q233krx4sXP+b0LPeYqaRlInjx5GDFiBCtXrmTOnDncfPPNbNq0yXUsERHJYEJCQjh48GCGLmoZjbWWgwcPEhISkuLX6Jq0DCgiIoLVq1fz+uuv07RpU2JjY3nuuedSZf1bREQCX7Fixdi/fz+//vrrBZWGzOb48eOpenxCQkIoVqxYin9eJS2DMsbQtm1bYmNj6d+/P2FhYTzzzDN07NiRoCCdIBURkf+WNWtWrrvuOlavXk3ZsmVdx/Et18cnoP7f3BgTa4yZeOjQIddR0k3+/Pl58cUXWbp0KVOnTqVKlSps377ddSwRERG5RAFV0gJhn7SLFRUVxbp16+jcuTO33XYbDz74IL/88ovrWCIiInKRAqqkZXZBQUF06NCBhIQEzpw5Q1hYGNOmTePMmTOuo4mIiMgFUkkLQJdddhnjx49n0aJFjBs3jpiYGHbv3u06loiIiFwAlbQAVr58eTZs2MA999xDnTp1eOSRR8hM1+uJiIhkZCppAS44OJjOnTuTkJDA0aNHCQ0NZcaMGdobR0RExOdU0jKJyy+/nEmTJjFv3jxGjhxJrVq1SEhIcB1LRERE/oNKWiZTqVIltmzZQvPmzalevTq9evX62zBZERER8QeVtEwoODiYbt26ERcXx/fff09oaChvvvmmlkBFRER8RCUtEytcuDCvvvoqM2fO5KmnnqJevXp8/PHHrmOJiIgIAVbSMuPEgdRQrVo1tm/fToMGDahatSp9+/bl2LFjrmOJiIhkagFV0jLzxIFLlTVrVnr06MHu3bvZt28f4eHhLFiwQEugIiIijgRUSZNLV7RoUWbOnMnUqVPp27cvDRs25LPPPnMdS0REJNNRSZNzqlmzJjt37qRGjRpUrFiRgQMH8vvvv7uOJSIikmmopMl/ypYtG7169WLHjh3Ex8cTERHBO++84zqWiIhIpqCSJud19dVX8+abbzJu3Dh69OhB06ZN2bdvn+tYIiIiAU0lTVKsXr167NmzhwoVKlC+fHmeffZZ/vjjD9exREREApJKmlyQ7Nmz88QTT7B161a2bNlCZGQky5Ytcx1LREQk4KikyUUpXrw4CxYsYNSoUXTt2pUWLVrw9ddfu44lIiISMFTSLsa8eVzz+utw8qTrJM41bNiQuLg4IiIiKFu2LMOGDePEiROuY4mIiGR4KmkXo3x58u/eDRUrws6drtM4lyNHDgYOHMimTZv44IMPiIqKYuXKla5jiYiIZGhZXAdITcaYWCC2ZMmSaftB11zD7qFDqfHll1C3LnTpAk88Admzp+3n+lyJEiVYvHgxCxcupEOHDpQoUYJSpUpRtGhR19FEREQynIA6k5auY6GMgfbtvTNpu3ZBdDRs3pz2n+tzxhiaNGlCQkICRYoUoXTp0owaNYqTWhoWERG5IAFV0pwoWhQWLIB+/aBxY+jVC7QzPzlz5qRTp058+OGHLFmyhOjoaNauXes6loiISIahkpYajIFWrWD3bvjqK4iKgnXrXKfyhRtvvJFly5bx5JNPctddd9GuXTu+//5717FERER8TyUtNRUqBLNnw5Ah0LIlPPQQHD3qOpVzxhjuuOMOEhMTKVy4MBEREYwdO5ZTp065jiYiIuJbKmlpoVkz2LMHDh+G0qXh/fddJ/KF3LlzM2zYMFavXs1bb71FhQoV2Lhxo+tYIiIivqSSllYuuwymTYOXXoJ774XOneHQIdepfCE8PJyVK1fyv//9j+bNm9OpUyd++ukn17FERER8RSUtrTVoAHFxEBQEERHwzjuuE/mCMYa77rqLxMRE8uTJQ1hYGC+//DKnT592HU1ERMQXVNLSQ968MGGCd2ate3e45x74+WfXqXwhb968jBo1iuXLlzN9+nQqV67M1q1bXccSERFxTiUtPdWu7d0BWqCAd1Zt3jzXiXyjTJkyrFmzhgcffJDY2Fi6du3KzyqyIiKSiamkpbfcuWH0aHjjDejTB+68E374wXUqXwgKCqJdu3YkJCQQHBxMWFgYU6ZM4cyZM66jiYiIpDuVNFduucWbVnDddRAZCTNngrWuU/lCgQIFGDt2LEuWLGHixInccsst7NSMVBERyWRU0lzKkQOGDoXFi2HwYGjSBA4ccJ3KN8qVK8f69evp0KED9erV46GHHuKQ7pAVEZFMQiXNDypUgG3boGxZb1rBlCk6q5YkKCiITp06kZCQwPHjxwkNDWX69OlYHR8REQlwAVXSjDGxxpiJGfJsS/bsMGgQrFgBY8dCvXrw5ZeuU/lGwYIFmThxIvPnz+eFF16gRo0axMXFuY4lIiKSZgKqpFlrF1lrO+fLl891lItXpgxs2gQ1a0J0NIwbB7pw/i8VK1Zk8+bNtGrVilq1atGzZ0+OHDniOpaIiEiqC6iSFjCyZvXu/Fy7FqZPh1q14NNPXafyjeDgYLp27UpcXBw///wzoaGhzJ49W0ugIiISUFTS/Cw0FNatg6ZNoVIlGDUKtCP/XwoVKsTUqVOZM2cOzz33HHXq1CExMdF1LBERkVShkuZ3wcHwyCOwcSO8/ba3dYeKyN9UrVqVbdu20aRJE2JiYujduzfHjh1zHUtEROSSqKRlFCVLwsqV3kipmBh47jk4edJ1Kt/IkiULDz30ELt372b//v2Ehoby1ltvaQlUREQyLJW0jCQoCLp2ha1bYfVqbwl01y7XqXylSJEivP7667z22mv079+fBg0asHfvXtexRERELphKWkZ07bXw3nvQrRvceisMGAAnTrhO5Ss1atRg586d1KlTh8qVK/Pkk0/y22+/uY4lIiKSYippGZUxcO+93mipHTu87Tq2bHGdyleyZs3KY489xs6dO/nkk08IDw9n0aJFrmOJiIikiEpaRle0qHdDQd++EBsLjz8Ov//uOpWvFCtWjDlz5vDKK6/wv//9j9jYWL744gvXsURERJKlkhYIjIHWrWH3bti3zxst9eGHrlP5Tp06ddi1axdVqlShQoUKPPXUUxw/ftx1LBERkXNSSQskhQrBnDnenZ933AEPPwzaiuJvsmfPTp8+fdi+fTs7d+4kIiKCd99913UsERGRf1FJC0S33w5xcfDrrxAZ6W3dIX9zzTXXMG/ePMaMGUP37t25/fbb+eqrr1zHEhER+YtKWqC67DJ49VVvWHv79nD//ZARB8+nsQYNGhAXF0dUVBTlypVjyJAhnNCdsiIi4gMqaYHutttgzx7v7yMjQUt7/xISEkL//v3ZvHkz69ato3Tp0rz//vuuY4mISCankpYZ5MsHL78MU6fCgw9Cu3bw88+uU/nO9ddfz+LFixk2bBidOnWiZcuWHDhwwHUsERHJpFTSMpPatb07QPPnh4gImD/fdSJfaty4MfHx8ZQqVYoyZcowcuRITmoEl4iIpDOVtMwmd24YPRreeAN694aWLeGHH1yn8p2cOXPy9NNPs2HDBpYtW0bZsmX54IMPXMcSEZFMRCUts7rlFm9aQfHiULo0zJoFGkb+LzfccAPvvfcegwYNom3bttx999189913rmOJiEgmEFAlzRgTa4yZeEh3MaZMjhwwdCgsWgTPPgtNm8I337hO5TvGGJo3b05CQgLFihUjMjKS0aNHc+rUKdfRREQkgAVUSbPWLrLWds6XL5/rKBlLhQqwbZs3qSAqyrvBQGfV/iV37twMGTKENWvW8Pbbb1O+fHnWr1/vOpaIiASogCppcgmyZ4dBg2DZMhgzBurXhy+/dJ3Kl0JDQ3n//ffp3bs3d955Jx06dOAHXdcnIiKpTCVN/i4qCjZtgurVIToaxo+HM2dcp/IdYwytWrUiISGBAgUKEBERwfjx4zl9+rTraCIiEiBU0uTfsmaFvn1hzRpvakGtWvDpp65T+VLevHkZOXIk77//PrNmzaJixYps3rzZdSwREQkAKmny38LC4MMPoXFjqFQJRo0CnSk6p8jISD744AMefvhhmjRpQufOnTl48KDrWCIikoGppEnygoPh0UdhwwZYsMDbuiMx0XUqXzLG0LZtWxITE8mePTthYWFMmjSJM1ouFhGRi6CSJilzww2wahW0bQvVqsFzz4G2oDin/PnzM2bMGN577z0mT55MlSpV2L59u+tYIiKSwaikScoFBcEDD8DWrV5hq1gRdu1yncq3ypYty4cffkjnzp257bbb6NatG7/88ovrWCIikkGopMmFK14cli71hrXXqQMDBsCJE65T+VJQUBAdOnQgISGB06dPExYWxquvvorVPnQiInIeKmlycYyBDh280VLbt3vbdWzd6jqVb1122WWMHz+ehQsXMnbsWGJiYvjss89cxxIRER9TSZNLc9VVsHAh9OkDDRt6Q9t//911Kt+qUKECGzdupE2bNjz22GP06NGDw4cPu44lIiI+pJIml84YuOsu2L0bPv/c2xD3ww9dp/Kt4OBgunTpwtSpUzl8+DChoaHMnDlTS6AiIvI3KmmSegoXhjfegMGD4Y47uGHUKPj1V9epfCt//vxMnjyZuXPnMnz4cGrVqkVCQoLrWCIi4hMqaZL6mjeH+HjMmTMQHg5vvqmB7cmoXLkyW7ZsoXnz5lSvXp1evXpx9OhR17FERMQxlTRJGwUK8EnPnjBnDgwcCLGxGtiejCxZstCtWzfi4uL47rvvCA0N5c0339QSqIhIJqaSJmnrlltgxw6oXNm7A3TkSG2Cm4zChQvz2muvMWPGDJ566inq1avHxx9/7DqWiIg4oJImaS9bNnjiCdi4Ed59FypUgC1bXKfytZiYGLZv3079+vWpWrUqTzzxBL/99pvrWCIiko5U0iT9lCwJy5d7s0BjY+Hhh+HIEdepfCtr1qw8+uij7N69m88//5ywsDAWLFigJVARkUxCJU3SlzHe/M/4eK+ghYV5g9vlPxUtWpRZs2YxefJk+vTpQ6NGjbQRrohIJqCSJm4ULAhTpsD06fD449CsGezf7zqVr9WuXZtdu3YRExNDxYoVGThwIL9r42ARkYClkiZu1ajhbYJbpoy3Ce6LL8Lp065T+Va2bNl4/PHH2bFjB3FxcURERPDOO++4jiUiImlAJU3cy57d26Zj3TqYNw8qVfLuCJX/dPXVVzN37lzGjRtHjx49aNq0Kfv27XMdS0REUpFKmvjHTTfBqlXQtSvUqwc9e4I2dU1WvXr12LNnD+XLlyc6Oppnn32WP/74w3UsERFJBSpp4i/GQIcOEBcHP/wAERGg5bxkZc+enX79+rF161Y2b95MZGQky5Ytcx1LREQuUUCVNGNMrDFm4qFDh1xHkUtVqJB3U8GkSd5WHXfcAd984zqVr1133XW8/fbbPP/883Tp0oU77riD/boZQ0QkwwqokmatXWSt7ZwvXz7XUSS11KkDe/bAjTd6NxeMGwdnzrhO5WuNGjUiPj6esLAwoqKiGDZsGCdOnHAdS0RELlBAlTQJUDlywDPPwOrVMGMGVK3qFTf5Tzly5GDQoEFs3LiRVatWERUVxapVq1zHEhGRC6CSJhlHeDisXQv33gu1akHv3qBRSckqWbIkS5Ys4dlnn6V9+/bcddddfPvtt65jiYhICqikScYSFASdO3tn0r78EiIjYelS16l8zRhDs2bNSEhIoHjx4pQuXZoXXniBUxp0LyLiayppkjFdeSXMmgVjx0KXLnDXXfD9965T+VquXLkYPHgwa9euZfHixZQrV45169a5jiUiIv9BJU0ytgYNvO06rr7aO6v2yiu6seA8brrpJpYvX06/fv1o1aoV7dq143sVXBER31FJk4wvVy4YOhSWL/e27KheHRISXKfyNWMMd955J4mJiRQqVIiIiAjGjh3LaY3kEhHxDZU0CRxlysD69dCqlVfUnnwSjh93ncrX8uTJw/Dhw1m9ejVz586lQoUKbNy40XUsERFBJU0CTXAwPPgg7NwJiYneEuj777tO5Xvh4eGsWrWKnj17cvvtt9OpUyd++ukn17FERDI1lTQJTFddBXPnwvPPe2Om2rWDH390ncrXjDG0adOGxMREcufOTVhYGC+//DJndI2fiIgTKmkS2GJjIT4eChb05oBOmwbWuk7la/ny5eOFF15g+fLlvPbaa1SqVImtW7e6jiUikumopEngy53bO6P27rvelh21asHHH7tO5XtlypRh7dq1PPDAAzRq1IiuXbvy888/u44lIpJpqKRJ5lGuHGzcCE2aeKOlnnoK/vjDdSpfCwoKon379iQmJmKMISwsjKlTp2oJVEQkHaikSeaSJQs88gjs2AHbtkFUFKxZ4zqV7xUoUIBx48bxzjvvMGHCBKpVq8bOnTtdxxIRCWgqaZI5XX01LFgAgwdDmzbQqRNoKe+8oqOj2bBhA+3bt6devXo89NBDHDp0yHUsEZGApJImmZcx0KyZd2NBjhzeAPcZM3RjwXkEBQVx3333ER8fz/HjxwkNDeX111/H6riJiKQqlTSRvHlhzBh4+20YPhzq1YPPPnOdyvcuv/xyJk6cyPz58xk1ahQ1atQgLi7OdSwRkYChkibyp5tvhi1b4NZboWJFeO45OHHCdSrfq1ixIps3b6Zly5bUqlWLxx57jCNHjriOJSKS4amkiZwta1b43/9g61ZYuxaio71RU5Ks4OBgHnjgAeLi4vjpp58IDQ1lzpw5WgIVEbkEKmki51K8OLzzjjf/s0UL6NIFfv3VdSrfK1SoENOmTWP27NkMHjyYW2+9lY8++sh1LBGRDEklTeS/GAN33gkJCd7fh4XBnDm6sSAFbrnlFrZt20ZsbCzVqlWjT58+HDt2zHUsEZEMRSVN5Hzy54fx471ZoE8/DQ0bwhdfuE7le1myZOHhhx9m9+7dfPXVV4SFhTFv3jwtgYqIpJBKmkhKVakC27dDtWpQoYJ3J+jJk65T+V6RIkWYMWMGr776Kk8++SQNGjRg7969rmOJiPieSprIhciWDfr0gU2bYPlyr6xt3uw6VYZQo0YNdu7cSZ06dahcuTL9+/fn999/dx1LRMS3VNJELkaJErB0qXcnaJMm0L07HD7sOpXvZc2alccee4ydO3fy8ccfEx4ezqJFi1zHEhHxJZU0kYtljDdSKj4efv/du7Fg3jzdWJACxYoVY86cObz88ss89thjNG7cmC90nZ+IyN+opIlcqssug0mTYOZMeOIJaNoUvv7adaoM4dZbb2X37t1UqlSJ8uXL8/TTT3P8+HHXsUREfEElTSS1xMTAzp3eBrhly8ILL8Dp065T+V727Nnp27cv27dvZ/v27URGRvLee++5jiUi4pxKmkhqyp4d+veHDz/0ZoFWrOjdESrnde211zJ//nxGjx5Nt27d6N+/P1999ZXrWCIizqikiaSFG2+ElSuhWzdo0AAefRSOHnWdKkO47bbbiIuLo0SJEpQrV44hQ4ZwQjNURSQTUkkTSSvGQPv2EBcHP/8M4eGgOxlTJCQkhHbt2rF582bWrVtH6dKlef/9913HEhFJVyppImntiitg2jSYOhV69oTmzeHAAdepMoTrr7+eRYsWMWzYMDp16kSrVq04oGMnIpmESppIeqlVC3bv9s6oRUVx1dy5cOqU61S+Z4yhcePGxMfHU7JkScqUKcPIkSM5qWkPIhLgVNJE0lNICDz1FKxZw+UbNkBUFKxa5TpVhpAzZ06eeeYZ1q9fz9KlSylbtiwffPCB61giImlGJU3EhdBQdo0Y4RW2e++FO+8E3cmYIqVKlWLp0qUMHDiQu+++m7Zt2/Ldd9+5jiUikupU0kRcMQZuvx0SErwl0HLl4OmnvekFkixjDC1atCAxMZGiRYsSGRnJmDFjOKXlYxEJICppIq7lzAkDBsDWrbBrl1fYFizQeKkUyJ07N0OHDmXNmjXMnz+fChUqsH79etexRERShUqaiF8ULw5z58LEid54qfr1ITHRdaoMITQ0lPfff59evXpxxx130KFDB3788UfXsURELolKmojf1KnjjZdq0MAbNdWzJxw+7DqV7xljaN26NYmJieTPn5/w8HDGjx/PaY3mEpEMSiVNxI+yZoVHHoH4eDh0CG66ydtr7cwZ18l8L2/evDz//PO8//77zJw5k0qVKrFlyxbXsURELpjvS5ox5npjzGRjzFzXWUTSXaFCMGmSNwd0/HioUgVUOFIkMjKSNWvW0L17dxo3bsz999/PwYMHXccSEUmxNC1pxpgpxpgfjDFx/3i+vjHmY2PMp8aY3sm9h7X2c2ttx7TMKeJ7FSrAhg3QpQs0bgydOsEPP7hO5XvGGO655x4SExPJli0b4eHhTJ48mTM6IykiGUBan0mbBtQ/+wljTDDwEtAACANaG2PCjDGRxpjF/3gUSuN8IhlHUJA3C/SjjyBfPu8u0NGjQTvvn1f+/PkZM2YMS5YsYdKkSVStWpUdO3a4jiUikixj/+M2f2PM+9ba2saYodbaxy/6A4wpDiy21kYkfV0ZGGitrZf0dR8Aa+1z53mfudbaFsl8vzPQGaBw4cLRs2fPvtjIKXL06FFy586dpp+R0ekYJe9Sj0/OL7+k5JgxZD94kL3duvFrdHQqpnMvrf78nDlzhnfffZfJkydTo0YNOnTokGH/nOqfseTp+JyfjlHy0uv41KxZc5u1tvy/vmGtPecDSACqAIlAWaDc2Y//et053qc4EHfW1y2ASWd93RYYm8zrCwITgM+APin5zOjoaJvWVq1aleafkdHpGCUvVY7PmTPWzptnbfHi1jZvbu2+fZf+nj6R1n9+Dh48aO+//3575ZVX2ldffdWeOXMmTT8vLeifseTp+JyfjlHy0uv4AFvtOfpMcsud/YEngWLAyH88Rlx8X7ww1tqD1tou1toS9jxn20QyHWOgWTNvakHp0t7UgkGDNLUgBS677DImTJjAwoULGTNmDDExMezZs8d1LBGRv/xnSbPWzrXWNgCGWWtrWWtrnvWodQmfeQC4+qyviyU9JyIXK0cO6N8ftm+HuDgIC4N58zS1IAUqVKjAxo0badOmDbVr16ZHjx4c1r50IuID571xwFr7dCp/5hbgBmPMdcaYbEArYGEqf4ZI5nTttfDmmzB5slfa6tb1zrJJsoKDg+nSpQvx8fEcPnyY0NBQZs2a9eclFyIiTqT1FhyzgA3AjcaY/caYjtbaU0A3YCne9W5vWGvj0zKHSKZTqxbs2AGxsVC9Ojz6qLcpriTriiuuYPLkybz55psMHTqU2rVrk6CSKyKO/GdJM8Zcd6lvbq1tba0tYq3Naq0tZq2dnPT8EmttqaTrzJ691M8RkXPImhUeesibWnDkiDe1YOpUTS1IgSpVqrB161aaNWtG9erVefzxxzl69KjrWCKSySR3Jm0ueFtxpFOWS2aMiTXGTDykMwYi/69QIXjlFVi40BveXrkybN7sOpXvZcmShe7du7Nnzx6+/fZbwsLCmDt3rpZARSTdJFfSgowxfYFSxphH//lIr4AXwlq7yFrbOV++fK6jiPhPhQrw4YfwwAPQtCl06ADff+86le9deeWVvPbaa7z++usMHDiQ+vXr88knn7iOJSKZQHIlrRVwGsgC5DnHQ0QymqAgaNfOm1pQsCBERMCoUZpakAIxMTHs2LGDevXqUaVKFfr168dvv/3mOpaIBLDktuD42Fo7FOhgrR30z0c6ZhSR1JY3LwwfDmvXwnvvQZkysGKF61S+lzVrVh599FF27drFp59+SlhYGG+//baWQEUkTaTk7s71xpjnjTFbkx4jjTFaTxQJBDfd5JW0556Dzp2heXPYt891Kt+76qqrmD17NpMnT6Z3797Exsby+eefu44lIgEmJSVtCnAEuDPpcRiYmpahRCQdGQNNmnj7qZUtC9HRMGAAaCnvvGrXrs2uXbuoVq0aN998M4MGDeL48eOuY4lIgEhJSSthrR1grf086TEIuD6tg4lIOgsJgX79vP3VPvrIm1rw1luaWnAe2bJl4/HHH2f79u3s2bOHiIgIlixZ4jqWiASAlJS0340xt/z5hTGmKuDLwYDagkMkFVxzDcyZA9OmwcCBcOut3l5rkqxrrrmGuXPnMnbsWB5++GGaNWvGl19+6TqWiGRgKSlpXYCXjDH7jDH7gLHA/Wma6iJpCw6RVFSjhndWrWlTqFkTHnkEfv3VbaYMoH79+uzZs4fo6Giio6MZPHgwf/zxh+tYIpIBpWR25y5rbRmgNFDaWlvWWrs77aOJiHNZskC3bt6ZtN9/h9BQby6ophYkKyQkhH79+rFlyxY2bdpE6dKlWb58uetYIpLBpHh2p7X2sLX2cFqGERGfuuIKePllWLzYK2kVK8KmTa5T+d51113H22+/zciRI7n//vu588472b9/v+tYIpJBpOmAdREJMNHR3tSChx6C22+He++F775zncr3GjVqRHx8PDfddBNRUVEMHz6ck9pAWETOQyVNRC6MMdC2rXcH6BVXQGQkPP+8phacR44cOXjqqafYuHEjK1euJCoqitWrV7uOJSI+dt6SZozJaYx50hjzStLXNxhjGqV9NBHxtTx5YNgwWLcOli+H0qW9v0qySpYsyZIlS3jmmWdo164dbdq04dtvv3UdS0R8KCVn0qYCfwCVk74+ADyTZolEJGO58UZYssQrbF26QLNm8MUXrlP5mjGGZs2akZCQwLXXXkvp0qV54YUXOHXqlOtoIuIjKd3MdhhwEsBa+xtg0jTVRdI+aSKOGAOxsd5doBUqeI/+/TW14Dxy5crF4MGDWbt2LYsXLyY6OpoPP/zQdSwR8YmUlLQTxpgcgAUwxpTAO7PmO9onTcSxkBDo29fbX23vXm/Ljjff1NSC87jppptYvnw5TzzxBK1ataJ9+/b88MMPrmOJiGMpKWkDgPeAq40xM4D3gV5pmkpEMrarr4ZZs+C11+Dpp6F2bYiLc53K14wx3HnnnSQkJHD55ZcTERHBuHHjOH36tOtoIuJISjazXQ7cDrQHZgHlrbWr0zaWiASE6tVh+3Zo3hxq1fK27vjlF9epfC1PnjyMGDGClStXMmfOHG6++WY2aU86kUwpJXd3lgOuBb4FvgGuMcaUMMZkSetwIhIAsmSBBx+EhAQ4ccJbAp00CXSGKFkRERGsXr2aHj160KxZM+677z5++ukn17FEJB2lZLlzHLARmAi8AmwA3gQ+NsbUTcNsIhJILr8cJkyAd9/1hrdXrAgbNrhO5WvGGO6++24SExPJmTMn4eHhTJw4kTMayyWSKaSkpH0DlLXWlrfWRgNlgc+BW4FhaRlORAJQ2bKwdi306AF33AHt2mlqwXnky5eP0aNHs2zZMl599VUqV67Mtm3bXMcSkTSWkpJWylob/+cX1toE4CZr7edpF0tEApox0KYNJCZCkSIQEQEjRnjLofKfypQpw9q1a+natSsNGzZk1KhR/KJr/EQCVkpKWrwxZrwxpnrSYxyQYIzJTtLeaSIiFyVPHhgyxFv2XLXKm1qwdKnrVL4WFBRE+/btSUxMBCAsLIxp06ZpCVQkAKWkpLUHPgUeSXp8nvTcSaBm2sQSkUzlhhvgnXdg5Ejo1g2aNiXkm29cp/K1AgUK0KNHDxYvXsz48eOJiYlh165drmOJSCpKyRYcv1trR1prmyU9Rlhrf7PWnrHWHk2PkCmliQMiGVzDht5+apUqEd21qzdmSiOmkhUdHc2GDRu45557qFu3Lo888gj6d6BIYEjJFhxVjTHLjTGfGGM+//ORHuEulCYOiASA7Nmhd282v/aad0dohQpw773eBAM5p6CgIDp37kx8fDzHjh0jNDSUGTNmYDXpQSRDS8ly52TgeeAWoMJZDxGRNHMyXz545hn49FO4/nqoWhXuusubDyrndPnll/PKK68wb948Ro4cSc2aNYnX8RLJsFJS0g5Za9+11v5grT345yPNk4mIAOTPD08+CZ99BmXKeCOmmjf35oPKOVWqVIktW7Zwxx13UKNGDR577DGOHDniOpaIXKCUlLRVxpjhxpjKxphyfz7SPJmIyNny5IHHH/fKWrVq0KgRxMaCRiadU3BwMA8++CDx8fH89NNPhIWF8cYbb2gJVCQDSUlJqwiUBwYDI5MeI9IylIjIf8qVCx55xCtrt90Gd94Jdet6G+TKvxQqVIhp06Yxa9YsnnnmGerWrcvHH3/sOpaIpEBK7u6seY5HrfQIJyLyn0JCoGtX74aCli29mwuqV4cVK0Bni/7llltuYfv27TRs2JCqVavSt29fjh075jqWiCQjJWfSMMY0NMb0Msb0//OR1sFERFIkWzbo2BE++gjuuw+6d4cqVbx911TW/iZLliw88sgj7N69my+//JKwsDDmz5+vJVARn0rJFhwTgJZAd8AAdwDXpnEuEZELkyUL3H23t8/ao49C374QHQ3z5oF24/+bokWLMmPGDKZNm8YTTzxBw4YN+fTTT13HEpF/SMmZtCrW2nuAX6y1g4DKQKm0jSUicpGCg73B7Tt2wIAB8Nxz3l2hs2fD6dOu0/lKzZo12blzJzVr1qRSpUoMGDCA33//3XUsEUmSkpL25z+xvxljiuKNgyqSdpFERFJBUBA0aQKbN8Pw4TBmDISFwauvwkmNHf5TtmzZ+N///sfOnTtJTEwkPDycxYsXu44lIqSspC02xuQHhgPbgX3ArDTMJCKSeoyB+vVh3TqYMMEraTfeCBMnwh9/uE7nG8WKFeONN95gwoQJPProozRp0oQvNJJLxKmU3N35tLX2V2vtW3jXot1krX0y7aNdOM3uFJH/ZAzUrAkrV8L06TB/vjfYfexY0BLfX+rWrcuePXuoWLEiFSpU4JlnnuEPlVkRJ1J6d2cVY8xdeDcQNDHG3JO2sS6OZneKSIpUrQrvvgtvveVt2VGiBIwcCUePuk7mC9mzZ6dv375s3bqVbdu2ERkZydKlS13HEsl0UnJ353S8zWvPnt1ZPo1ziYikvQoVYMECr7Bt2uSVtcGD4fBh18l8oXjx4syfP59Ro0bxwAMP0KJFC77++mvXsUQyjZScSSsPVLXWPmCt7Z70eCitg4mIpJsyZeCNN2D1akhM9Aa6DxgAP//sOpkvNGzYkLi4OCIjIylbtixDhw7lxIkTrmOJBLyUlLQ44Mq0DiIi4lxoqHe92saNcOCAd81anz7www+ukzmXI0cOBgwYwKZNm1izZg1lypRh5cqVrmOJBLT/LGnGmEXGmIXA5UCCMWapMWbhn4/0iygiks5KloRJk2D7dm/p86abvA1yv/3WdTLnSpQoweLFixkyZAgdOnSgdevWfPPNN65jiQSk5M6kjcAbpj4QaMrfB6yPTOtgIiLOXXstvPSSN8XAWggPhwcfhK++cp3MKWMMTZo0ISEhgeuvv57SpUvz/PPPc1L7z4mkquRK2gHglLX2g7MfwGlgf/rEExHxgaJFYdQobz5onjxQtix06gSffeY6mVM5c+bk2WefZf369bz33nuUK1eONWvWuI4lEjCSK2kvAOe6xelQ0vdERDKXQoVgyBD45BO46iqoWBHuuccrb5lYqVKlWLp0KQMGDKBNmzbcc889fP/9965jiWR4yZW0wtbaPf98Mum54mmWSETE7woWhEGDvDNpN90E1atDy5awe7frZM4YY2jRogWJiYkUKVKEiIgIxowZw6lTp1xHE8mwkitp+ZP5Xo5UziEikvHkywd9+3plrUIFqFcPmjaFbdtcJ3Mmd+7cDB06lA8++IB58+ZRoUIFNmzY4DqWSIaUXEnbaoy5759PGmM6AZn330AiIv+UOzc89hh8/jnUru0Vtdtug/XrXSdzJiwsjJUrV9KrVy9atGhBx44d+fHHH13HEslQkitpjwD3GmNWG2NGJj0+ADoCD6dLOhGRjCRHDujeHT791Ctqbdp4pW3VKu/u0EzGGEPr1q1JTEwkb968hIeHM2HCBE6fPu06mkiG8J8lzVr7vbW2CjAI2Jf0GGStrWyt/S594omIZEDZs0Pnzt4NBm3bwv33Q7VqsHRppixrefPmZdSoUaxYsYIZM2ZQqVIltmzZ4jqWiO+dd+KAtXaVtXZM0sPX20sbY2KNMRMPHTrkOoqICGTNCu3be6OmHnwQevb07ghduDBTlrXSpUuzZs0aunXrRuPGjenSpQs/a/SWyH9KyVioDMNau8ha2zlfvnyuo4iI/L/gYGjd2rv7s3dvGDgQoqLgzTfhzBnX6dKVMYZ27dqRmJhIlixZCAsLY/LkyZzJZMdBJCUCqqSJiPhaUBDcfrt39+fgwTByJEREwOuvQybbqiJ//vyMHTuWJUuW8Morr3DLLbewY8cO17FEfEUlTUQkvRkDDRvChg0wejRMnOgNd58yBU6ccJ0uXZUrV47169fTsWNH6tevT/fu3fn1119dxxLxBZU0ERFXjIFbb4U1a2DyZJg1C0qVgvHj4fhx1+nSTVBQEB07diQhIYETJ04QGhrKa6+9hs2E1+2JnE0lTUTED2JiYPlymD0b3nkHSpSAF16A335znSzdFCxYkJdffpm3336bF198kerVq7Nnz78G34hkGippIiJ+UqkSLF7sPdauheuvh6FD4cgR18nSzc0338ymTZto3bo1tWvXpmfPnhw+fK5R0iKBTSVNRMSPypaFt96CFStg507vzNrTT0MmuV4rODiYrl27Eh8fzy+//EJYWBizZ8/WEqhkKippIiJ+FhHhXau2dq03I7RkSejXD376yXWydHHFFVcwZcoU5syZw5AhQ6hTpw6JiYmuY4mkC5U0EZGM4MYbYdo02LwZfvwRbryR4lOnZppr1qpWrcrWrVtp0qQJMTExPP744xw9etR1LJE0pZImIpKRXH89vPwy7NhBzq+/hrAwmDcvU0wwyJIlCw899BB79uzhm2++ISwsjLfeektLoBKwVNJERDKia64hoX9/mDoV+veHevXgo49cp0oXV155JdOnT2f69OkMGDCA+vXrs3fvXtexRFKdSpqISEZWsybs2AG33eYNce/VK9PcCVq9enV27NhB3bp1qVy5Mv369eO3TLL8K5mDSpqISEaXNSs88gjExXnXq4WGwowZmWIJNGvWrPTs2ZNdu3bx6aefEh4ezsKFC13HEkkVKmkiIoGicGFv+fPNN+H556F6ddi1y3WqdHHVVVcxe/ZsXnnlFXr16kVsbCzffPON61gil0QlTUQk0FSu7N0F2qYN1K0L3bvDL7+4TpUu6tSpw+7du6latSpdu3blqaee4ngmGrElgUUlTUQkEAUHw/33Q0ICnD7tLYFOmgRnzrhOluayZctG7969mThxIjt37iQiIoJ3333XdSyRC6aSJiISyAoWhHHjYMkSbym0UiXvLFsmULhwYebNm8eYMWPo3r07zZo148svv3QdSyTFAqqkGWNijTETDx065DqKiIi/lCsH69Z5S59Nm0KnTvDDD65TpYsGDRoQFxdHuXLliI6O5rnnnuPEiROuY4mcV0CVNGvtImtt53z58rmOIiLiP8ZA27aQmAj58kF4OIwZA6dOuU6W5kJCQnjyySfZvHkz69evp3Tp0qxYscJ1LJFkBVRJExGRFMiXD0aOhNWrYcEC7yzbmjWuU6WL66+/nkWLFjF8+HDuu+8+WrZsyf79+13HEjknlTQRkcwqPBxWrPAmFtx9t3c36IEDrlOli9jYWOLj47nxxhuJiopixIgRnDx50nUskb9RSRMRycyMgRYtvCXQ666DMmVg2DDIBNds5cyZk6eeeooNGzawYsUKoqKiWL16tetYIn9RSRMREciVC555BjZu9JY+IyNh2TLXqdLFDTfcwLvvvstTTz3FPffcw9133823337rOpaISpqIiJylZElYvNi7Zu2BB+D222HfPtep0pwxhubNm5OYmEixYsWIjIxk9OjRnMoEN1WIf6mkiYjIvzVq5M0CjY6G8uVh0CD4/XfXqdJcrly5GDJkCGvXrmXhwoVER0fz4Ycfuo4lmZRKmoiInFtICDzxBGzf7hW2sDB4++1MMbg9NDSUFStW0LdvX1q2bMm9997LD5lkXznxD5U0ERFJ3jXXeEPbJ02CPn3gttvgk09cp0pzxhhatmxJYmIiBQsWJCIignHjxnH69GnX0SSTUEkTEZGUqV0bdu2CW2+FKlWgd284etR1qjSXJ08eRowYwcqVK5kzZw4333wzmzZtch1LMgGVNBERSbmsWeHRR2HPHvjmG29w++zZmWIJNCIigtWrV/PII4/QtGlTOnfuzMGDB13HkgCmkiYiIheuSBF47TWvoA0dCjVresUtwBljaNu2LYmJiYSEhBAWFsYrr7zCmTNnXEeTAKSSJiIiF69qVdi6FVq29JZDH34Yfv3Vdao0lz9/fl588UWWLl3K1KlTqVKlCtu3b3cdSwKMSpqIiFya4GDo2hUSEuD4cW8JdOpUyARnl6Kioli3bh2dO3fmtttu48EHH+SXX35xHUsChEqaiIikjssvh5df9jbDffll7+aCrVtdp0pzQUFBdOjQgYSEBM6cOUNYWBjTpk3TEqhcMpU0ERFJXdHRsH49dOkCsbHQuTP89JPrVGnusssuY/z48SxcuJCXXnqJmJgYdu/e7TqWZGAqaSIikvqCgqB9e29we86c3ka448ZBJthjrEKFCmzcuJG2bdtSp04dHnnkEQ4dOuQ6lmRAKmkiIpJ28ueHF16AlSu9DXHLl4d161ynSnPBwcHcf//9xMfHc/ToUUJDQ5kxYwY2E2xVIqlHJU1ERNJeRIRX1Hr3htatoW1b+PZb16nS3BVXXMGkSZN46623GDFiBLVq1SIhIcF1LMkgVNJERCR9GONt1ZGYCMWKQWQkjBwJJ0+6TpbmKleuzNatW2nevDnVq1enV69eHM0E0xrk0qikiYhI+sqdG557zru5YMUKKFPG+2uACw4Oplu3bsTFxfHdd98RGhrKm2++qSVQ+U8qaSIi4kapUrBkCQwZ4t0B2qIFfPml61RprnDhwrz22mvMmDGDp556inr16vHxxx+7jiU+pJImIiLuGAONG0N8vHdGLToannnG2xQ3wMXExLB9+3YaNGhA1apV6du3L8eOHXMdS3xEJU1ERNzLkQOefNLb/HbHDggP9zbFDXBZs2alR48e7N69m3379hEeHs6CBQu0BCqASpqIiPhJ8eLw1lswfjw89hg0bAh797pOleaKFi3KzJkzmTJlCn369KFRo0Z89tlnrmOJYwFV0owxscaYido0UEQkg6tbF3bvhpo1oXJleOIJyARLgbVq1WLXrl3ExMRQsWJFBg4cyO+//+46ljgSUCXNWrvIWts5X758rqOIiMilypbNO5u2e7d3Q0FoqLchboAvBWbLlo3HH3+cHTt2EBcXR0REBO+8847rWOJAQJU0EREJQEWLwuuve49nnoHatb0bDQLc1Vdfzdy5cxk3bhw9evSgadOm7Nu3z3UsSUcqaSIikjHExMC2bXD77d4y6KOPQia4vKVevXrs2bOH8uXLEx0dzbPPPssff/zhOpakA5U0ERHJOLJkgW7dvDNpR454S6CvvgpnzrhOlqayZ89Ov3792LZtG5s3byYyMpJly5a5jiVpTCVNREQyniuugFdegQUL4KWX4JZbYPt216nSXPHixXn77bd5/vnn6dKlC3fccQf79+93HUvSiEqaiIhkXDffDBs3QseOcNtt0LUrHDzoOlWaa9SoEfHx8YSFhREVFcWwYcM4ceKE61iSylTSREQkYwsK8kpaYiJkzQphYTBhApw+7TpZmsqRIweDBg1i48aNrFq1iqioKFatWuU6lqQilTQREQkMBQrAiy/C8uUwaxblunWDTLAUWLJkSZYsWcKzzz5L+/btueuuu/jmm29cx5JUoJImIiKBpXRpWL2aH2NivI1wd+50nSjNGWNo1qwZCQkJFC9enNKlSzNq1ChOnjzpOppcApU0EREJPMbwdevWMGqUN71gyRLXidJFrly5GDx4MOvWreOdd94hOjqatWvXuo4lF0klTUREAleLFrBwIXTqBOPGuU6Tbm666SaWL19Ov379aN26Ne3ateP77793HUsukEqaiIgEtkqVYN06GDMGevYM+BsK/mSM4c477yQxMZFChQoRERHB2LFjOZ1Jfv9AoJImIiKB7/rrYf16by+1O+6A335znSjd5MmTh+HDh7N69Wrmzp1LhQoV2Lhxo+tYkgIqaSIikjkUKABLl0KePFCjBnz3netE6So8PJxVq1bRs2dPbr/9djp16sShTDBWKyNTSRMRkcwjWzaYNg0aNfLu/MwEg9rPZoyhTZs2JCYmkitXLtq3b8/LL7+sJVCfUkkTEZHMxRjo3x+efhpq1YL333edKN3ly5eP0aNHM3z4cF577TUqV67M1q1bXceSf1BJExGRzOnuu+HNN6FNG5gyxXUaJ0qWLMnatWt54IEHaNSoEV27duXnn392HUuSqKSJiEjmFRMDH3wAgwfDE0/AmTOuE6W7oKAg2rdvT2JiIsYYwsLCmDp1Kmcy4bHwG5U0ERHJ3G68ETZsgNWrvbNqx4+7TuREgQIFGDduHO+88w4TJkygWrVq7MwE0xr8TCVNRETkiiu8a9POnIE6deCnn1wnciY6OpoNGzbQvn176tWrx0MPPaS7QB1RSRMREQEICYFZs7wl0MqVYe9e14mcCQoK4r777iM+Pp7jx48TGhrK9OnTsda6jpapqKSJiIj8KSjIuz7t8cehWjXI5HMvL7/8ciZOnMj8+fMZNWoUNWrUIC4uznWsTEMlTURE5J86dYLp06F5c5g503Ua5ypWrMiWLVu48847qVmzJj179uTIkSOuYwU8lTQREZFzufVWWLkS+vaFZ56BTL7UFxwczIMPPkh8fDwHDx4kNDSUOXPmaAk0DamkiYiI/JeICO/OzwULoEMHOHHCdSLnChUqxLRp05g9ezaDBw/m1ltv5aOPPnIdKyCppImIiCSnSBFvL7VffoEGDeDXX10n8oVbbrmFbdu2ERsbS7Vq1ejTpw/Hjh1zHSugqKSJiIicT65c8NZbULo0VKkCX3zhOpEvZMmShYcffpjdu3fz1VdfERYWxrx587QEmkpU0kRERFIiOBhGjYIHHoCqVWHTJteJfKNIkSLMmDGDadOm0a9fPxo0aMDeTLyFSWpRSRMREbkQ3brBxInQqJF3dk3+UrNmTXbu3Ent2rWpXLky/fv35/fff3cdK8NSSRMREblQjRrB0qXw8MMwYkSmv/PzbNmyZeN///sfO3fu5KOPPiI8PJxFixa5jpUhqaSJiIhcjHLlvDs/X3sNunaFU6dcJ/KVYsWK8cYbbzBhwgQee+wxGjduzBe6lu+CqKSJiIhcrKuvhnXr4MsvITYWDh92nch36taty+7du6lUqRLly5fn6aef5ngmHWJ/oVTSRERELkXevLBoEVx7rTdK6uuvXSfynezZs9O3b1+2b9/O9u3biYyM5L333nMdy/dU0kRERC5Vliwwfjy0bett0bFjh+tEvnTttdcyf/58Ro8eTbdu3WjevDlfffWV61i+pZImIiKSGoyBxx6DF16AunVh8WLXiXzrtttuIy4ujtKlS1O2bFmGDBnCCU1z+BeVNBERkdTUvLm3/HnffTB2rOs0vhUSEsKAAQPYvHkza9eupXTp0rz//vuuY/mKSpqIiEhqq1QJ1q+Hl16CHj3g9GnXiXyrRIkSLF68mKFDh9KxY0datWrFgQMHXMfyBZU0ERGRtHDddV5R27XLO7umuZb/yRhDkyZNSEhIoGTJkpQpU4aRI0dy8uRJ19GcUkkTERFJKwUKwHvvQf78UKMGfPed60S+ljNnTp555hnWr1/P0qVLKVu2LB988IHrWM74vqQZY5oaY14xxswxxtR1nUdEROSCZMsGU6dC48beMmhcnOtEvleqVCmWLl3KwIEDufvuu2nbti3fZcKCm6YlzRgzxRjzgzEm7h/P1zfGfGyM+dQY0zu597DWLrDW3gd0AVqmZV4REZE0YQw8+SQ8+yzUqgXLl7tO5HvGGFq0aEFiYiJFixYlMjKSF198kVOZaLJDWp9JmwbUP/sJY0ww8BLQAAgDWhtjwowxkcaYxf94FDrrpf2SXiciIpIxtWkDc+d6+6lNnuw6TYaQO3duhg4dygcffMD8+fOpUKEC69evdx0rXRibxkNhjTHFgcXW2oikrysDA6219ZK+7gNgrX3uP15vgCHAcmvtimQ+pzPQGaBw4cLRs2fPTs1f41+OHj1K7ty50/QzMjodo+Tp+CRPx+f8dIyS5+fjk+Prrynduzc/1KjBFx07QpCbq4/8fIzOxVrLypUrmTBhAuXLl+f+++8nf/78afZ56XV8atasuc1aW/5f37DWpukDKA7EnfV1C2DSWV+3BcYm8/qHgG3ABKBLSj4zOjraprVVq1al+WdkdDpGydPxSZ6Oz/npGCXP98fnxx+trVLF2pYtrf39dycRfH+M/sOhQ4dsjx497BVXXGHHjRtnT506lSafk17HB9hqz9FnfH/jgLX2RWtttLW2i7V2gus8IiIiqeLyy+HPzVtr14Yff3SbJwPJmzcvzz//PCtWrGDmzJlUqlSJLVu2uI6V6lyUtAPA1Wd9XSzpORERkcwlJARmzvS256hcGT7+2HWiDKV06dKsWbOG7t2707hxY+6//34OHjzoOlaqcVHStgA3GGOuM8ZkA1oBCx3kEBERcS8oyLvrs08fiImBNWtcJ8pQjDHcc889JCYmki1bNsLCwpg0aRJnzpxxHe2SpfUWHLOADcCNxpj9xpiO1tpTQDdgKZAIvGGtjU/LHCIiIr7XsSPMmAEtWnh/lQuSP39+xowZw7vvvsvkyZOpWrUqO3bscB3rkmRJyze31rb+j+eXAEvS8rNFREQynDp1YNUqaNgQPvvM21vNGNepMpRy5crx4YcfMnXqVOrXr8+dd97J008/naZ3gaYV3984cCGMMbHGmImHDh1yHUVEROTihIfDxo2waBHcey+cOOE6UYYTFBREx44dSUhI4MSJE4SGhvLaa6/9uWtEhhFQJc1au8ha2zlfvnyuo4iIiFy8K6+E1avh11+hXj345RfXiTKkggUL8vLLL/P222/z4osvEhMTw549e1zHSrGAKmkiIiIBI1cueOstKFsWqlSBzz93nSjDuvnmm9m0aRNt2rShdu3a9OjRg8OHD7uOdV4qaSIiIn4VHAzPPw/dukHVqt4yqFyU4OBgunTpQnx8PIcPHyY0NJRZs2b5eglUJU1ERMTvHnwQJk2C2Fhv9qdctCuuuILJkyfz5ptvMnToUGrXrk1CQoLrWOekkiYiIpIRNGwIy5ZBjx4wfDj4+AxQRlClShW2bt1K06ZNqV69Oo8//jhHjx51HetvVNJEREQyirJlYcMGeP116NoVTp1ynShDy5IlCw899BB79uzhm2++ISwsjLlz5/pmCTSgSpq24BARkYBXrBisWwdffgmNGkEGuADe76688kqmT5/O66+/zsCBA6lfvz6ffPKJ61iBVdK0BYeIiGQKefJ4+6hddx3ccgt8/bXrRAEhJiaGHTt2ULduXapUqcKUKVOcnlULqJImIiKSaWTJAuPGQbt23nD27dtdJwoIWbNmpWfPnuzatYsiRYpgHE58UEkTERHJqIyBnj1h9Ghv09vFi10nChhXXXUVDRo0cJpBJU1ERCSja97cK2idO8OYMa7TSCpRSRMREQkEFSvChx/C+PHwyCNw+rTrRHKJVNJEREQCxXXXeUVt9264/XY4dsx1IrkEKmkiIiKBpEABeO89uOwyqF4dvv3WdSK5SCppIiIigSZbNpgyBZo29e78jItznUguQkCVNG1mKyIiksQY6NcPBg+GWrW8kVKSoQRUSdNmtiIiIv9w113w1ltwzz3ekHbJMLK4DiAiIiJprFo1WLPGG9L+2Wfw7LMQFFDnaQKS/hcSERHJDEqV8oazr10LrVrB77+7TiTnoZImIiKSWVx+OaxYAcHBULs2IQcOuE4kyVBJExERyUxCQmDGDGjYkHIPPgg1asC0aXD0qOtk8g8qaSIiIplNUBA88QQb3ngDHnrIu7GgWDG4917v2jVrXScUVNJEREQyLZstmzeZYNEi+OgjCA+Hrl2hZEl4+mn46ivXETM1lTQRERGBK6+Exx7zNr6dPdubVFC2LNSp4y2P/vab64SZjkqaiIiI/D9joEIFGDcODhyA++6D11/3lkM7d4b167Ucmk4CqqRp4oCIiEgqCgmBli3h3Xdhzx64/nrvurWbboLnnvNKnKSZgCppmjggIiKSRq66Cnr39q5dmzoVvvgCIiOhQQOYMweOH3edMOAEVEkTERGRNGYMVKkCEyfC/v1w993wyiteiXvgAdiyRcuhqUQlTURERC5OzpzQpo23Qe727VCkiDfNIDISRoyA775znTBDU0kTERGRS3fttfDkk/Dpp95NB/Hx3rVrsbEwbx6cOOE6YYajkiYiIiKpxxiIifGuW9u/H5o3hxdf9JZDH34YduxwnTDDUEkTERGRtJE7N7RvD6tXw8aNkD8/NG0KUVEwejT8+KPTeH6nkiYiIiJpr0QJGDTIuyt05EjYuhVuuMGbeLBwIZw86Tqh76ikiYiISPoJCoLatWH6dPjyS7jtNhg6FK6+Gnr29CYeCKCSJiIiIq7kywedOsGHH3qD3bNnh/r1oXx5eOkl+Pln1wmdUkkTERER90qVgsGDvbNrzz4La9fCddfBnXd6Ew9OnXKdMN0FVEnTWCgREZEMLjgY6tXzhrzv2wc1a8LAgd4WH39OPMgkAqqkaSyUiIhIAClQALp2hU2bYNkyOH3aK22VK3sTDwL8pExAlTQREREJUOHhMHw4fP01PPGEV9quvdabeLB8uVfgAoxKmoiIiGQcWbJAo0Ywd6433aBSJXj8ce/6tX79vOcChEqaiIiIZEyXXw7du3tzQxctgmPHvOHv1arBlClw5IjrhJdEJU1EREQyvjJlYNQobxRVz57w9tve3mvt2nkTD86ccZ3wgqmkiYiISODIls0bPfX22/Dxx155694dSpb0Jh7s2+c6YYqppImIiEhgKlwYHn0Udu+GN9/0ZoWWLw+1ankTD44dc50wWSppIiIiEtiMgehoGDsWDhzwtvWYPRuKFfMmHqxbB9a6TvkvKmkiIiKSeWTPDnfcAe+8A/Hx3qSD++7z/vrss94WHz6hkiYiIiKZU9Gi0KsXJCR4y59ff+1dw1avHsyaRdAffziNl8Xpp4uIiIi4Zoy331qlSt4dogsWwNSpRH39NSQmOoulM2kiIiIif8qRA1q3hmXL2PnCC06jqKSJiIiInMOZ7Nmdfn5AlTRjTKwxZuKhAB+4KiIiIoEvoEqatXaRtbZzvnz5XEcRERERuSQBVdJEREREAoVKmoiIiIgPqaSJiIiI+JBKmoiIiIgPqaSJiIiI+JBKmoiIiIgPqaSJiIiI+JBKmoiIiIgPqaSJiIiI+JBKmoiIiIgPqaSJiIiI+JBKmoiIiIgPqaSJiIiI+JCx1rrOkOqMMT8CX6bxx1wO/JTGn5HR6RglT8cneTo+56djlDwdn/PTMUpeeh2fa621V/zzyYAsaenBGLPVWlvedQ4/0zFKno5P8nR8zk/HKHk6PuenY5Q818dHy50iIiIiPqSSJiIiIuJDKmkXb6LrABmAjlHydHySp+NzfjpGydPxOT8do+Q5PT66Jk1ERETEh3QmTURERMSHVNJEREREfEgl7QIZY642xqwyxiQYY+KNMQ+7zuQnxpgQY8xmY8yupOMzyHUmPzLGBBtjdhhjFrvO4kfGmH3GmD3GmJ3GmK2u8/iNMSa/MWauMeYjY0yiMaay60x+Yoy5MenPzp+Pw8aYR1zn8hNjTI+kf0fHGWNmGWNCXGfyG2PMw0nHJ97Vnx9dk3aBjDFFgCLW2u3GmDzANqCptTbBcTRfMMYYIJe19qgxJiuwDnjYWrvRcTRfMcY8CpQH8lprG7nO4zfGmH1AeWutNtk8B2PMq8Baa+0kY0w2IKe19lfHsXzJGBMMHAAqWmvTepPzDMEYcxXev5vDrLW/G2PeAJZYa6e5TeYfxpgIYDZwM3ACeA/oYq39ND1z6EzaBbLWfmut3Z7090eAROAqt6n8w3qOJn2ZNemh/xI4izGmGNAQmOQ6i2Q8xph8QAwwGcBae0IFLVm1gc9U0P4lC5DDGJMFyAl84ziP34QCm6y1v1lrTwEfALendwiVtEtgjCkOlAU2OY7iK0lLeTuBH4Dl1lodn797AegFnHGcw88ssMwYs80Y09l1GJ+5DvgRmJq0ZD7JGJPLdSgfawXMch3CT6y1B4ARwFfAt8Aha+0yt6l8Jw6oZowpaIzJCdwGXJ3eIVTSLpIxJjfwFvCItfaw6zx+Yq09ba2NAooBNyedNhbAGNMI+MFau811Fp+7xVpbDmgAPGiMiXEdyEeyAOWA8dbassAxoLfbSP6UtBTcGHjTdRY/McYUAJrgFf6iQC5jzN1uU/mLtTYRGAosw1vq3AmcTu8cKmkXIelaq7eAGdbaea7z+FXSEswqoL7jKH5SFWicdM3VbKCWMeZ1t5H8J+m/9LHW/gDMx7suRDz7gf1nnaGei1fa5N8aANuttd+7DuIzdYAvrLU/WmtPAvOAKo4z+Y61drK1NtpaGwP8AnyS3hlU0i5Q0oXxk4FEa+3zrvP4jTHmCmNM/qS/zwHcCnzkNJSPWGv7WGuLWWuL4y3DrLTW6r9gz2KMyZV0Uw5Jy3h18ZYeBLDWfgd8bYy5Memp2oBuXDq31mip81y+AioZY3Im/X9abbzrq+UsxphCSX+9Bu96tJnpnSFLen9gAKgKtAX2JF13BdDXWrvEXSRfKQK8mnRHVRDwhrVW20zIhSgMzPf+v4MswExr7XtuI/lOd2BG0nLe58C9jvP4TlLBvxW433UWv7HWbjLGzAW2A6eAHWg81Lm8ZYwpCJwEHnRxg4624BARERHxIS13ioiIiPiQSpqIiIiID6mkiYiIiPiQSpqIiIiID6mkiYiIiPiQSpqI+IYxxhpjRp719WPGmIGp9N7TjDEtUuO9zvM5dxhjEo0xq1LhvQYaYx47x/NFk7ZQwBgTZYy57VI/S0T8RyVNRPzkD+B2Y8zlroOcLWkIdUp1BO6z1tZMqzzW2m+stX8Wzii8uYIiEmBU0kTET07hbarZ45/f+OeZMGPM0aS/1jDGfGCMedsY87kxZogxpo0xZrMxZo8xpsRZb1PHGLPVGPNJ0hxVjDHBxpjhxpgtxpjdxpj7z3rftcaYhZxjR39jTOuk948zxgxNeq4/cAsw2Rgz/B8/b4wxY40xHxtjVhhjlvz5+xhj9v1ZTI0x5Y0xq896aRljzAZjzF5jzH1JP1M86XOzAU8BLY0xO40xLS/scIuIn2nigIj4zUvAbmPMsAt4TRkgFPgZbwf+Sdbam40xD+Ptzv9I0s8Vx5sDWgJYZYwpCdwDHLLWVjDGZAc+NMYsS/r5ckCEtfaLsz/MGFMUb/hyNN5Mv2XGmKbW2qeMMbWAx6y1W/+RsRlwIxCGN1UhAZiSgt+tNFAJyAXsMMa88+c3rLUnkopheWtttxS8l4hkIDqTJiK+Yq09DLwGPHQBL9tirf3WWvsH8BnwZ8nag1fM/vSGtfaMtXYvXpm7CW826D1JY942AQWBG5J+fvM/C1qSCsDqpAHVp4AZQMx5MsYAs6y1p6213wArU/i7vW2t/d1a+xOwCg2bF8k0dCZNRPzoBby5glPPeu4USf9haYwJArKd9b0/zvr7M2d9fYa//3vun3PwLGCA7tbapWd/wxhTAzh2MeEvwl+/GxDyj++dK7OIZAI6kyYivmOt/Rl4A+8i/D/tw1teBGgMZL2It77DGBOUdJ3a9cDHwFKgqzEmK4AxplTScO7kbAaqG2MuN8YEA62BD87zmjV4144FG2OKAGffWLCP///dmv/jdU2MMSFJg55rAFv+8f0jQJ7zfLaIZEAqaSLiVyOBs+/yfAWvGO0CKnNxZ7m+witY7wJdrLXHgUl414dtN8bEAS9znlUGa+23QG+85cddwDZr7dvn+ez5wN6kz3oN2HDW9wYBo40xW4HT/3jd7qTP2Qg8nbRUerZVQJhuHBAJPMZanTkXEUlvxphpwGJr7VzXWUTEn3QmTURERMSHdCZNRERExId0Jk1ERETEh1TSRERERHxIJU1ERETEh1TSRERERHxIJU1ERETEh/4PfRBTOrQpTbIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.linspace(2, 9, 8)\n",
    "y = 1/2**(x-2)\n",
    "plt.figure(figsize=(10,7))\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of qubit\")\n",
    "plt.ylabel(\"Change of f\")\n",
    "# 设置横轴的上下限\n",
    "# plt.xlim(2, 12)\n",
    "# 设置纵轴的上下限\n",
    "# plt.ylim(0, 1)\n",
    "\n",
    "plt.semilogy()\n",
    "plt.plot(x, loss_change, color=\"red\", linewidth=1.0, linestyle=\"-\", label=\" Delta C\")\n",
    "plt.plot(x, y, color=\"black\", linewidth=1.0, linestyle=\"-\", label=\"2^(-0.5n-1)\")\n",
    "\n",
    "\n",
    "plt.legend(loc=\"best\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "fb2e486a015784361e0077d7fcfeac02d1a431449f68aa51e1f4959008c61275"
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
