{
 "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 = layers.create_parameter(shape=[D, N], default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2 * np.pi),\n",
    "#             dtype='float64',is_bias=False)\n",
    "    theta = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N]))\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",
    "            target = np.random.choice(3, N) \n",
    "            if target[i] == 0:\n",
    "                cir.rz(theta[d][i], i)\n",
    "            elif target[i] == 1:\n",
    "                cir.ry(theta[d][i], i)\n",
    "            else:\n",
    "                cir.rx(theta[d][i], i)\n",
    "\n",
    "        for i in range(N - 1):\n",
    "            cir.cz([i, i + 1])\n",
    "\n",
    "    return cir.U.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": 4,
   "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, 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, 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, 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, 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, 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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.7184325247678838\n",
      "num_qubits = 2,     vC = 0.635023648768038\n",
      "num_qubits = 2,     vC = 0.6570114298751997\n",
      "num_qubits = 2,     vC = 0.4034682344083524\n",
      "num_qubits = 2,     vC = 0.22132474376234357\n",
      "num_qubits = 2,     vC = 0.4205625535998294\n",
      "num_qubits = 2,     vC = 0.5892317508539399\n",
      "num_qubits = 2,     vC = 0.771926313450565\n",
      "num_qubits = 2,     vC = 0.6671458417374404\n",
      "num_qubits = 2,     vC = 0.552153354116086\n",
      "num_qubits = 3,     vC = 0.3830755788526243\n",
      "num_qubits = 3,     vC = 0.4532038155277034\n",
      "num_qubits = 3,     vC = 0.4879584694046619\n",
      "num_qubits = 3,     vC = 0.18792033050806445\n",
      "num_qubits = 3,     vC = 0.3085437535390675\n",
      "num_qubits = 3,     vC = 0.4340888542167734\n",
      "num_qubits = 3,     vC = 0.5840049561246909\n",
      "num_qubits = 3,     vC = 0.35121486702763954\n",
      "num_qubits = 3,     vC = 0.24959421766458845\n",
      "num_qubits = 3,     vC = 0.3926687041650912\n",
      "num_qubits = 4,     vC = 0.4981030391290995\n",
      "num_qubits = 4,     vC = 0.44795402196693695\n",
      "num_qubits = 4,     vC = 0.25033651222220377\n",
      "num_qubits = 4,     vC = 0.3127497678909562\n",
      "num_qubits = 4,     vC = 0.09958734809154152\n",
      "num_qubits = 4,     vC = 0.28689777340202843\n",
      "num_qubits = 4,     vC = 0.26863281607416983\n",
      "num_qubits = 4,     vC = 0.4927199515760315\n",
      "num_qubits = 4,     vC = 0.44407915974352263\n",
      "num_qubits = 4,     vC = 0.1818265098204176\n",
      "num_qubits = 5,     vC = 0.19099335809568208\n",
      "num_qubits = 5,     vC = 0.36177786155021413\n",
      "num_qubits = 5,     vC = 0.15693400191278917\n",
      "num_qubits = 5,     vC = 0.11628114135305279\n",
      "num_qubits = 5,     vC = 0.21532909267625855\n",
      "num_qubits = 5,     vC = 0.22140598352434648\n",
      "num_qubits = 5,     vC = 0.2654735261872223\n",
      "num_qubits = 5,     vC = 0.08961895765355471\n",
      "num_qubits = 5,     vC = 0.209207272734322\n",
      "num_qubits = 5,     vC = 0.16249075467971752\n",
      "num_qubits = 6,     vC = 0.15747183758004407\n",
      "num_qubits = 6,     vC = 0.14295957731409858\n",
      "num_qubits = 6,     vC = 0.19100455789942583\n",
      "num_qubits = 6,     vC = 0.06445630615512765\n",
      "num_qubits = 6,     vC = 0.3615528849601378\n",
      "num_qubits = 6,     vC = 0.2678678660765017\n",
      "num_qubits = 6,     vC = 0.11207074053997212\n",
      "num_qubits = 6,     vC = 0.1371925000699491\n",
      "num_qubits = 6,     vC = 0.08087632212944162\n",
      "num_qubits = 6,     vC = 0.19859715091274577\n",
      "num_qubits = 7,     vC = 0.11356128718955438\n",
      "num_qubits = 7,     vC = 0.11939709145782268\n",
      "num_qubits = 7,     vC = 0.03617420251409709\n",
      "num_qubits = 7,     vC = 0.1734864298956864\n",
      "num_qubits = 7,     vC = 0.2266061142506961\n",
      "num_qubits = 7,     vC = 0.10105649009157514\n",
      "num_qubits = 7,     vC = 0.08931073172622833\n",
      "num_qubits = 7,     vC = 0.13599021119432192\n",
      "num_qubits = 7,     vC = 0.0712530563731042\n",
      "num_qubits = 7,     vC = 0.18175287722698819\n",
      "num_qubits = 8,     vC = 0.12155131822964044\n",
      "num_qubits = 8,     vC = 0.06677496279739853\n",
      "num_qubits = 8,     vC = 0.09295153908552967\n",
      "num_qubits = 8,     vC = 0.09643795302112068\n",
      "num_qubits = 8,     vC = 0.10039895447017422\n",
      "num_qubits = 8,     vC = 0.08114158831117102\n",
      "num_qubits = 8,     vC = 0.034973840098536324\n",
      "num_qubits = 8,     vC = 0.08232119588068343\n",
      "num_qubits = 8,     vC = 0.06790013840575704\n",
      "num_qubits = 8,     vC = 0.08880497029182\n",
      "num_qubits = 9,     vC = 0.007527123795998569\n",
      "num_qubits = 9,     vC = 0.04934186383154693\n",
      "num_qubits = 9,     vC = 0.06352149813757613\n",
      "num_qubits = 9,     vC = 0.06249697466804194\n",
      "num_qubits = 9,     vC = 0.06912884906867067\n",
      "num_qubits = 9,     vC = 0.038066520364374856\n",
      "num_qubits = 9,     vC = 0.10089141071159446\n",
      "num_qubits = 9,     vC = 0.04171339425260323\n",
      "num_qubits = 9,     vC = 0.09352740628459155\n",
      "num_qubits = 9,     vC = 0.080895129565354\n"
     ]
    }
   ],
   "source": [
    "loss_change = []\n",
    "\n",
    "for N in range(2,10):\n",
    "\n",
    "    temp = []\n",
    "\n",
    "    # heisenberg model\n",
    "    H = np.kron(np.array([[1.0, 0.0],[0.0, 0.0]]), np.eye(2**(N-1)))\n",
    "    \n",
    "    # spectral width of H = 1\n",
    "\n",
    "    for _ in range(100):\n",
    "\n",
    "        V = uni_2_design(N, 10*N)\n",
    "        rand_H = paddle.to_tensor(V @ H @ V.conjugate().T)\n",
    "        \n",
    "        Delta_C = train_loss(N, 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_QAE_ahead_Adam_'+str(N)+'qubit')\n",
    "\n",
    "    loss_change.append(np.average(temp))\n",
    "np.savetxt(\"QAE_Adam\", loss_change)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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yhReeOEFqlevzvbt213HEhERkUSkqZJmrV1ore0SHBzsOopPqlGjBtu2baNdu3bUr1+fzp0788MPP7iOJSIiIpeRpkqaXFlgYCBdunQhLi6O4OBgIiIiGD58OH/88YfraCIiInIRlTQ/lSNHDkaOHMn69etZt24dERERzJ8/X/PVREREfIRKmp8rUqQICxYs4I033mDAgAHUqlWL3bt3u44lIiLi91TSBIA6deqwc+dOmjdvTq1atejevTs//fST61giIiJ+SyVN/hIUFMQjjzxCbGws6dOnJzw8nNGjR3PmzBnX0URERPyOSpr8Q86cORkzZgyfffYZy5Yto1ixYnz88cearyYiIpKCVNLkX4WHh7NkyRJGjRrFE088Qf369dm7d6/rWCIiIn5BJU0SZYyhYcOG7N69m3r16lGtWjV69uzJzz//7DqaiIhImqaSJkmSPn16evXqRWxsLOfOnSM0NJRx48Zx7tw519FERETSJJU0uSq5c+fmjTfeYMWKFXz44YdERkayfPly17FERETSHJU0uSbFihXj008/ZejQofTo0YPGjRuzb98+17FERETSDJU0uWbGGJo1a0ZMTAxVqlShYsWK9OnTh2PHjrmOJiIikuqppMl1y5AhA3379iUmJobjx48TGhrKhAkTOH/+vOtoIiIiqZZKmtwwt956K5MmTWLJkiXMnDmTLl26sGrVKtexREREUqU0VdKMMY2NMROPHz/uOopfK1myJKtXr+aBBx7goYceonnz5hw8eNB1LBERkVQlTZU0a+1Ca22X4OBg11H8njGGatWqERsbS1RUFGXKlKFfv36cOHHCdTQREZFUIU2VNPE9mTJlYsCAAezevZvvvvuOkJAQpkyZwoULF1xHExER8WkqaZIibr/9dqZNm8b8+fOZNGkSZcqUYd26da5jiYiI+CyVNElRZcuW5fPPP6dPnz60bduW1q1b87///c91LBEREZ+jkiYpzhhD27ZtiYuLIywsjFKlSjFw4EB+++0319FERER8hkqaOJM5c2aee+45duzYwRdffEFISAjTp0/XfDURERFU0sQH5MuXj5kzZzJ79mzGjBlDxYoV2bRpk+tYIiIiTqmkic/4s5x1796d5s2b0759e7755hvXsURERJxQSROfEhAQQIcOHYiPj+eOO+6gePHiDBkyhFOnTrmOJiIikqJU0sQn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JU0SV64cbNwIc+dC+/Zw+rTrRJKCKlWqxObNm+nWrRvNmzenffv2fPPNN65jiYj4BZU0ubK8eWHNGjh3DqpVg+++c51IUlBAQAAPPvggcXFx5MuXj8jISF544QV+//1319FERNK0NFXSjDGNjTETdZh0MsicGd57zztGqmxZ2LLFdSJJYdmyZePFF18kOjqaHTt2EBYWxuzZs7G6DS4ikizSVEmz1i601nYJDg52HSVtMgaeeQbGjvUOap81y3UicaBAgQLMnTuXadOm8eKLL1K1alW2bt3qOpaISJqTpkqapJB77oFPP4V+/bzSppV/fqlatWps3bqVBx54gIYNG9KpUye+//5717FERNIMlTS5NpGRsHkzfPYZtGgBJ0+6TiQOBAYG8vDDDxMfH0/OnDkpWrQow4YN448//nAdTUQk1VNJk2t3yy3eiFrOnFCpEhw65DqROBIcHMyIESPYsGED69evJzw8nA8//FDz1UREroNKmlyfDBlg0iTo2BEqVIC1a10nEofuuusuPvroIyZMmMDAgQO5++672bVrl+tYIiKpkkqaXD9j4PHHYepU79bn5MmuE4ljtWrVYseOHbRs2ZLatWvTtWtXfvrpJ9exRERSFZU0uXHq1vVG0oYNg8ceI0hbofi1oKAgevToQVxcHJkyZSI8PJxRo0Zx5swZ19FERFIFlTS5sUJCYNMmOHmS8u3aeUdLrVmjI6X82E033cSrr77K2rVr+fTTTylWrBiLFi3SfDURkStQSZMb76ab4O232ThzJpQuDd26QXg4jB4NR4+6TieOhIaGsnjxYl599VWefPJJ6tWrx969e13HEhHxWSppkmzOZc8OvXpBTAxMnAjbtkGhQhpd83P169dn9+7dNGjQgGrVqvHYY49xVOVdROQfVNIk+RkDVarAu+/CwYMaXRPSpUvH448/TmxsLBcuXCAsLIzXXnuNs2fPuo4mIuIzVNIkZeXM+e+ja2vXanTNz+TOnZvXX3+dlStXsmDBAiIjI1m2bJnrWCIiPiHIdQDxU3+OrlWpAj//DO+8A126eN/r0gUeeABy5XKbUVJM0aJFWb58OQsXLuTRRx8lJCSEVq1auY4lIuKURtLEvT9H1/bu1eiaHzPG0KRJE/bs2UP16tV57LHHeOKJJzh27JjraCIiTqikie+4eO7aF194c9e6dPn/uWs//+w6oaSADBky8OSTT/L2229z8uRJQkNDefPNNzl37pzraCIiKUolTXxTrlyXH11r316ja34iZ86cTJw4kaVLlzJr1ixKlSrFypUrXccSEUkxKmni2y4eXTtwAKKivNG1iAh49VWNrvmBEiVKsGrVKgYNGkTnzp255557+OKLL1zHEhFJdippknpcPLo2YQJs2QIFC2p0zQ8YY2jRogV79+6lbNmylC1blqeeeopff/3VdTQRkWSjkiapz5+ja9One3PXSpXS6JqfyJgxI/3792f37t388MMPhISEMHnyZM6fP+86mojIDaeSJqlbrlzQu7dG1/zM7bffztSpU1m4cCFTpkyhTJkyrF271nUsEZEbSiVN0gaNrvml0qVLs27dOvr27cv9999Pq1atOHTokOtYIiI3hEqapD0Xj669+aZG19I4Ywz33XcfsbGxFC1alKioKJ555hlOnjzpOpqIyHVRSZO0yxioWlWja34ic+bMPPvss+zYsYMvv/yS0NBQ3nnnHS5cuOA6mojINVFJE/+Q2OjaunUaXUtD8uXLx4wZM5gzZw7jxo2jQoUKbNiwwXUsEZGrppIm/uVyo2sPPwxFi8KYMRpdS0MqVKjAxo0beeSRR7j33ntp164dhw8fdh1LRCTJVNLEf108ujZ+PERHa3QtjQkICOCBBx4gLi6OggULEhkZyeDBgzl16pTraCIiV6SSJnK50bXOnTW6loZkzZqV559/nq1btxITE0NoaCjvvfceVkVcRHyYSprIxf4cXYuN9UbXNm/W6Foakj9/fmbPns306dMZMWIElStXJjo62nUsEZHLUkkTuZw/R9dmzNDoWhpUtWpVoqOj6dixI02aNOHBBx/ku+++cx1LRORvVNJEruTfRtceeECja6lYYGAgnTp1Ij4+nltvvZVixYrx4osvcvr0adfRREQAlTSRpLt4dO3AAShRQqNraUD27NkZNmwYmzZtIjo6mrCwMObOnav5aiLinEqayLXInRueeMIbXXvjDY2upQGFChXiww8/ZPLkyQwZMoQaNWqwY8cO17FExI+ppIlcD2OgWrV/H1375RfXCeUq1axZk23btnHfffdRt25dHn74YX744QfXsUTED6WpkmaMaWyMmXj8+HHXUcQfXW50rUABb3Tt8881upaKBAUF0a1bN+Lj48mWLRsRERG88sornDlzxnU0EfEj/1rSjDErEv46LOXiXB9r7UJrbZfg4GDXUcSfXW50rVMnja6lQjly5GDUqFF8/vnnrF69moiICBYsWKD5aiKSIhIbSctjjKkINDHGlDTGlLr4kVIBRVK1REbXssbHu04nSRQSEsKiRYsYN24c/fr1o06dOuzZs8d1LBFJ4xIrac8CA4G8wMhLHq8kfzSRNOTS0bXISIo98wy0aAExMa7TSRLVrVuXnTt30qRJE2rWrEmPHj04cuSI61gikkb9a0mz1s611tYHhltra1pra1z0qJmCGUXSlty5oU8fNr37LlSoADVqeCcafPGF62SSBOnSpeOxxx4jNjaWwMBAwsLCGDNmDGfPnnUdTUTSmCsuHLDWPp8SQUT8zYWMGeHJJ72RtcKFoVw56NYNDh92HU2SIFeuXLz22musXr2axYsXU7x4cZYsWeI6loikIWlqdadIqpQ9OwwaBPHxEBwMkZHePLaffnKdTJIgIiKCpUuXMmLECB5//HEaNGhAXFyc61gikgYktrqzQEoGEfF7uXLBsGGwZw+cOQOhoTBwIBw75jqZXIExhkaNGrFnzx5q1apFlSpV6NWrF79oJa+IXIfERtLmwv9vxSEiKSRPHhg3DrZu9W593nUXvPQS/Pab62RyBenTp+eJJ55g7969nD59mtDQUF5//XXOnTvnOpqIpEKJlbQAY8zTQBFjzBOXPlIqoIjfyp8f3n4b1q6FHTu8eWtjx8Iff7hOJldw88038+abb/LJJ58wb948SpQowaeffuo6loikMomVtPuA80AQkO0yDxFJCaGh8P77sGQJLF8ORYrA5Mmg0RmfV7x4cVasWMHzzz9P165dadq0Kfv373cdS0RSicS24Ii31g4DOlprB1/6SMGMIgLeyQWLFsF778H06RAe7v35wgXXySQRxhjuuece9u7dS8WKFalQoQL//e9/0fF1InIlSVndud4YM8oYsyXhMdIYo3OXRFypWBFWrvROMHj1Va+8LVigs0F9XIYMGXjqqafYs2cPP//8M6Ghobz11lucP3/edTQR8VFJKWlTgBNAq4THr8DbyRlKRK7AGKhVCzZuhBdegGeegfLlYYXW+fi62267jcmTJ7No0SLeeecdoqKi+Oyzz1zHEhEflJSSVshaO8haezDhMRgomNzBRCQJjIEmTbyFBb16QffuULMmbNjgOplcQVRUFGvW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+QS2bfPK2tChoLmsTlWtWpXo6GgeeughGjduzEMPPcR3333nOpaIU4mVtFuttbsvfTLhufzJlkhEJCUUKwazZsFnn0FcHBQuDM89B7/84jqZ3woMDKRTp07Ex8dzyy23UKxYMV566SVOax6h+KnESlqORL6X6QbnEBFxIywM3n3X277j66+9sjZgABw54jqZ38qePTvDhg1j06ZNbN68mfDwcD744APNVxO/k1hJ22KMefjSJ40xnYGtyRdJRMSBwoVh8mTYuhWOHvW27vjvf+GHH1wn81uFChXiww8/5K233mLQoEHUrFmTHTt2uI4lkmISK2m9gIeMMauNMSMTHp8BnYDHUySdiEhKy58f3nwTdu70tusIC4NeveDbb10n81t3330327dvp3Xr1tStW5cuXbrw448/uo4lkuz+taRZa3+w1lYEBgOHEh6DrbUVrLXfp0w8ERFH8uWD116DmBjv+KmiReGRR+Crr1wn80tBQUF069aN+Ph4smbNSkREBCNHjuTMmTOuo4kkmyueOGCtXWWtfS3hsTIlQomI+Iw8eWDUKG9xQdasUKIEdOkCX37pOplfypEjB6NGjWLdunWsWrWKokWLsnDhQs1XkzQpKcdCiYjILbd4h7jv2+f9uXRpeOgh2L/fdTK/FBISwqJFi3jttdd46qmnqFu3LjExMa5jidxQKmkiIlcjd2544QX44gsoUAAqVoR27WDvXtfJ/FLdunXZuXMnjRo1okaNGjz66KMcPXrUdSyRG0IlTUTkWuTIAc8+65W1okWhRg1o1Qp27XKdzO+kS5eOnj17EhsbizGGsLAwxowZw7lz51xHE7kuKmkiItcje3bo3x8OHoRy5aBuXbjnHu80A0lRuXLl4rXXXmPVqlUsXryYTp06sXTpUtexRK6ZSpqIyI2QJQv06eOVtRo1oEkTaNQINm1ynczvREREsHTpUrp27UrPnj1p2LAh8fHxrmOJXDWVNBGRGylTJujZEw4cgIYNvVugdep4h7pLijHGULFiRfbs2UPNmjWpXLkyvXv35hcd+yWpiEqaiEhyyJgRunf3Vn+2agUPPOCNsK1aBdouIsWkT5+ePn36EBMTw6lTpwgNDWX8+PGaryapgkqaiEhySp8eOneG+Hh48EHo2hWqVIFly1TWUtAtt9zChAkTWL58ObNnz6ZkyZKsWLHCdSyRRKmkiYikhHTpoEMHiI31Ti544gkoXx4WLVJZS0GRkZGsXLmSIUOG0KVLF5o1a8aBAwdcxxK5LJU0EZGUFBgIbdrA7t3eAe4DBkBUFHz4IVy44DqdXzDGcM899xATE0P58uUpX748ffv25ddff3UdTeRvVNJERFwICICWLWH7dhg0CIYOhchIeP99OH/edTq/kDFjRvr168fu3bs5cuQIISEhTJo0ifO6/uIjVNJERFwKCICmTSE62jt26tVXvc1xZ8wATW5PEXny5GHKlCksWrSIqVOnUrp0adasWeM6lohKmoiITzAGGjSA9evhtddgwgQIC4O334azZ12n8wtRUVGsXbuWfv360b59e+69914OHTrkOpb4MZU0ERFfYgzUqgVr1sCkSTB9OhQpAhMnwpkzrtOlecYYWrduTVxcHMWLFycqKooBAwZw8uRJ19HED6mkiYj4qmrVYMUK79bnhx9C4cLw+utw+rTrZGlepkyZGDhwIDt37uSrr74iJCSEadOmcUGLOyQFqaSJiPi6ihVhyRKYO9fbX61QIRg9moA//nCdLM3Lmzcv7777LvPmzWP8+PGUL1+e9evXu44lfkIlTUQktShbFhYs8PZWW7WKUt27w759rlP5hT/LWc+ePWndujVt27bl66+/dh1L0jiVNBGR1KZkSfjoI75p1gwqVYJ581wn8gsBAQHcf//9xMXFUbhwYUqUKMFzzz3HqVOnXEeTNEolTUQkNTKG75o08W6D9unjPbQKNEVkyZKFIUOGsG3bNuLi4ggNDWXmzJlYnRwhN5hKmohIala6NGzd6h03VbMmfPut60R+484772TWrFnMnDmTUaNGUalSJaKjo13HkjREJU1EJLXLlcubp1anjlfaVq92ncivVK5cmc2bN/Pwww/TtGlTOnTowLcqy3IDqKSJiKQFAQEwcCBMmwb33Qcvv6yzQFNQQEAADz30EPHx8dx+++0UL16coUOH8vvvv7uOJqmYSpqISFpSu7Z3xNT8+XDPPXDsmOtEfiVbtmy89NJLbN68mW3bthEeHs6cOXM0X02uiUqaiEhaky+fd2LBnXdCVBTs2OE6kd8pWLAg8+bNY8qUKbzwwgtUr16d7du3u44lqYxKmohIWpQ+PYwdC0OHeqNrU6a4TuSXatSowbZt22jXrh3169enc+fO/PDDD65jSSqhkiYikpbddx98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N90Er7wCW7Z4o2shIfD223D+vOtkqUaaKmkiIiLiYwoUgPfeg3nzYPJkKFUKPvnEdapUQSVNREREkl+5crB2LQwaBD16QP36sGeP61Q+TSVNREREUoYx0Ly5t/Kzfn3v9IKHH4bvvnOdzCeppImIiEjKSp8eevaEffu8uWtFi8LgwVpccAmVNBEREXEjRw4YPhy2bvUKW5Ei3rw1LS4AVNJERETEtfz5YcYMmD/fO16qRAlYtsxxKPdU0kRERMQ3lCkDn30GL7zg3Q6tWxd27XKdyhmVNBEREfEdxkDTpt7KzyZNvNMLOnWCb791nSzFqaSJiIiI70mXDh55xJurdsstUKyYt33HyZOuk6UYlTQRERHxXcHB8NJLsG0bHDzoLS546y04d851smSnkiYiIiK+78474d13YcECb5FBiRKwZAlY6zpZslFJExERkdSjdGlYtcobXevdG+rUgR07XKdKFippIiIikroYA40bw+7d3gkG9erBQw/B4cOuk91QKmkiIiKSOqVLB927e4sLbr8dIiNh4EA4ccJ1shtCJU1ERERSt+zZYehQ77bnV195iwsmTEj1iwtU0kRERCRtyJfPO7Hg44/h/feheHHvz6l0cUGaKmnGmMbGmInHjx93HUVERERcKVUKVqyAESPgv/+FWrVg+3bXqa5amipp1tqF1touwcHBrqOIiIiIS8ZAw4besVKtWkGDBtChA3z9tetkSZamSpqIiIjI3wQFQdeu3uKCO+7w9lcbMAB+/dV1sitSSRMREZG0L1s2eP552LkTvvnGW1wwfjycPes62b9SSRMRERH/kTcvTJ0KS5fCvHne4oKFC31ycYFKmoiIiPifEiXgk09g1Cjo1w9q1oStW12n+huVNBEREfFPxkD9+t4t0DZtvFMM2rf39lrzASppIiIi4t+CgqBLF4iPhwIFoGRJ6NePwJMnncZSSRMREREBb3HBkCHeth0//URk375O56oFOftkEREREV/0n//A5MnsWLKEqsY4i6GRNBEREZHLuJApk9PPV0kTERER8UEqaSIiIiI+SCVNRERExAeppImIiIj4IJU0ERERER+kkiYiIiLig1TSRERERHyQSpqIiIiID1JJExEREfFBKmkiIiIiPkglTURERMQHpamSZoxpbIyZePz4cddRRERERK5Lmipp1tqF1touwcHBrqOIiIiI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\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**(0.5*x-1)\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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
