{
 "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 uni_2_design_vec(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.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": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.3990153809962845\n",
      "num_qubits = 2,     vC = 0.6176889061756068\n",
      "num_qubits = 2,     vC = 0.5486954348622974\n",
      "num_qubits = 2,     vC = 0.09345277598540709\n",
      "num_qubits = 2,     vC = 0.08167483439327052\n",
      "num_qubits = 2,     vC = 0.5377235364052859\n",
      "num_qubits = 2,     vC = 0.18071351921558787\n",
      "num_qubits = 2,     vC = 0.2870033633850513\n",
      "num_qubits = 2,     vC = 0.4795259181153814\n",
      "num_qubits = 2,     vC = 0.48649725021868656\n",
      "num_qubits = 2,     vC = 0.3840810321745911\n",
      "num_qubits = 2,     vC = 0.9112838018177827\n",
      "num_qubits = 2,     vC = 0.127953686627286\n",
      "num_qubits = 2,     vC = 0.4533769240049217\n",
      "num_qubits = 2,     vC = 0.6173722942077539\n",
      "num_qubits = 2,     vC = 0.7289081500612752\n",
      "num_qubits = 2,     vC = 0.5885876151710362\n",
      "num_qubits = 2,     vC = 0.5236099676304259\n",
      "num_qubits = 2,     vC = 0.10055512872412077\n",
      "num_qubits = 2,     vC = 0.7456530275768506\n",
      "num_qubits = 2,     vC = 0.356057098681645\n",
      "num_qubits = 2,     vC = 0.8823720766518798\n",
      "num_qubits = 2,     vC = 0.4246717428635129\n",
      "num_qubits = 2,     vC = 0.605041138278131\n",
      "num_qubits = 2,     vC = 0.7162894408928773\n",
      "num_qubits = 2,     vC = 0.3270400117564863\n",
      "num_qubits = 2,     vC = 0.1849317438082701\n",
      "num_qubits = 2,     vC = 0.48599427218255215\n",
      "num_qubits = 2,     vC = 0.7889936923956222\n",
      "num_qubits = 2,     vC = 0.22211640630818782\n",
      "num_qubits = 2,     vC = 0.1708644934269547\n",
      "num_qubits = 2,     vC = 0.6378832616098239\n",
      "num_qubits = 2,     vC = 0.4434261574565105\n",
      "num_qubits = 2,     vC = 0.38379744081940104\n",
      "num_qubits = 2,     vC = 0.40464913577437106\n",
      "num_qubits = 2,     vC = 0.7280528583718427\n",
      "num_qubits = 2,     vC = 0.5628920122831725\n",
      "num_qubits = 2,     vC = 0.44604725029095516\n",
      "num_qubits = 2,     vC = 0.7501039133990792\n",
      "num_qubits = 2,     vC = 0.22917349644325122\n",
      "num_qubits = 2,     vC = 0.8978272575234917\n",
      "num_qubits = 2,     vC = 0.5606260874235581\n",
      "num_qubits = 2,     vC = 0.22747249968086508\n",
      "num_qubits = 2,     vC = 0.3582760574190122\n",
      "num_qubits = 2,     vC = 0.26137656303274887\n",
      "num_qubits = 2,     vC = 0.44766879836766366\n",
      "num_qubits = 2,     vC = 0.6504694696109867\n",
      "num_qubits = 2,     vC = 0.7051322498075069\n",
      "num_qubits = 2,     vC = 0.44624340297427295\n",
      "num_qubits = 2,     vC = 0.20323694865071468\n",
      "num_qubits = 2,     vC = 0.2169368627648311\n",
      "num_qubits = 2,     vC = 0.2542206657412685\n",
      "num_qubits = 2,     vC = 0.5646931358323721\n",
      "num_qubits = 2,     vC = 0.46391465423214145\n",
      "num_qubits = 2,     vC = 0.5385691938001226\n",
      "num_qubits = 2,     vC = 0.6226090422396766\n",
      "num_qubits = 2,     vC = 0.9611773105459583\n",
      "num_qubits = 2,     vC = 0.28914326911224764\n",
      "num_qubits = 2,     vC = 0.6318112249770506\n",
      "num_qubits = 2,     vC = 0.40923549000742643\n",
      "num_qubits = 2,     vC = 0.4287551049716297\n",
      "num_qubits = 2,     vC = 0.738171098234895\n",
      "num_qubits = 2,     vC = 0.6268871057211884\n",
      "num_qubits = 2,     vC = 0.025701295200943528\n",
      "num_qubits = 2,     vC = 0.857293478717666\n",
      "num_qubits = 2,     vC = 0.6366960533248722\n",
      "num_qubits = 2,     vC = 0.7357049054718555\n",
      "num_qubits = 2,     vC = 0.601460404459386\n",
      "num_qubits = 2,     vC = 0.4042814800764586\n",
      "num_qubits = 2,     vC = 0.3388785451988715\n",
      "num_qubits = 2,     vC = 0.37965879471788905\n",
      "num_qubits = 2,     vC = 0.7075897271734995\n",
      "num_qubits = 2,     vC = 0.5800784653341321\n",
      "num_qubits = 2,     vC = 0.3842555835730323\n",
      "num_qubits = 2,     vC = 0.4992555794971914\n",
      "num_qubits = 2,     vC = 0.8177003489968886\n",
      "num_qubits = 2,     vC = 0.7282876802159315\n",
      "num_qubits = 2,     vC = 0.14122118482846502\n",
      "num_qubits = 2,     vC = 0.5434133013293865\n",
      "num_qubits = 2,     vC = 0.5321901979511205\n",
      "num_qubits = 2,     vC = 0.6176425610376645\n",
      "num_qubits = 2,     vC = 0.4254442949383725\n",
      "num_qubits = 2,     vC = 0.33204061053199335\n",
      "num_qubits = 2,     vC = 0.6555824480065477\n",
      "num_qubits = 2,     vC = 0.49021268246251887\n",
      "num_qubits = 2,     vC = 0.7248914065385013\n",
      "num_qubits = 2,     vC = 0.513594328688977\n",
      "num_qubits = 2,     vC = 0.38573094823630644\n",
      "num_qubits = 2,     vC = 0.3047275765175748\n",
      "num_qubits = 2,     vC = 0.414362187619805\n",
      "num_qubits = 2,     vC = 0.5648781843244377\n",
      "num_qubits = 2,     vC = 0.6308812814577222\n",
      "num_qubits = 2,     vC = 0.7848471845075146\n",
      "num_qubits = 2,     vC = 0.8964226213522714\n",
      "num_qubits = 2,     vC = 0.576127112854428\n",
      "num_qubits = 2,     vC = 0.25016128568440743\n",
      "num_qubits = 2,     vC = 0.7379620686208538\n",
      "num_qubits = 2,     vC = 0.44282907097859\n",
      "num_qubits = 2,     vC = 0.7584178458555966\n",
      "num_qubits = 2,     vC = 0.8504735582287208\n",
      "num_qubits = 3,     vC = 0.12432735728925612\n",
      "num_qubits = 3,     vC = 0.21616817965977364\n",
      "num_qubits = 3,     vC = 0.16285966794159842\n",
      "num_qubits = 3,     vC = 0.3602279568700859\n",
      "num_qubits = 3,     vC = 0.2417502902893287\n",
      "num_qubits = 3,     vC = 0.09988266530169357\n",
      "num_qubits = 3,     vC = 0.2561360705582805\n",
      "num_qubits = 3,     vC = 0.15935483029809344\n",
      "num_qubits = 3,     vC = 0.2865378064839726\n",
      "num_qubits = 3,     vC = 0.23350607954581734\n",
      "num_qubits = 3,     vC = 0.7124580667106813\n",
      "num_qubits = 3,     vC = 0.1464269913317218\n",
      "num_qubits = 3,     vC = 0.0358048583202982\n",
      "num_qubits = 3,     vC = 0.06907568502483075\n",
      "num_qubits = 3,     vC = 0.18637797437165637\n",
      "num_qubits = 3,     vC = 0.04849126640740245\n",
      "num_qubits = 3,     vC = 0.16523276946616003\n",
      "num_qubits = 3,     vC = 0.08422775603695082\n",
      "num_qubits = 3,     vC = 0.08130974109565683\n",
      "num_qubits = 3,     vC = 0.3104222076746739\n",
      "num_qubits = 3,     vC = 0.2861620202886011\n",
      "num_qubits = 3,     vC = 0.5248542528671737\n",
      "num_qubits = 3,     vC = 0.18979345192804706\n",
      "num_qubits = 3,     vC = 0.2938131613775239\n",
      "num_qubits = 3,     vC = 0.21574376552475852\n",
      "num_qubits = 3,     vC = 0.1776013620357197\n",
      "num_qubits = 3,     vC = 0.4495717531875626\n",
      "num_qubits = 3,     vC = 0.5672455049168084\n",
      "num_qubits = 3,     vC = 0.37457718961059316\n",
      "num_qubits = 3,     vC = 0.260399528372727\n",
      "num_qubits = 3,     vC = 0.46368773444871064\n",
      "num_qubits = 3,     vC = 0.3272856717410955\n",
      "num_qubits = 3,     vC = 0.1494054311225741\n",
      "num_qubits = 3,     vC = 0.08874003655747953\n",
      "num_qubits = 3,     vC = 0.15116625935389533\n",
      "num_qubits = 3,     vC = 0.25607843252511137\n",
      "num_qubits = 3,     vC = 0.1294809908325042\n",
      "num_qubits = 3,     vC = 0.17443458673557893\n",
      "num_qubits = 3,     vC = 0.2606779110625334\n",
      "num_qubits = 3,     vC = 0.21551172019352088\n",
      "num_qubits = 3,     vC = 0.2593724030117495\n",
      "num_qubits = 3,     vC = 0.22856228436287296\n",
      "num_qubits = 3,     vC = 0.26579958451880087\n",
      "num_qubits = 3,     vC = 0.4864385013924912\n",
      "num_qubits = 3,     vC = 0.1997874085893969\n",
      "num_qubits = 3,     vC = 0.2061216184667566\n",
      "num_qubits = 3,     vC = 0.23910386501861633\n",
      "num_qubits = 3,     vC = 0.2569696980296399\n",
      "num_qubits = 3,     vC = 0.4239778412097861\n",
      "num_qubits = 3,     vC = 0.3608174651487496\n",
      "num_qubits = 3,     vC = 0.5472944833613115\n",
      "num_qubits = 3,     vC = 0.17052217956163493\n",
      "num_qubits = 3,     vC = 0.1304867213347571\n",
      "num_qubits = 3,     vC = 0.5053347640016207\n",
      "num_qubits = 3,     vC = 0.06619108738037206\n",
      "num_qubits = 3,     vC = 0.1388820658139656\n",
      "num_qubits = 3,     vC = 0.3842855480179036\n",
      "num_qubits = 3,     vC = 0.18425351161668557\n",
      "num_qubits = 3,     vC = 0.3202332077298716\n",
      "num_qubits = 3,     vC = 0.46260864516957223\n",
      "num_qubits = 3,     vC = 0.5292344813425178\n",
      "num_qubits = 3,     vC = 0.346837995373156\n",
      "num_qubits = 3,     vC = 0.469593711191464\n",
      "num_qubits = 3,     vC = 0.15755346132680556\n",
      "num_qubits = 3,     vC = 0.20439551535298525\n",
      "num_qubits = 3,     vC = 0.15427640673565943\n",
      "num_qubits = 3,     vC = 0.7515956758424237\n",
      "num_qubits = 3,     vC = 0.09949619721991437\n",
      "num_qubits = 3,     vC = 0.2801100035573939\n",
      "num_qubits = 3,     vC = 0.2615456131280716\n",
      "num_qubits = 3,     vC = 0.44703760274602883\n",
      "num_qubits = 3,     vC = 0.048022050686524875\n",
      "num_qubits = 3,     vC = 0.18834990127465578\n",
      "num_qubits = 3,     vC = 0.13292274040186788\n",
      "num_qubits = 3,     vC = 0.14909772281981937\n",
      "num_qubits = 3,     vC = 0.21481935783224188\n",
      "num_qubits = 3,     vC = 0.28351151682466214\n",
      "num_qubits = 3,     vC = 0.3273693309776055\n",
      "num_qubits = 3,     vC = 0.3310144399362881\n",
      "num_qubits = 3,     vC = 0.30003377184068064\n",
      "num_qubits = 3,     vC = 0.2638941772086586\n",
      "num_qubits = 3,     vC = 0.3694219004339486\n",
      "num_qubits = 3,     vC = 0.09278758814843549\n",
      "num_qubits = 3,     vC = 0.1062975293294322\n",
      "num_qubits = 3,     vC = 0.21574505256845555\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 3,     vC = 0.05740791436897177\n",
      "num_qubits = 3,     vC = 0.4624829704305126\n",
      "num_qubits = 3,     vC = 0.1777525596410929\n",
      "num_qubits = 3,     vC = 0.23275883853458645\n",
      "num_qubits = 3,     vC = 0.19504700547592674\n",
      "num_qubits = 3,     vC = 0.37154574196565465\n",
      "num_qubits = 3,     vC = 0.09162757759963205\n",
      "num_qubits = 3,     vC = 0.26920941243151897\n",
      "num_qubits = 3,     vC = 0.46386554801821855\n",
      "num_qubits = 3,     vC = 0.04993381071189124\n",
      "num_qubits = 3,     vC = 0.1686630695769953\n",
      "num_qubits = 3,     vC = 0.07387651435187399\n",
      "num_qubits = 3,     vC = 0.14754736018524336\n",
      "num_qubits = 3,     vC = 0.026534095393880963\n",
      "num_qubits = 3,     vC = 0.2700843359658536\n",
      "num_qubits = 4,     vC = 0.2749936057868077\n",
      "num_qubits = 4,     vC = 0.030141519496290476\n",
      "num_qubits = 4,     vC = 0.07029924615350788\n",
      "num_qubits = 4,     vC = 0.16190917254049134\n",
      "num_qubits = 4,     vC = 0.07109932727191663\n",
      "num_qubits = 4,     vC = 0.1682759222514883\n",
      "num_qubits = 4,     vC = 0.09689978994543873\n",
      "num_qubits = 4,     vC = 0.18724602441208368\n",
      "num_qubits = 4,     vC = 0.11931396659430193\n",
      "num_qubits = 4,     vC = 0.10066339875853006\n",
      "num_qubits = 4,     vC = 0.08187576559456113\n",
      "num_qubits = 4,     vC = 0.1191629757504257\n",
      "num_qubits = 4,     vC = 0.1605718067189922\n",
      "num_qubits = 4,     vC = 0.11971337476208564\n",
      "num_qubits = 4,     vC = 0.02451111195619539\n",
      "num_qubits = 4,     vC = 0.16976960511910585\n",
      "num_qubits = 4,     vC = 0.16554945101707344\n",
      "num_qubits = 4,     vC = 0.09999880220713783\n",
      "num_qubits = 4,     vC = 0.2638411320272438\n",
      "num_qubits = 4,     vC = 0.09024461449871694\n",
      "num_qubits = 4,     vC = 0.20019988311703923\n",
      "num_qubits = 4,     vC = 0.12491186942715889\n",
      "num_qubits = 4,     vC = 0.44535010064398745\n",
      "num_qubits = 4,     vC = 0.08994134716825632\n",
      "num_qubits = 4,     vC = 0.07405796221895383\n",
      "num_qubits = 4,     vC = 0.11128271718114052\n",
      "num_qubits = 4,     vC = 0.12364781148760916\n",
      "num_qubits = 4,     vC = 0.3317363306313048\n",
      "num_qubits = 4,     vC = 0.08238458331523373\n",
      "num_qubits = 4,     vC = 0.09828696550649312\n",
      "num_qubits = 4,     vC = 0.03936351002953022\n",
      "num_qubits = 4,     vC = 0.16438413414701783\n",
      "num_qubits = 4,     vC = 0.2201587844964269\n",
      "num_qubits = 4,     vC = 0.2367093848964776\n",
      "num_qubits = 4,     vC = 0.030752099009359466\n",
      "num_qubits = 4,     vC = 0.10666137996665331\n",
      "num_qubits = 4,     vC = 0.07833986779440351\n",
      "num_qubits = 4,     vC = 0.13218418970127885\n",
      "num_qubits = 4,     vC = 0.01580564600993041\n",
      "num_qubits = 4,     vC = 0.17928652612255125\n",
      "num_qubits = 4,     vC = 0.33596737966559326\n",
      "num_qubits = 4,     vC = 0.11840722799404561\n",
      "num_qubits = 4,     vC = 0.3090776523292291\n",
      "num_qubits = 4,     vC = 0.04707704078794295\n",
      "num_qubits = 4,     vC = 0.23226050074582494\n",
      "num_qubits = 4,     vC = 0.20542239824872588\n",
      "num_qubits = 4,     vC = 0.10477748835745314\n",
      "num_qubits = 4,     vC = 0.19900923199497744\n",
      "num_qubits = 4,     vC = 0.14092796628225931\n",
      "num_qubits = 4,     vC = 0.0734947065275409\n",
      "num_qubits = 4,     vC = 0.13094771925905963\n",
      "num_qubits = 4,     vC = 0.08720929411362616\n",
      "num_qubits = 4,     vC = 0.09385186577744939\n",
      "num_qubits = 4,     vC = 0.27209157663778766\n",
      "num_qubits = 4,     vC = 0.0872417180050237\n",
      "num_qubits = 4,     vC = 0.19080470760978768\n",
      "num_qubits = 4,     vC = 0.23675630405944226\n",
      "num_qubits = 4,     vC = 0.03188233194162752\n",
      "num_qubits = 4,     vC = 0.2429013816788319\n",
      "num_qubits = 4,     vC = 0.19917360703110493\n",
      "num_qubits = 4,     vC = 0.06873810917264798\n",
      "num_qubits = 4,     vC = 0.14148925526814418\n",
      "num_qubits = 4,     vC = 0.06868571586292148\n",
      "num_qubits = 4,     vC = 0.010938600430468844\n",
      "num_qubits = 4,     vC = 0.06875123165347963\n",
      "num_qubits = 4,     vC = 0.20297878080189014\n",
      "num_qubits = 4,     vC = 0.18044890634896618\n",
      "num_qubits = 4,     vC = 0.07546077045059756\n",
      "num_qubits = 4,     vC = 0.27835716685999184\n",
      "num_qubits = 4,     vC = 0.0525824858547591\n",
      "num_qubits = 4,     vC = 0.14247202626841915\n",
      "num_qubits = 4,     vC = 0.05903387510964327\n",
      "num_qubits = 4,     vC = 0.18764295567131087\n",
      "num_qubits = 4,     vC = 0.1634620213767638\n",
      "num_qubits = 4,     vC = 0.15564898124933774\n",
      "num_qubits = 4,     vC = 0.11215311544079809\n",
      "num_qubits = 4,     vC = 0.05809591323225\n",
      "num_qubits = 4,     vC = 0.23736439279859062\n",
      "num_qubits = 4,     vC = 0.2750552754541901\n",
      "num_qubits = 4,     vC = 0.04311947261772337\n",
      "num_qubits = 4,     vC = 0.04864492501344186\n",
      "num_qubits = 4,     vC = 0.1890639159948469\n",
      "num_qubits = 4,     vC = 0.1875820749885587\n",
      "num_qubits = 4,     vC = 0.2716106002895575\n",
      "num_qubits = 4,     vC = 0.12928106844718462\n",
      "num_qubits = 4,     vC = 0.08177545450158766\n",
      "num_qubits = 4,     vC = 0.28909810752576276\n",
      "num_qubits = 4,     vC = 0.2627909940150522\n",
      "num_qubits = 4,     vC = 0.11361570599222713\n",
      "num_qubits = 4,     vC = 0.06553172506283615\n",
      "num_qubits = 4,     vC = 0.050980058131529234\n",
      "num_qubits = 4,     vC = 0.2740897971172779\n",
      "num_qubits = 4,     vC = 0.1741128068967882\n",
      "num_qubits = 4,     vC = 0.12764432595920996\n",
      "num_qubits = 4,     vC = 0.06453773207775039\n",
      "num_qubits = 4,     vC = 0.11519462294240973\n",
      "num_qubits = 4,     vC = 0.33337963879144156\n",
      "num_qubits = 4,     vC = 0.23768299535996879\n",
      "num_qubits = 4,     vC = 0.05205406206399551\n",
      "num_qubits = 4,     vC = 0.02419966264581576\n",
      "num_qubits = 5,     vC = 0.07432090042404897\n",
      "num_qubits = 5,     vC = 0.018736888856761842\n",
      "num_qubits = 5,     vC = 0.02951178725341984\n",
      "num_qubits = 5,     vC = 0.07560173607955485\n",
      "num_qubits = 5,     vC = 0.02231292338965984\n",
      "num_qubits = 5,     vC = 0.09407132730059553\n",
      "num_qubits = 5,     vC = 0.08231914097998999\n",
      "num_qubits = 5,     vC = 0.07839845686812426\n",
      "num_qubits = 5,     vC = 0.13477488700026807\n",
      "num_qubits = 5,     vC = 0.06771455117042019\n",
      "num_qubits = 5,     vC = 0.015500713445248152\n",
      "num_qubits = 5,     vC = 0.10931277522876295\n",
      "num_qubits = 5,     vC = 0.11786430268034923\n",
      "num_qubits = 5,     vC = 0.03322498444096795\n",
      "num_qubits = 5,     vC = 0.07052481461921078\n",
      "num_qubits = 5,     vC = 0.05024966105287302\n",
      "num_qubits = 5,     vC = 0.041696219038451734\n",
      "num_qubits = 5,     vC = 0.02987436574178345\n",
      "num_qubits = 5,     vC = 0.04427464911275634\n",
      "num_qubits = 5,     vC = 0.15561065696140503\n",
      "num_qubits = 5,     vC = 0.034223696633117\n",
      "num_qubits = 5,     vC = 0.0739154864717174\n",
      "num_qubits = 5,     vC = 0.09413150352693851\n",
      "num_qubits = 5,     vC = 0.023581315516060544\n",
      "num_qubits = 5,     vC = 0.019655166268317866\n",
      "num_qubits = 5,     vC = 0.03445082763383362\n",
      "num_qubits = 5,     vC = 0.029005504309354183\n",
      "num_qubits = 5,     vC = 0.103570335548145\n",
      "num_qubits = 5,     vC = 0.05152885779668004\n",
      "num_qubits = 5,     vC = 0.03665229690514581\n",
      "num_qubits = 5,     vC = 0.00908032652329054\n",
      "num_qubits = 5,     vC = 0.0501679566009856\n",
      "num_qubits = 5,     vC = 0.0869641154547295\n",
      "num_qubits = 5,     vC = 0.02166760949487506\n",
      "num_qubits = 5,     vC = 0.0853680031121798\n",
      "num_qubits = 5,     vC = 0.043088615441827106\n",
      "num_qubits = 5,     vC = 0.03019740406349302\n",
      "num_qubits = 5,     vC = 0.10775769937632373\n",
      "num_qubits = 5,     vC = 0.05294702390627563\n",
      "num_qubits = 5,     vC = 0.036992955283490586\n",
      "num_qubits = 5,     vC = 0.09545161179724437\n",
      "num_qubits = 5,     vC = 0.023465989452492494\n",
      "num_qubits = 5,     vC = 0.06756059004587318\n",
      "num_qubits = 5,     vC = 0.01758162778498755\n",
      "num_qubits = 5,     vC = 0.0705564257019039\n",
      "num_qubits = 5,     vC = 0.07303579845405869\n",
      "num_qubits = 5,     vC = 0.05969184782448714\n",
      "num_qubits = 5,     vC = 0.015093133996961279\n",
      "num_qubits = 5,     vC = 0.04864608175434466\n",
      "num_qubits = 5,     vC = 0.04876892878463176\n",
      "num_qubits = 5,     vC = 0.056094338986933556\n",
      "num_qubits = 5,     vC = 0.09550459236953049\n",
      "num_qubits = 5,     vC = 0.032211226970368406\n",
      "num_qubits = 5,     vC = 0.07645729566726407\n",
      "num_qubits = 5,     vC = 0.08504888339744968\n",
      "num_qubits = 5,     vC = 0.09340362941713087\n",
      "num_qubits = 5,     vC = 0.058814421597850164\n",
      "num_qubits = 5,     vC = 0.08154363091078785\n",
      "num_qubits = 5,     vC = 0.11212326325941177\n",
      "num_qubits = 5,     vC = 0.05936621803189403\n",
      "num_qubits = 5,     vC = 0.058875678300346124\n",
      "num_qubits = 5,     vC = 0.037380408773092136\n",
      "num_qubits = 5,     vC = 0.07385515082870539\n",
      "num_qubits = 5,     vC = 0.03987751797682632\n",
      "num_qubits = 5,     vC = 0.24647222025129562\n",
      "num_qubits = 5,     vC = 0.07589649767777962\n",
      "num_qubits = 5,     vC = 0.022507838000890304\n",
      "num_qubits = 5,     vC = 0.0394985941899808\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.11176210567551724\n",
      "num_qubits = 5,     vC = 0.04510400765588924\n",
      "num_qubits = 5,     vC = 0.02710708943380621\n",
      "num_qubits = 5,     vC = 0.11145258235305341\n",
      "num_qubits = 5,     vC = 0.02031479065848001\n",
      "num_qubits = 5,     vC = 0.04661913143712082\n",
      "num_qubits = 5,     vC = 0.11383175493177239\n",
      "num_qubits = 5,     vC = 0.11117712631735144\n",
      "num_qubits = 5,     vC = 0.04289601000899954\n",
      "num_qubits = 5,     vC = 0.0674537809017507\n",
      "num_qubits = 5,     vC = 0.02729861651994908\n",
      "num_qubits = 5,     vC = 0.1214166713820857\n",
      "num_qubits = 5,     vC = 0.13130067254659522\n",
      "num_qubits = 5,     vC = 0.03886464928386702\n",
      "num_qubits = 5,     vC = 0.0631595668373039\n",
      "num_qubits = 5,     vC = 0.14488123315798704\n",
      "num_qubits = 5,     vC = 0.028431660712078984\n",
      "num_qubits = 5,     vC = 0.1064345391187316\n",
      "num_qubits = 5,     vC = 0.006400091263276987\n",
      "num_qubits = 5,     vC = 0.010916054585881331\n",
      "num_qubits = 5,     vC = 0.016788809183674612\n",
      "num_qubits = 5,     vC = 0.017062231375531534\n",
      "num_qubits = 5,     vC = 0.03092514017163874\n",
      "num_qubits = 5,     vC = 0.05408891739815867\n",
      "num_qubits = 5,     vC = 0.07488867992299218\n",
      "num_qubits = 5,     vC = 0.04970477322470217\n",
      "num_qubits = 5,     vC = 0.01357180027596198\n",
      "num_qubits = 5,     vC = 0.0523789897109349\n",
      "num_qubits = 5,     vC = 0.10836634610524239\n",
      "num_qubits = 5,     vC = 0.039702911651652205\n",
      "num_qubits = 5,     vC = 0.07287361121287636\n",
      "num_qubits = 5,     vC = 0.04619530407777635\n",
      "num_qubits = 6,     vC = 0.04959059826947698\n",
      "num_qubits = 6,     vC = 0.007028233587585365\n",
      "num_qubits = 6,     vC = 0.04608971465131582\n",
      "num_qubits = 6,     vC = 0.024353640350903826\n",
      "num_qubits = 6,     vC = 0.07125048139257692\n",
      "num_qubits = 6,     vC = 0.01208722975890452\n",
      "num_qubits = 6,     vC = 0.005093928040902802\n",
      "num_qubits = 6,     vC = 0.019735899139512323\n",
      "num_qubits = 6,     vC = 0.031711493568168464\n",
      "num_qubits = 6,     vC = 0.040724426656301264\n",
      "num_qubits = 6,     vC = 0.05215019238023525\n",
      "num_qubits = 6,     vC = 0.011458600503301863\n",
      "num_qubits = 6,     vC = 0.01797021693525886\n",
      "num_qubits = 6,     vC = 0.06189657212794613\n",
      "num_qubits = 6,     vC = 0.03865054524735904\n",
      "num_qubits = 6,     vC = 0.04787945027830174\n",
      "num_qubits = 6,     vC = 0.05264352692197511\n",
      "num_qubits = 6,     vC = 0.016926000761711683\n",
      "num_qubits = 6,     vC = 0.02402011430938018\n",
      "num_qubits = 6,     vC = 0.04607374208290304\n",
      "num_qubits = 6,     vC = 0.058470003393676674\n",
      "num_qubits = 6,     vC = 0.04963441225761769\n",
      "num_qubits = 6,     vC = 0.011919400451840267\n",
      "num_qubits = 6,     vC = 0.011943833575474412\n",
      "num_qubits = 6,     vC = 0.025987885870811165\n",
      "num_qubits = 6,     vC = 0.03511476304431888\n",
      "num_qubits = 6,     vC = 0.0035318163373480324\n",
      "num_qubits = 6,     vC = 0.005879499471019299\n",
      "num_qubits = 6,     vC = 0.008127547487543386\n",
      "num_qubits = 6,     vC = 0.008138868095190538\n",
      "num_qubits = 6,     vC = 0.029270621149846125\n",
      "num_qubits = 6,     vC = 0.041556654631836575\n",
      "num_qubits = 6,     vC = 0.054341513944933306\n",
      "num_qubits = 6,     vC = 0.027729401562502514\n",
      "num_qubits = 6,     vC = 0.0450981233080943\n",
      "num_qubits = 6,     vC = 0.018049842809064652\n",
      "num_qubits = 6,     vC = 0.08463864900676128\n",
      "num_qubits = 6,     vC = 0.03063531296492348\n",
      "num_qubits = 6,     vC = 0.03439111103684993\n",
      "num_qubits = 6,     vC = 0.01621384998906482\n",
      "num_qubits = 6,     vC = 0.004314070452704838\n",
      "num_qubits = 6,     vC = 0.02864746243807848\n",
      "num_qubits = 6,     vC = 0.047781363204477956\n",
      "num_qubits = 6,     vC = 0.0071775600398385426\n",
      "num_qubits = 6,     vC = 0.01592006175968087\n",
      "num_qubits = 6,     vC = 0.0339661624256102\n",
      "num_qubits = 6,     vC = 0.035074285446263516\n",
      "num_qubits = 6,     vC = 0.0031621308668301645\n",
      "num_qubits = 6,     vC = 0.008111482782331347\n",
      "num_qubits = 6,     vC = 0.026420599370324524\n",
      "num_qubits = 6,     vC = 0.0585305825769018\n",
      "num_qubits = 6,     vC = 0.01964653670637427\n",
      "num_qubits = 6,     vC = 0.028001631389268013\n",
      "num_qubits = 6,     vC = 0.0600649819543178\n",
      "num_qubits = 6,     vC = 0.03373457427155445\n",
      "num_qubits = 6,     vC = 0.029810115336610814\n",
      "num_qubits = 6,     vC = 0.02835704001960868\n",
      "num_qubits = 6,     vC = 0.041036884638779754\n",
      "num_qubits = 6,     vC = 0.03843409595945096\n",
      "num_qubits = 6,     vC = 0.06605545819688256\n",
      "num_qubits = 6,     vC = 0.04534799804252293\n",
      "num_qubits = 6,     vC = 0.07180414377712663\n",
      "num_qubits = 6,     vC = 0.09056845945903194\n",
      "num_qubits = 6,     vC = 0.04604599602869086\n",
      "num_qubits = 6,     vC = 0.016116124954635467\n",
      "num_qubits = 6,     vC = 0.02359789584785607\n",
      "num_qubits = 6,     vC = 0.01249211443673892\n",
      "num_qubits = 6,     vC = 0.023980811447062385\n",
      "num_qubits = 6,     vC = 0.05444112727124518\n",
      "num_qubits = 6,     vC = 0.024915084938595428\n",
      "num_qubits = 6,     vC = 0.01984983400044003\n",
      "num_qubits = 6,     vC = 0.041822863064141375\n",
      "num_qubits = 6,     vC = 0.026362061914801085\n",
      "num_qubits = 6,     vC = 0.04389376498256713\n",
      "num_qubits = 6,     vC = 0.09596501945979323\n",
      "num_qubits = 6,     vC = 0.03271841438413254\n",
      "num_qubits = 6,     vC = 0.018725819503068678\n",
      "num_qubits = 6,     vC = 0.005397628421183515\n",
      "num_qubits = 6,     vC = 0.06918959200396199\n",
      "num_qubits = 6,     vC = 0.05349283520948758\n",
      "num_qubits = 6,     vC = 0.029642629700710417\n",
      "num_qubits = 6,     vC = 0.040100008953918374\n",
      "num_qubits = 6,     vC = 0.012027476663669165\n",
      "num_qubits = 6,     vC = 0.016391229799186856\n",
      "num_qubits = 6,     vC = 0.00947736953878709\n",
      "num_qubits = 6,     vC = 0.020887390377651773\n",
      "num_qubits = 6,     vC = 0.0094703003869882\n",
      "num_qubits = 6,     vC = 0.013914105083148448\n",
      "num_qubits = 6,     vC = 0.06641083101459322\n",
      "num_qubits = 6,     vC = 0.025490424885378126\n",
      "num_qubits = 6,     vC = 0.015162478139110286\n",
      "num_qubits = 6,     vC = 0.00959863322526817\n",
      "num_qubits = 6,     vC = 0.03111749730403681\n",
      "num_qubits = 6,     vC = 0.01833246815245497\n",
      "num_qubits = 6,     vC = 0.04380115874173573\n",
      "num_qubits = 6,     vC = 0.017747634394064335\n",
      "num_qubits = 6,     vC = 0.01843464573611377\n",
      "num_qubits = 6,     vC = 0.03887872981000584\n",
      "num_qubits = 6,     vC = 0.027047306634978636\n",
      "num_qubits = 6,     vC = 0.08115990662173529\n",
      "num_qubits = 7,     vC = 0.011236717107405944\n",
      "num_qubits = 7,     vC = 0.0005430856641286233\n",
      "num_qubits = 7,     vC = 0.009430715463504147\n",
      "num_qubits = 7,     vC = 0.012314511743481192\n",
      "num_qubits = 7,     vC = 0.0229614610708602\n",
      "num_qubits = 7,     vC = 0.009881185163453482\n",
      "num_qubits = 7,     vC = 0.04491558680849345\n",
      "num_qubits = 7,     vC = 0.04147130799633643\n",
      "num_qubits = 7,     vC = 0.013897411780357749\n",
      "num_qubits = 7,     vC = 0.007851605816948107\n",
      "num_qubits = 7,     vC = 0.005205231070759929\n",
      "num_qubits = 7,     vC = 0.005732692415663417\n",
      "num_qubits = 7,     vC = 0.010313975165656766\n",
      "num_qubits = 7,     vC = 0.01248789399721722\n",
      "num_qubits = 7,     vC = 0.011113920557483684\n",
      "num_qubits = 7,     vC = 0.008658940135483928\n",
      "num_qubits = 7,     vC = 0.017479502447911452\n",
      "num_qubits = 7,     vC = 0.0057840726905408965\n",
      "num_qubits = 7,     vC = 0.0406887467983093\n",
      "num_qubits = 7,     vC = 0.010304479025125652\n",
      "num_qubits = 7,     vC = 0.004257034606295971\n",
      "num_qubits = 7,     vC = 0.013854835245660758\n",
      "num_qubits = 7,     vC = 0.01102661585358345\n",
      "num_qubits = 7,     vC = 0.01545101593673949\n",
      "num_qubits = 7,     vC = 0.020722611173112124\n",
      "num_qubits = 7,     vC = 0.02710282215205361\n",
      "num_qubits = 7,     vC = 0.021014188656817926\n",
      "num_qubits = 7,     vC = 0.016163213035588847\n",
      "num_qubits = 7,     vC = 0.013652364131251449\n",
      "num_qubits = 7,     vC = 0.002449715120856337\n",
      "num_qubits = 7,     vC = 0.011337855511094643\n",
      "num_qubits = 7,     vC = 0.009267361865195793\n",
      "num_qubits = 7,     vC = 0.006374436134114883\n",
      "num_qubits = 7,     vC = 0.004647130740114213\n",
      "num_qubits = 7,     vC = 0.004453842874429875\n",
      "num_qubits = 7,     vC = 0.0186790945385453\n",
      "num_qubits = 7,     vC = 0.01615748217233009\n",
      "num_qubits = 7,     vC = 0.010292130690847192\n",
      "num_qubits = 7,     vC = 0.008858804817986341\n",
      "num_qubits = 7,     vC = 0.010508595878875607\n",
      "num_qubits = 7,     vC = 0.0041028722660665295\n",
      "num_qubits = 7,     vC = 0.008597594083123062\n",
      "num_qubits = 7,     vC = 0.012085670314942114\n",
      "num_qubits = 7,     vC = 0.014890521929251565\n",
      "num_qubits = 7,     vC = 0.005008493718200305\n",
      "num_qubits = 7,     vC = 0.0014898805780415387\n",
      "num_qubits = 7,     vC = 0.040068230306237185\n",
      "num_qubits = 7,     vC = 0.03242632050265725\n",
      "num_qubits = 7,     vC = 0.009005127516001464\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 7,     vC = 0.008723369959525088\n",
      "num_qubits = 7,     vC = 0.010481220579290115\n",
      "num_qubits = 7,     vC = 0.0050313208466156575\n",
      "num_qubits = 7,     vC = 0.022233483478047038\n",
      "num_qubits = 7,     vC = 0.014977786088763795\n",
      "num_qubits = 7,     vC = 0.012411583515682877\n",
      "num_qubits = 7,     vC = 0.03155892656722335\n",
      "num_qubits = 7,     vC = 0.008131990908487005\n",
      "num_qubits = 7,     vC = 0.00820538165342996\n",
      "num_qubits = 7,     vC = 0.0374965062731387\n",
      "num_qubits = 7,     vC = 0.016520918140135267\n",
      "num_qubits = 7,     vC = 0.024766491069109067\n",
      "num_qubits = 7,     vC = 0.048103500916997506\n",
      "num_qubits = 7,     vC = 0.0203334654215022\n",
      "num_qubits = 7,     vC = 0.04205273158413834\n",
      "num_qubits = 7,     vC = 0.016374397408710228\n",
      "num_qubits = 7,     vC = 0.04989874560835196\n",
      "num_qubits = 7,     vC = 0.0026391459383371778\n",
      "num_qubits = 7,     vC = 0.011556668304299411\n",
      "num_qubits = 7,     vC = 0.004536193800692218\n",
      "num_qubits = 7,     vC = 0.008224081309201386\n",
      "num_qubits = 7,     vC = 0.0017009461026425844\n",
      "num_qubits = 7,     vC = 0.0027778247498531517\n",
      "num_qubits = 7,     vC = 0.029409525777741953\n",
      "num_qubits = 7,     vC = 0.01485552746031689\n",
      "num_qubits = 7,     vC = 0.03207115390254628\n",
      "num_qubits = 7,     vC = 0.003091101686674345\n",
      "num_qubits = 7,     vC = 0.017728139464713452\n",
      "num_qubits = 7,     vC = 0.037241358088755665\n",
      "num_qubits = 7,     vC = 0.025981090453350224\n",
      "num_qubits = 7,     vC = 0.012087875540631302\n",
      "num_qubits = 7,     vC = 0.014569314174901229\n",
      "num_qubits = 7,     vC = 0.0049215525031828505\n",
      "num_qubits = 7,     vC = 0.034200825616639605\n",
      "num_qubits = 7,     vC = 0.003185148623127735\n",
      "num_qubits = 7,     vC = 0.025510009513205503\n",
      "num_qubits = 7,     vC = 0.034263483591449005\n",
      "num_qubits = 7,     vC = 0.012199194741343912\n",
      "num_qubits = 7,     vC = 0.029266900888213074\n",
      "num_qubits = 7,     vC = 0.023364372944028947\n",
      "num_qubits = 7,     vC = 0.004899918049039315\n",
      "num_qubits = 7,     vC = 0.014089057421860056\n",
      "num_qubits = 7,     vC = 0.03008890950796876\n",
      "num_qubits = 7,     vC = 0.02655920492554651\n",
      "num_qubits = 7,     vC = 0.07572362794551857\n",
      "num_qubits = 7,     vC = 0.008402209924870981\n",
      "num_qubits = 7,     vC = 0.007572679643532832\n",
      "num_qubits = 7,     vC = 0.010928966982236442\n",
      "num_qubits = 7,     vC = 0.046681068404778904\n",
      "num_qubits = 7,     vC = 0.031575398941632304\n",
      "num_qubits = 7,     vC = 0.008563122014326964\n",
      "num_qubits = 8,     vC = 0.00510780854070862\n",
      "num_qubits = 8,     vC = 0.009415505826173691\n",
      "num_qubits = 8,     vC = 0.00805253363645845\n",
      "num_qubits = 8,     vC = 0.025055642858828317\n",
      "num_qubits = 8,     vC = 0.006230386300678345\n",
      "num_qubits = 8,     vC = 0.013168583547304378\n",
      "num_qubits = 8,     vC = 0.022559621603750055\n",
      "num_qubits = 8,     vC = 0.005052882546520587\n",
      "num_qubits = 8,     vC = 0.0026839529336870364\n",
      "num_qubits = 8,     vC = 0.0029923622629545914\n",
      "num_qubits = 8,     vC = 0.008433486786916309\n",
      "num_qubits = 8,     vC = 0.0030561011644773483\n",
      "num_qubits = 8,     vC = 0.013431006630146958\n",
      "num_qubits = 8,     vC = 0.0010464276594423876\n",
      "num_qubits = 8,     vC = 0.012110717587428176\n",
      "num_qubits = 8,     vC = 0.009645252450271924\n",
      "num_qubits = 8,     vC = 0.011522991958128365\n",
      "num_qubits = 8,     vC = 0.001649276222062001\n",
      "num_qubits = 8,     vC = 0.013754439096669666\n",
      "num_qubits = 8,     vC = 0.004549003020695365\n",
      "num_qubits = 8,     vC = 0.013038846288805667\n",
      "num_qubits = 8,     vC = 0.011339774953097842\n",
      "num_qubits = 8,     vC = 0.002407027363247125\n",
      "num_qubits = 8,     vC = 0.008945216067231436\n",
      "num_qubits = 8,     vC = 0.005041263723977207\n",
      "num_qubits = 8,     vC = 0.010098544171592554\n",
      "num_qubits = 8,     vC = 0.0057012516392709045\n",
      "num_qubits = 8,     vC = 0.001990178021771802\n",
      "num_qubits = 8,     vC = 0.004382367629316612\n",
      "num_qubits = 8,     vC = 0.011939682814424172\n",
      "num_qubits = 8,     vC = 0.005437243083043766\n",
      "num_qubits = 8,     vC = 0.004726269201712639\n",
      "num_qubits = 8,     vC = 0.009619858720741834\n",
      "num_qubits = 8,     vC = 0.009150827067367006\n",
      "num_qubits = 8,     vC = 0.00719516808503931\n",
      "num_qubits = 8,     vC = 0.008974529085454026\n",
      "num_qubits = 8,     vC = 0.005923785857889153\n",
      "num_qubits = 8,     vC = 0.009076484605578847\n",
      "num_qubits = 8,     vC = 0.002356294592656574\n",
      "num_qubits = 8,     vC = 0.006718679136491027\n",
      "num_qubits = 8,     vC = 0.00506489101231293\n",
      "num_qubits = 8,     vC = 0.007379947231918468\n",
      "num_qubits = 8,     vC = 0.012315881899299112\n",
      "num_qubits = 8,     vC = 0.007158669051929846\n",
      "num_qubits = 8,     vC = 0.006709416157548657\n",
      "num_qubits = 8,     vC = 0.004443282131480339\n",
      "num_qubits = 8,     vC = 0.004561078138426415\n",
      "num_qubits = 8,     vC = 0.0021662557615552405\n",
      "num_qubits = 8,     vC = 0.00036964214315053835\n",
      "num_qubits = 8,     vC = 0.0024309135542613597\n",
      "num_qubits = 8,     vC = 0.009348321717015929\n",
      "num_qubits = 8,     vC = 0.014515491130842058\n",
      "num_qubits = 8,     vC = 0.011653869048849179\n",
      "num_qubits = 8,     vC = 0.007660323934223037\n",
      "num_qubits = 8,     vC = 0.004820662865760107\n",
      "num_qubits = 8,     vC = 0.0071545797773972415\n",
      "num_qubits = 8,     vC = 0.003875370812102941\n",
      "num_qubits = 8,     vC = 0.009202108303335062\n",
      "num_qubits = 8,     vC = 0.020695105442728772\n",
      "num_qubits = 8,     vC = 0.0010619691606629023\n",
      "num_qubits = 8,     vC = 0.0071942967038801505\n",
      "num_qubits = 8,     vC = 0.008166052642210958\n",
      "num_qubits = 8,     vC = 0.01225743853310597\n",
      "num_qubits = 8,     vC = 0.0051378207848478425\n",
      "num_qubits = 8,     vC = 0.003987377923449209\n",
      "num_qubits = 8,     vC = 0.01108171531280351\n",
      "num_qubits = 8,     vC = 0.018811032014548125\n",
      "num_qubits = 8,     vC = 0.005075645857814298\n",
      "num_qubits = 8,     vC = 0.012107147086826866\n",
      "num_qubits = 8,     vC = 0.007887187435561684\n",
      "num_qubits = 8,     vC = 0.020150819476907427\n",
      "num_qubits = 8,     vC = 0.00689466204373437\n",
      "num_qubits = 8,     vC = 0.007487673025779989\n",
      "num_qubits = 8,     vC = 0.0029394467968256806\n",
      "num_qubits = 8,     vC = 0.0035043156989926004\n",
      "num_qubits = 8,     vC = 0.005752290044887618\n",
      "num_qubits = 8,     vC = 0.0017382457691126178\n",
      "num_qubits = 8,     vC = 0.011023509854324903\n",
      "num_qubits = 8,     vC = 0.01208104060939124\n",
      "num_qubits = 8,     vC = 0.00931743826203767\n",
      "num_qubits = 8,     vC = 0.005089722575519334\n",
      "num_qubits = 8,     vC = 0.003431868987483566\n",
      "num_qubits = 8,     vC = 0.0017626587931960768\n",
      "num_qubits = 8,     vC = 0.014612129025563574\n",
      "num_qubits = 8,     vC = 0.017683913506441336\n",
      "num_qubits = 8,     vC = 0.0064655073640605635\n",
      "num_qubits = 8,     vC = 0.009365558308891037\n",
      "num_qubits = 8,     vC = 0.024535213251930386\n",
      "num_qubits = 8,     vC = 0.0050277927458644645\n",
      "num_qubits = 8,     vC = 0.006552854011796267\n",
      "num_qubits = 8,     vC = 0.0007259747521530978\n",
      "num_qubits = 8,     vC = 0.00785331018338878\n",
      "num_qubits = 8,     vC = 0.004882150496379885\n",
      "num_qubits = 8,     vC = 0.0029639654102152652\n",
      "num_qubits = 8,     vC = 0.0011890902006312766\n",
      "num_qubits = 8,     vC = 0.001503255591789242\n",
      "num_qubits = 8,     vC = 0.0041780855146419564\n",
      "num_qubits = 8,     vC = 0.008675738950601766\n",
      "num_qubits = 8,     vC = 0.007397952340251765\n",
      "num_qubits = 8,     vC = 0.007866374964783087\n",
      "num_qubits = 9,     vC = 0.0017868199640336735\n",
      "num_qubits = 9,     vC = 0.0009631338309820495\n",
      "num_qubits = 9,     vC = 0.0030253062218969034\n",
      "num_qubits = 9,     vC = 0.0029341311992352524\n",
      "num_qubits = 9,     vC = 0.0054473989934434065\n",
      "num_qubits = 9,     vC = 0.005665178081697282\n",
      "num_qubits = 9,     vC = 0.015399469569675027\n",
      "num_qubits = 9,     vC = 0.0017529722602290022\n",
      "num_qubits = 9,     vC = 0.004610041529118347\n",
      "num_qubits = 9,     vC = 0.002799857327248814\n",
      "num_qubits = 9,     vC = 0.002036608368076267\n",
      "num_qubits = 9,     vC = 0.006729423980026139\n",
      "num_qubits = 9,     vC = 0.005164674711939441\n",
      "num_qubits = 9,     vC = 0.004633263440879602\n",
      "num_qubits = 9,     vC = 0.0006083492818811233\n",
      "num_qubits = 9,     vC = 0.004185346746606532\n",
      "num_qubits = 9,     vC = 0.006361601355092322\n",
      "num_qubits = 9,     vC = 0.0020846406695370526\n",
      "num_qubits = 9,     vC = 0.008412706821564612\n",
      "num_qubits = 9,     vC = 0.006489525852526408\n",
      "num_qubits = 9,     vC = 0.0075094187664533005\n",
      "num_qubits = 9,     vC = 0.0016685795127244457\n",
      "num_qubits = 9,     vC = 0.0026839195216411577\n",
      "num_qubits = 9,     vC = 0.0036639217946108416\n",
      "num_qubits = 9,     vC = 0.002703876604442608\n",
      "num_qubits = 9,     vC = 0.0028059823521738095\n",
      "num_qubits = 9,     vC = 0.0025066511538902126\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 0.0016501838357498638\n",
      "num_qubits = 9,     vC = 0.003788698178555008\n",
      "num_qubits = 9,     vC = 0.0064954903178756\n",
      "num_qubits = 9,     vC = 0.001199168008888901\n",
      "num_qubits = 9,     vC = 0.0016089318408128446\n",
      "num_qubits = 9,     vC = 0.003164408800291261\n",
      "num_qubits = 9,     vC = 0.0063954219588747245\n",
      "num_qubits = 9,     vC = 0.006319778567734588\n",
      "num_qubits = 9,     vC = 0.0046896537074262905\n",
      "num_qubits = 9,     vC = 0.005731249990809988\n",
      "num_qubits = 9,     vC = 0.005739507049538626\n",
      "num_qubits = 9,     vC = 0.00015756660267575784\n",
      "num_qubits = 9,     vC = 0.001426040770694606\n",
      "num_qubits = 9,     vC = 0.0034500402312331465\n",
      "num_qubits = 9,     vC = 0.002078814716509379\n",
      "num_qubits = 9,     vC = 0.0029164961117303565\n",
      "num_qubits = 9,     vC = 0.003382741735255153\n",
      "num_qubits = 9,     vC = 0.011957782564306466\n",
      "num_qubits = 9,     vC = 0.002373823969869407\n",
      "num_qubits = 9,     vC = 0.006010698672724644\n",
      "num_qubits = 9,     vC = 0.0016165829560003144\n",
      "num_qubits = 9,     vC = 0.0030872105696794242\n",
      "num_qubits = 9,     vC = 0.00020464664326595887\n",
      "num_qubits = 9,     vC = 0.0024091786187750677\n",
      "num_qubits = 9,     vC = 0.00631218380414731\n",
      "num_qubits = 9,     vC = 0.002019788175954084\n",
      "num_qubits = 9,     vC = 0.005180722120756461\n",
      "num_qubits = 9,     vC = 0.004596035816530296\n",
      "num_qubits = 9,     vC = 0.003973228970033064\n",
      "num_qubits = 9,     vC = 0.006951853576861617\n",
      "num_qubits = 9,     vC = 0.0015052775039760405\n",
      "num_qubits = 9,     vC = 0.0038000381191964556\n",
      "num_qubits = 9,     vC = 0.001931561081871778\n",
      "num_qubits = 9,     vC = 0.0030620341634993355\n",
      "num_qubits = 9,     vC = 0.0019945206857353262\n",
      "num_qubits = 9,     vC = 0.003946777347081431\n",
      "num_qubits = 9,     vC = 0.002078816119494984\n",
      "num_qubits = 9,     vC = 0.0037620592715265195\n",
      "num_qubits = 9,     vC = 0.0015427563253944349\n",
      "num_qubits = 9,     vC = 0.006032542868445157\n",
      "num_qubits = 9,     vC = 0.003607654498186634\n",
      "num_qubits = 9,     vC = 0.0018597841100740434\n",
      "num_qubits = 9,     vC = 0.002940824155960563\n",
      "num_qubits = 9,     vC = 0.006059350524477675\n",
      "num_qubits = 9,     vC = 0.004562635810306385\n",
      "num_qubits = 9,     vC = 0.0035690421711582505\n",
      "num_qubits = 9,     vC = 0.0026571869872378095\n",
      "num_qubits = 9,     vC = 0.0007966116773082839\n",
      "num_qubits = 9,     vC = 0.0024844249302244125\n",
      "num_qubits = 9,     vC = 0.0019642578426505336\n",
      "num_qubits = 9,     vC = 0.0017104896409581398\n",
      "num_qubits = 9,     vC = 0.00037284092282581147\n",
      "num_qubits = 9,     vC = 0.00488817042708466\n",
      "num_qubits = 9,     vC = 0.0042600338111279095\n",
      "num_qubits = 9,     vC = 0.0051755309367751716\n",
      "num_qubits = 9,     vC = 0.002781562377574251\n",
      "num_qubits = 9,     vC = 0.010482020089827635\n",
      "num_qubits = 9,     vC = 0.004862176062128401\n",
      "num_qubits = 9,     vC = 0.0005953961779483099\n",
      "num_qubits = 9,     vC = 0.010078192224469037\n",
      "num_qubits = 9,     vC = 0.005495829805269094\n",
      "num_qubits = 9,     vC = 0.0013759986487438549\n",
      "num_qubits = 9,     vC = 0.00135922492245057\n",
      "num_qubits = 9,     vC = 0.006085240256657624\n",
      "num_qubits = 9,     vC = 0.00123722503051297\n",
      "num_qubits = 9,     vC = 0.004841865171511956\n",
      "num_qubits = 9,     vC = 0.009258647314046969\n",
      "num_qubits = 9,     vC = 0.006416880437249229\n",
      "num_qubits = 9,     vC = 0.0030056637359101687\n",
      "num_qubits = 9,     vC = 0.0029307687725606507\n",
      "num_qubits = 9,     vC = 0.0055144756531495176\n",
      "num_qubits = 9,     vC = 0.0029699730781111797\n",
      "num_qubits = 9,     vC = 0.004773051357868916\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(100):\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",
    "        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",
    "np.savetxt(\"QSL_inside_Adam\", loss_change)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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o3HjxgwZMoT06dPf8etPnjzJgw8+eC8/LpkzZ+bIkSNs3ryZjz/+mJYtW3LmzBkAUqRIQZ06dQAICwvj8OHDcX79TJkyceLEiXvKCCppPskYQ6FChXjjjTf4+eef2bdvH/Xr12fOnDnkzZv3hg12tSwqIiJuuXz5Mo0bN+app56iUaNGsfqeVKlSceHCheiPa9asSVhYGB06dCBjxoz89ddfXLlyBYBjx46RNWvWm14jZcqUZMyYEYDixYuTO3du9u7dC0Dy5MmjzwT6+/tz5coVrl69Gn2TQe/eve+Y8cKFC6RKlSpWP09MfGrHVGNMXaBunjx53I7iUR588EFat25N69atuXTpEitWrGDWrFk0atSIy5cvU6dOHerUqUPVqlUJCAhwO66IiCQB1lrat29P/vz56d69e6y/L3/+/AwaNCj643+vVftXlSpVmDFjBs2bN2fixInUr1//ptf47bffuP/++/H39+fgwYPs27ePXLly3fY9/f392bJlS6wz7t27l/Lly8f662/Hp86kees+aYkpRYoUVKtWjSFDhrB//37mzZtHzpw56devH5kyZYreYDc+TtOKiIjczs8//8ykSZNYvHhx9FmqOXPuPHQoX758REZGcvbs2Vt+vn///nz88cfkyZOH06dPR2/V8cMPP0SfBVu+fDmFCxcmLCyMJk2aMGLECO6///445e/ZsychISGcP3+ekJAQ+vTpc8PPVqNGjTi93q341Jk0iRtjDPnz5yd//vy8+uqr/PHHH/z000/MmjWL1157jVy5clG3bl3q1KlDsWLF4nwhqIiIyO1UqFDhri+5adeuHV999RUdOnS46XO5cuW65Z2V9erVo169egA0btyYxo0b3/K1z507F/37Bg0a8PTTT9/y6wYMGMCAAQNuen7z5s0ULFgwejn1XvjUmTS5N/fffz8tW7Zk6tSphIeHM3DgQM6ePUvLli0JCQmJ3mD3/PnzbkcVEZEkrHPnzqRMmdLtGLf0+++/33ID3ruhkia3lDx5cipXrszAgQPZs2cPS5YsIX/+/AwZMoTg4GCeeOIJRowYwdGjR92OKiIid8GbbxwLCAi47Rkut9WoUYMcOXLc8nNxPeYqaRIrefPmpVu3bixevJgjR47QunVrfv75Z4oWLUrRokWjN9i9du2a21FFROQOAgICOH36tFcXNW9jreX06dNx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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
}
