{
 "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.5021480951033095\n",
      "num_qubits = 2,     vC = 0.9246375796144509\n",
      "num_qubits = 2,     vC = 0.4265028615539658\n",
      "num_qubits = 2,     vC = 0.6568665546197348\n",
      "num_qubits = 2,     vC = 0.5635257833197875\n",
      "num_qubits = 2,     vC = 0.538866182677187\n",
      "num_qubits = 2,     vC = 0.6862762866186938\n",
      "num_qubits = 2,     vC = 0.7226223242666626\n",
      "num_qubits = 2,     vC = 0.7782141054896862\n",
      "num_qubits = 2,     vC = 0.7017035315045504\n",
      "num_qubits = 2,     vC = 0.30307155863395285\n",
      "num_qubits = 2,     vC = 0.6506064769659194\n",
      "num_qubits = 2,     vC = 0.4569322948559581\n",
      "num_qubits = 2,     vC = 0.5130381043349773\n",
      "num_qubits = 2,     vC = 0.37370164148613544\n",
      "num_qubits = 2,     vC = 0.31888159966574947\n",
      "num_qubits = 2,     vC = 0.6270119048562538\n",
      "num_qubits = 2,     vC = 0.6835938113495648\n",
      "num_qubits = 2,     vC = 0.36576665129384506\n",
      "num_qubits = 2,     vC = 0.4605993271779209\n",
      "num_qubits = 2,     vC = 0.5485203600544194\n",
      "num_qubits = 2,     vC = 0.716763211833654\n",
      "num_qubits = 2,     vC = 0.6644078417773951\n",
      "num_qubits = 2,     vC = 0.46147302108232785\n",
      "num_qubits = 2,     vC = 0.9023789204627896\n",
      "num_qubits = 2,     vC = 0.5479103262326044\n",
      "num_qubits = 2,     vC = 0.6979230253068989\n",
      "num_qubits = 2,     vC = 0.6215127754184274\n",
      "num_qubits = 2,     vC = 0.4814818539319406\n",
      "num_qubits = 2,     vC = 0.49666479214415277\n",
      "num_qubits = 2,     vC = 0.6678742493023087\n",
      "num_qubits = 2,     vC = 0.5861682360815864\n",
      "num_qubits = 2,     vC = 0.9210620326151765\n",
      "num_qubits = 2,     vC = 0.5348707028997912\n",
      "num_qubits = 2,     vC = 0.9740429030706671\n",
      "num_qubits = 2,     vC = 0.4088548617536167\n",
      "num_qubits = 2,     vC = 0.16806524617698265\n",
      "num_qubits = 2,     vC = 0.6909092992631793\n",
      "num_qubits = 2,     vC = 0.293595381516709\n",
      "num_qubits = 2,     vC = 0.5974639113377207\n",
      "num_qubits = 2,     vC = 0.7476531093490796\n",
      "num_qubits = 2,     vC = 0.5877683715529366\n",
      "num_qubits = 2,     vC = 0.5910824727924092\n",
      "num_qubits = 2,     vC = 0.6383300153732134\n",
      "num_qubits = 2,     vC = 0.8826445497290198\n",
      "num_qubits = 2,     vC = 0.7413225435356006\n",
      "num_qubits = 2,     vC = 0.5411903108163967\n",
      "num_qubits = 2,     vC = 0.9205855231943235\n",
      "num_qubits = 2,     vC = 0.6169050827573689\n",
      "num_qubits = 2,     vC = 0.3959876851588307\n",
      "num_qubits = 2,     vC = 0.24422146323176708\n",
      "num_qubits = 2,     vC = 0.5833416697241165\n",
      "num_qubits = 2,     vC = 0.8241983316759792\n",
      "num_qubits = 2,     vC = 0.6447165466917989\n",
      "num_qubits = 2,     vC = 0.6705277791072575\n",
      "num_qubits = 2,     vC = 0.37342179316310337\n",
      "num_qubits = 2,     vC = 0.4827155438246034\n",
      "num_qubits = 2,     vC = 0.3393862663528776\n",
      "num_qubits = 2,     vC = 0.7816596319808387\n",
      "num_qubits = 2,     vC = 0.4266439184103957\n",
      "num_qubits = 2,     vC = 0.45260548289837116\n",
      "num_qubits = 2,     vC = 0.1689346666493343\n",
      "num_qubits = 2,     vC = 0.6612630920795839\n",
      "num_qubits = 2,     vC = 0.8562769355736262\n",
      "num_qubits = 2,     vC = 0.9093105916258911\n",
      "num_qubits = 2,     vC = 0.6063931801158233\n",
      "num_qubits = 2,     vC = 0.4710441861157062\n",
      "num_qubits = 2,     vC = 0.12459205385323308\n",
      "num_qubits = 2,     vC = 0.7184115788590357\n",
      "num_qubits = 2,     vC = 0.6831407982973796\n",
      "num_qubits = 2,     vC = 0.4618682550807094\n",
      "num_qubits = 2,     vC = 0.11529143685334109\n",
      "num_qubits = 2,     vC = 0.44947769347322614\n",
      "num_qubits = 2,     vC = 0.4116836946516657\n",
      "num_qubits = 2,     vC = 0.8426093585501189\n",
      "num_qubits = 2,     vC = 0.9203921621325634\n",
      "num_qubits = 2,     vC = 0.7020177759313219\n",
      "num_qubits = 2,     vC = 0.4855524157115772\n",
      "num_qubits = 2,     vC = 0.5076779361853241\n",
      "num_qubits = 2,     vC = 0.3503598352509186\n",
      "num_qubits = 2,     vC = 0.8153653370298466\n",
      "num_qubits = 2,     vC = 0.5753459104831332\n",
      "num_qubits = 2,     vC = 0.2678753405287598\n",
      "num_qubits = 2,     vC = 0.6547927977665746\n",
      "num_qubits = 2,     vC = 0.3601181097293307\n",
      "num_qubits = 2,     vC = 0.5690263588740984\n",
      "num_qubits = 2,     vC = 0.6623783833632861\n",
      "num_qubits = 2,     vC = 0.2822505862231199\n",
      "num_qubits = 2,     vC = 0.5507003666283516\n",
      "num_qubits = 2,     vC = 0.5890119719494309\n",
      "num_qubits = 2,     vC = 0.7778567782043575\n",
      "num_qubits = 2,     vC = 0.7306787877483014\n",
      "num_qubits = 2,     vC = 0.24516695296035781\n",
      "num_qubits = 2,     vC = 0.6487670370327968\n",
      "num_qubits = 2,     vC = 0.31970204548358094\n",
      "num_qubits = 2,     vC = 0.9458249637168697\n",
      "num_qubits = 2,     vC = 0.5758096782856652\n",
      "num_qubits = 2,     vC = 0.5108026162627206\n",
      "num_qubits = 2,     vC = 0.5620104041277465\n",
      "num_qubits = 2,     vC = 0.8772843133523788\n",
      "num_qubits = 3,     vC = 0.41904160920596006\n",
      "num_qubits = 3,     vC = 0.1910557566689235\n",
      "num_qubits = 3,     vC = 0.5465653423629666\n",
      "num_qubits = 3,     vC = 0.26254376527307866\n",
      "num_qubits = 3,     vC = 0.260335548941097\n",
      "num_qubits = 3,     vC = 0.36948570529012315\n",
      "num_qubits = 3,     vC = 0.6408900650730137\n",
      "num_qubits = 3,     vC = 0.580542202540364\n",
      "num_qubits = 3,     vC = 0.43802591189019824\n",
      "num_qubits = 3,     vC = 0.5097284300525984\n",
      "num_qubits = 3,     vC = 0.5500390617540579\n",
      "num_qubits = 3,     vC = 0.37867714275586367\n",
      "num_qubits = 3,     vC = 0.33077679902663826\n",
      "num_qubits = 3,     vC = 0.5929113837606279\n",
      "num_qubits = 3,     vC = 0.10455787918500203\n",
      "num_qubits = 3,     vC = 0.670733404384501\n",
      "num_qubits = 3,     vC = 0.1371314638153487\n",
      "num_qubits = 3,     vC = 0.2633140709536163\n",
      "num_qubits = 3,     vC = 0.5561210722351007\n",
      "num_qubits = 3,     vC = 0.4420647172740102\n",
      "num_qubits = 3,     vC = 0.6080738138442698\n",
      "num_qubits = 3,     vC = 0.0639423071037073\n",
      "num_qubits = 3,     vC = 0.38513009233283935\n",
      "num_qubits = 3,     vC = 0.11783650810016921\n",
      "num_qubits = 3,     vC = 0.591405861282096\n",
      "num_qubits = 3,     vC = 0.7911705355346837\n",
      "num_qubits = 3,     vC = 0.18096391366817144\n",
      "num_qubits = 3,     vC = 0.6008786676436606\n",
      "num_qubits = 3,     vC = 0.43123365395890084\n",
      "num_qubits = 3,     vC = 0.7513550485653055\n",
      "num_qubits = 3,     vC = 0.3851707322408726\n",
      "num_qubits = 3,     vC = 0.3933183859309821\n",
      "num_qubits = 3,     vC = 0.3276570467986163\n",
      "num_qubits = 3,     vC = 0.35873525643023807\n",
      "num_qubits = 3,     vC = 0.662715695276606\n",
      "num_qubits = 3,     vC = 0.254875094020037\n",
      "num_qubits = 3,     vC = 0.6028069787107567\n",
      "num_qubits = 3,     vC = 0.19351308546255674\n",
      "num_qubits = 3,     vC = 0.5526174539591271\n",
      "num_qubits = 3,     vC = 0.5374706492578847\n",
      "num_qubits = 3,     vC = 0.42839450667004864\n",
      "num_qubits = 3,     vC = 0.4231967767245238\n",
      "num_qubits = 3,     vC = 0.6787954319933015\n",
      "num_qubits = 3,     vC = 0.1099569013229803\n",
      "num_qubits = 3,     vC = 0.41315567443012946\n",
      "num_qubits = 3,     vC = 0.3450493517362514\n",
      "num_qubits = 3,     vC = 0.4482861593350992\n",
      "num_qubits = 3,     vC = 0.2901156346334972\n",
      "num_qubits = 3,     vC = 0.38054654746717287\n",
      "num_qubits = 3,     vC = 0.13632279714904158\n",
      "num_qubits = 3,     vC = 0.6740381534016573\n",
      "num_qubits = 3,     vC = 0.3930384005276624\n",
      "num_qubits = 3,     vC = 0.2252137082828839\n",
      "num_qubits = 3,     vC = 0.7289769885232067\n",
      "num_qubits = 3,     vC = 0.4560956497125955\n",
      "num_qubits = 3,     vC = 0.48041054736821126\n",
      "num_qubits = 3,     vC = 0.11975052439110101\n",
      "num_qubits = 3,     vC = 0.1538527469827734\n",
      "num_qubits = 3,     vC = 0.15516706713312384\n",
      "num_qubits = 3,     vC = 0.37474959344791353\n",
      "num_qubits = 3,     vC = 0.3921913773319557\n",
      "num_qubits = 3,     vC = 0.30109108719397737\n",
      "num_qubits = 3,     vC = 0.45172383747734435\n",
      "num_qubits = 3,     vC = 0.4976805626295442\n",
      "num_qubits = 3,     vC = 0.5371578916578568\n",
      "num_qubits = 3,     vC = 0.27585588137275974\n",
      "num_qubits = 3,     vC = 0.2731724986557078\n",
      "num_qubits = 3,     vC = 0.2869374803754615\n",
      "num_qubits = 3,     vC = 0.224703678858863\n",
      "num_qubits = 3,     vC = 0.6446477982111893\n",
      "num_qubits = 3,     vC = 0.5137972829510735\n",
      "num_qubits = 3,     vC = 0.44454581971713253\n",
      "num_qubits = 3,     vC = 0.4943599197785855\n",
      "num_qubits = 3,     vC = 0.3188906699657229\n",
      "num_qubits = 3,     vC = 0.43664587606745986\n",
      "num_qubits = 3,     vC = 0.8359167842163606\n",
      "num_qubits = 3,     vC = 0.3388995484915629\n",
      "num_qubits = 3,     vC = 0.42403702845446006\n",
      "num_qubits = 3,     vC = 0.7216479721714264\n",
      "num_qubits = 3,     vC = 0.6237256953298252\n",
      "num_qubits = 3,     vC = 0.35133518551486653\n",
      "num_qubits = 3,     vC = 0.39038009013179076\n",
      "num_qubits = 3,     vC = 0.3567678490254351\n",
      "num_qubits = 3,     vC = 0.5285746274379606\n",
      "num_qubits = 3,     vC = 0.3784965394385123\n",
      "num_qubits = 3,     vC = 0.568016756688106\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 3,     vC = 0.33578233109244127\n",
      "num_qubits = 3,     vC = 0.42021507440936046\n",
      "num_qubits = 3,     vC = 0.4325162284937032\n",
      "num_qubits = 3,     vC = 0.19842333916843635\n",
      "num_qubits = 3,     vC = 0.4873836891228597\n",
      "num_qubits = 3,     vC = 0.3537691782495819\n",
      "num_qubits = 3,     vC = 0.5439913988917893\n",
      "num_qubits = 3,     vC = 0.47445899613042486\n",
      "num_qubits = 3,     vC = 0.5184272294898593\n",
      "num_qubits = 3,     vC = 0.3565634636916735\n",
      "num_qubits = 3,     vC = 0.3260945671124773\n",
      "num_qubits = 3,     vC = 0.20182067547501614\n",
      "num_qubits = 3,     vC = 0.32525528266355236\n",
      "num_qubits = 3,     vC = 0.5779471425023377\n",
      "num_qubits = 4,     vC = 0.24145087288077793\n",
      "num_qubits = 4,     vC = 0.1146346241591798\n",
      "num_qubits = 4,     vC = 0.26492495218463785\n",
      "num_qubits = 4,     vC = 0.3857389314971091\n",
      "num_qubits = 4,     vC = 0.26597244574630985\n",
      "num_qubits = 4,     vC = 0.19086790518967056\n",
      "num_qubits = 4,     vC = 0.30055504262913446\n",
      "num_qubits = 4,     vC = 0.28625196050657487\n",
      "num_qubits = 4,     vC = 0.28323755731610245\n",
      "num_qubits = 4,     vC = 0.39775296010631433\n",
      "num_qubits = 4,     vC = 0.1326169164412786\n",
      "num_qubits = 4,     vC = 0.13801409896193\n",
      "num_qubits = 4,     vC = 0.1556887266838099\n",
      "num_qubits = 4,     vC = 0.4011281740545513\n",
      "num_qubits = 4,     vC = 0.1297068998958435\n",
      "num_qubits = 4,     vC = 0.33299403352427714\n",
      "num_qubits = 4,     vC = 0.18429205789241787\n",
      "num_qubits = 4,     vC = 0.32149673644155224\n",
      "num_qubits = 4,     vC = 0.1443853168959658\n",
      "num_qubits = 4,     vC = 0.18865434797518654\n",
      "num_qubits = 4,     vC = 0.22576361179563975\n",
      "num_qubits = 4,     vC = 0.4734620958461977\n",
      "num_qubits = 4,     vC = 0.34179681114738014\n",
      "num_qubits = 4,     vC = 0.5282570454535686\n",
      "num_qubits = 4,     vC = 0.18713764611449568\n",
      "num_qubits = 4,     vC = 0.40029040770503677\n",
      "num_qubits = 4,     vC = 0.37095945354437876\n",
      "num_qubits = 4,     vC = 0.36049803295329497\n",
      "num_qubits = 4,     vC = 0.11339972635434692\n",
      "num_qubits = 4,     vC = 0.17191042333444306\n",
      "num_qubits = 4,     vC = 0.25007397954314403\n",
      "num_qubits = 4,     vC = 0.4013264010564316\n",
      "num_qubits = 4,     vC = 0.6026949476588603\n",
      "num_qubits = 4,     vC = 0.4377215753548916\n",
      "num_qubits = 4,     vC = 0.2971233438242389\n",
      "num_qubits = 4,     vC = 0.1451648489358296\n",
      "num_qubits = 4,     vC = 0.4521812499736733\n",
      "num_qubits = 4,     vC = 0.31602309191150335\n",
      "num_qubits = 4,     vC = 0.1298698963256567\n",
      "num_qubits = 4,     vC = 0.2636972326198169\n",
      "num_qubits = 4,     vC = 0.22989807852639288\n",
      "num_qubits = 4,     vC = 0.44111842220095077\n",
      "num_qubits = 4,     vC = 0.40990188394963223\n",
      "num_qubits = 4,     vC = 0.18726120649556588\n",
      "num_qubits = 4,     vC = 0.31249658010500037\n",
      "num_qubits = 4,     vC = 0.205979420496891\n",
      "num_qubits = 4,     vC = 0.20517439891289269\n",
      "num_qubits = 4,     vC = 0.29440279083552034\n",
      "num_qubits = 4,     vC = 0.3883825758916685\n",
      "num_qubits = 4,     vC = 0.3233089083806695\n",
      "num_qubits = 4,     vC = 0.29289359344740656\n",
      "num_qubits = 4,     vC = 0.4623891087750931\n",
      "num_qubits = 4,     vC = 0.33771361800523464\n",
      "num_qubits = 4,     vC = 0.2908765588659094\n",
      "num_qubits = 4,     vC = 0.068816739638065\n",
      "num_qubits = 4,     vC = 0.3681248466114125\n",
      "num_qubits = 4,     vC = 0.3026128439226513\n",
      "num_qubits = 4,     vC = 0.23207949338459588\n",
      "num_qubits = 4,     vC = 0.37757693658258307\n",
      "num_qubits = 4,     vC = 0.30019554327658227\n",
      "num_qubits = 4,     vC = 0.19234811619908798\n",
      "num_qubits = 4,     vC = 0.1378174532295724\n",
      "num_qubits = 4,     vC = 0.48685009065305235\n",
      "num_qubits = 4,     vC = 0.12054385038139881\n",
      "num_qubits = 4,     vC = 0.2596040685219543\n",
      "num_qubits = 4,     vC = 0.11037182505345666\n",
      "num_qubits = 4,     vC = 0.1129782614864614\n",
      "num_qubits = 4,     vC = 0.1938912833236141\n",
      "num_qubits = 4,     vC = 0.3413340405412617\n",
      "num_qubits = 4,     vC = 0.1480687025597815\n",
      "num_qubits = 4,     vC = 0.30526960457156027\n",
      "num_qubits = 4,     vC = 0.3083690997986056\n",
      "num_qubits = 4,     vC = 0.4528950862808967\n",
      "num_qubits = 4,     vC = 0.09989892441084247\n",
      "num_qubits = 4,     vC = 0.3149377344682307\n",
      "num_qubits = 4,     vC = 0.18296232379639255\n",
      "num_qubits = 4,     vC = 0.46916814328198836\n",
      "num_qubits = 4,     vC = 0.4546179394394363\n",
      "num_qubits = 4,     vC = 0.19940130194629124\n",
      "num_qubits = 4,     vC = 0.3537002364918933\n",
      "num_qubits = 4,     vC = 0.41230129346899774\n",
      "num_qubits = 4,     vC = 0.3179389318637838\n",
      "num_qubits = 4,     vC = 0.5870399068967467\n",
      "num_qubits = 4,     vC = 0.1662317129319203\n",
      "num_qubits = 4,     vC = 0.3399212122483058\n",
      "num_qubits = 4,     vC = 0.2540819920785989\n",
      "num_qubits = 4,     vC = 0.250350691007507\n",
      "num_qubits = 4,     vC = 0.14056250210747656\n",
      "num_qubits = 4,     vC = 0.11132323540288358\n",
      "num_qubits = 4,     vC = 0.12098730188868956\n",
      "num_qubits = 4,     vC = 0.35292637760558787\n",
      "num_qubits = 4,     vC = 0.19012720385016685\n",
      "num_qubits = 4,     vC = 0.13073651123049357\n",
      "num_qubits = 4,     vC = 0.1472200023257919\n",
      "num_qubits = 4,     vC = 0.35195873089705615\n",
      "num_qubits = 4,     vC = 0.16655406353425734\n",
      "num_qubits = 4,     vC = 0.5103152012068559\n",
      "num_qubits = 4,     vC = 0.18035560108648996\n",
      "num_qubits = 4,     vC = 0.3699326548409762\n",
      "num_qubits = 4,     vC = 0.23100086780960433\n",
      "num_qubits = 5,     vC = 0.2685769053706383\n",
      "num_qubits = 5,     vC = 0.164127783322623\n",
      "num_qubits = 5,     vC = 0.2764272102977256\n",
      "num_qubits = 5,     vC = 0.13782765931468155\n",
      "num_qubits = 5,     vC = 0.24004807078454188\n",
      "num_qubits = 5,     vC = 0.3275387372188015\n",
      "num_qubits = 5,     vC = 0.061533533987112365\n",
      "num_qubits = 5,     vC = 0.26162546123832775\n",
      "num_qubits = 5,     vC = 0.3414201036884037\n",
      "num_qubits = 5,     vC = 0.07583339387097165\n",
      "num_qubits = 5,     vC = 0.28443189848920725\n",
      "num_qubits = 5,     vC = 0.06527597573835431\n",
      "num_qubits = 5,     vC = 0.27039259743537464\n",
      "num_qubits = 5,     vC = 0.263837709533667\n",
      "num_qubits = 5,     vC = 0.23550298116401103\n",
      "num_qubits = 5,     vC = 0.15281784167827467\n",
      "num_qubits = 5,     vC = 0.12796875254424162\n",
      "num_qubits = 5,     vC = 0.14992170258776083\n",
      "num_qubits = 5,     vC = 0.20193693755154524\n",
      "num_qubits = 5,     vC = 0.32444791766899356\n",
      "num_qubits = 5,     vC = 0.1571989533426511\n",
      "num_qubits = 5,     vC = 0.20764706790424972\n",
      "num_qubits = 5,     vC = 0.18938561793834596\n",
      "num_qubits = 5,     vC = 0.17022807886504465\n",
      "num_qubits = 5,     vC = 0.29365497351175296\n",
      "num_qubits = 5,     vC = 0.10708603277541706\n",
      "num_qubits = 5,     vC = 0.12607016556443462\n",
      "num_qubits = 5,     vC = 0.2896019497791752\n",
      "num_qubits = 5,     vC = 0.19320738379188318\n",
      "num_qubits = 5,     vC = 0.14643873708705574\n",
      "num_qubits = 5,     vC = 0.10611962574958356\n",
      "num_qubits = 5,     vC = 0.10946223357605805\n",
      "num_qubits = 5,     vC = 0.06442184391747263\n",
      "num_qubits = 5,     vC = 0.16182283074984477\n",
      "num_qubits = 5,     vC = 0.13177612229157815\n",
      "num_qubits = 5,     vC = 0.12439830036355393\n",
      "num_qubits = 5,     vC = 0.3708789351881117\n",
      "num_qubits = 5,     vC = 0.25918814698927084\n",
      "num_qubits = 5,     vC = 0.19479807046540276\n",
      "num_qubits = 5,     vC = 0.3043820136174943\n",
      "num_qubits = 5,     vC = 0.38889166131876096\n",
      "num_qubits = 5,     vC = 0.16596479447035356\n",
      "num_qubits = 5,     vC = 0.3554499743637878\n",
      "num_qubits = 5,     vC = 0.2225816650370665\n",
      "num_qubits = 5,     vC = 0.1808661115961967\n",
      "num_qubits = 5,     vC = 0.19171774870201158\n",
      "num_qubits = 5,     vC = 0.18823444856352645\n",
      "num_qubits = 5,     vC = 0.3669724230229822\n",
      "num_qubits = 5,     vC = 0.27575703300557425\n",
      "num_qubits = 5,     vC = 0.13821400093641661\n",
      "num_qubits = 5,     vC = 0.2857192572843534\n",
      "num_qubits = 5,     vC = 0.2111860045826004\n",
      "num_qubits = 5,     vC = 0.14332852343643832\n",
      "num_qubits = 5,     vC = 0.3060304438954831\n",
      "num_qubits = 5,     vC = 0.19010874804159555\n",
      "num_qubits = 5,     vC = 0.11334337314405829\n",
      "num_qubits = 5,     vC = 0.112366440765582\n",
      "num_qubits = 5,     vC = 0.1344315234903799\n",
      "num_qubits = 5,     vC = 0.21995580545848403\n",
      "num_qubits = 5,     vC = 0.22379523426785985\n",
      "num_qubits = 5,     vC = 0.20745620513788715\n",
      "num_qubits = 5,     vC = 0.1681440365404876\n",
      "num_qubits = 5,     vC = 0.17028666584916813\n",
      "num_qubits = 5,     vC = 0.1327710828167164\n",
      "num_qubits = 5,     vC = 0.2682840593012922\n",
      "num_qubits = 5,     vC = 0.23303774293200347\n",
      "num_qubits = 5,     vC = 0.31928086106422465\n",
      "num_qubits = 5,     vC = 0.15777724655682657\n",
      "num_qubits = 5,     vC = 0.2336272361771226\n",
      "num_qubits = 5,     vC = 0.17841383037019182\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.32948105361742913\n",
      "num_qubits = 5,     vC = 0.30974380641785154\n",
      "num_qubits = 5,     vC = 0.07833618273710685\n",
      "num_qubits = 5,     vC = 0.13536997676993628\n",
      "num_qubits = 5,     vC = 0.3782536442204137\n",
      "num_qubits = 5,     vC = 0.1631922412807263\n",
      "num_qubits = 5,     vC = 0.29073887911137264\n",
      "num_qubits = 5,     vC = 0.2144056891281898\n",
      "num_qubits = 5,     vC = 0.3042563405272277\n",
      "num_qubits = 5,     vC = 0.14137905820980767\n",
      "num_qubits = 5,     vC = 0.39801249876990563\n",
      "num_qubits = 5,     vC = 0.16095336022386802\n",
      "num_qubits = 5,     vC = 0.28409041416382036\n",
      "num_qubits = 5,     vC = 0.2737572689836152\n",
      "num_qubits = 5,     vC = 0.10754454387561269\n",
      "num_qubits = 5,     vC = 0.27553276182708963\n",
      "num_qubits = 5,     vC = 0.10302127793851129\n",
      "num_qubits = 5,     vC = 0.2190423604117233\n",
      "num_qubits = 5,     vC = 0.108385553779902\n",
      "num_qubits = 5,     vC = 0.08642007123383155\n",
      "num_qubits = 5,     vC = 0.1273165470631945\n",
      "num_qubits = 5,     vC = 0.09394669922004673\n",
      "num_qubits = 5,     vC = 0.07276784306531947\n",
      "num_qubits = 5,     vC = 0.28837952915633974\n",
      "num_qubits = 5,     vC = 0.12211859673059411\n",
      "num_qubits = 5,     vC = 0.25860016645645834\n",
      "num_qubits = 5,     vC = 0.24587263039398505\n",
      "num_qubits = 5,     vC = 0.2618580254011357\n",
      "num_qubits = 5,     vC = 0.2824416211370019\n",
      "num_qubits = 5,     vC = 0.16474153941093544\n",
      "num_qubits = 6,     vC = 0.1463674715938761\n",
      "num_qubits = 6,     vC = 0.21694826570618353\n",
      "num_qubits = 6,     vC = 0.07689702386082342\n",
      "num_qubits = 6,     vC = 0.19338121870103742\n",
      "num_qubits = 6,     vC = 0.22350859520311633\n",
      "num_qubits = 6,     vC = 0.16539385620793512\n",
      "num_qubits = 6,     vC = 0.15174179661556336\n",
      "num_qubits = 6,     vC = 0.10529403757223033\n",
      "num_qubits = 6,     vC = 0.15636618624873905\n",
      "num_qubits = 6,     vC = 0.1582505408191608\n",
      "num_qubits = 6,     vC = 0.20632979090181613\n",
      "num_qubits = 6,     vC = 0.0661490537886063\n",
      "num_qubits = 6,     vC = 0.22088525421772848\n",
      "num_qubits = 6,     vC = 0.08200669294941743\n",
      "num_qubits = 6,     vC = 0.19370343601980788\n",
      "num_qubits = 6,     vC = 0.17267944761278792\n",
      "num_qubits = 6,     vC = 0.04115378390633906\n",
      "num_qubits = 6,     vC = 0.25513034100406967\n",
      "num_qubits = 6,     vC = 0.127113816578715\n",
      "num_qubits = 6,     vC = 0.06175926528180098\n",
      "num_qubits = 6,     vC = 0.0821019275424194\n",
      "num_qubits = 6,     vC = 0.12371495058721688\n",
      "num_qubits = 6,     vC = 0.2443120298162188\n",
      "num_qubits = 6,     vC = 0.09199288802548622\n",
      "num_qubits = 6,     vC = 0.17424922227066936\n",
      "num_qubits = 6,     vC = 0.11622645152406275\n",
      "num_qubits = 6,     vC = 0.24415842484238998\n",
      "num_qubits = 6,     vC = 0.031885418564972734\n",
      "num_qubits = 6,     vC = 0.1280775950601437\n",
      "num_qubits = 6,     vC = 0.20535395387440292\n",
      "num_qubits = 6,     vC = 0.07503207017463026\n",
      "num_qubits = 6,     vC = 0.2729631400337891\n",
      "num_qubits = 6,     vC = 0.12965800070330102\n",
      "num_qubits = 6,     vC = 0.13863449298371033\n",
      "num_qubits = 6,     vC = 0.062452861081528366\n",
      "num_qubits = 6,     vC = 0.21266274899125692\n",
      "num_qubits = 6,     vC = 0.18162439459017654\n",
      "num_qubits = 6,     vC = 0.21296843857490422\n",
      "num_qubits = 6,     vC = 0.1177208506653592\n",
      "num_qubits = 6,     vC = 0.14866160217602958\n",
      "num_qubits = 6,     vC = 0.12175137618055287\n",
      "num_qubits = 6,     vC = 0.023379123433682314\n",
      "num_qubits = 6,     vC = 0.04081345371590095\n",
      "num_qubits = 6,     vC = 0.1414835103075881\n",
      "num_qubits = 6,     vC = 0.09349941461093186\n",
      "num_qubits = 6,     vC = 0.07504226707359613\n",
      "num_qubits = 6,     vC = 0.268356495560607\n",
      "num_qubits = 6,     vC = 0.13374167697009798\n",
      "num_qubits = 6,     vC = 0.060226905433016786\n",
      "num_qubits = 6,     vC = 0.1415236309371945\n",
      "num_qubits = 6,     vC = 0.17792093927061892\n",
      "num_qubits = 6,     vC = 0.13360173424211852\n",
      "num_qubits = 6,     vC = 0.1781084719971876\n",
      "num_qubits = 6,     vC = 0.18122277157455263\n",
      "num_qubits = 6,     vC = 0.1501861418707452\n",
      "num_qubits = 6,     vC = 0.05860169806958365\n",
      "num_qubits = 6,     vC = 0.22450404084709674\n",
      "num_qubits = 6,     vC = 0.13398118038463164\n",
      "num_qubits = 6,     vC = 0.08185031469642329\n",
      "num_qubits = 6,     vC = 0.10687848575445358\n",
      "num_qubits = 6,     vC = 0.0888897746333227\n",
      "num_qubits = 6,     vC = 0.12381733891562746\n",
      "num_qubits = 6,     vC = 0.1429229180933288\n",
      "num_qubits = 6,     vC = 0.2113996792818834\n",
      "num_qubits = 6,     vC = 0.10621932314555066\n",
      "num_qubits = 6,     vC = 0.12141705042779993\n",
      "num_qubits = 6,     vC = 0.184519079096236\n",
      "num_qubits = 6,     vC = 0.21223580810916243\n",
      "num_qubits = 6,     vC = 0.23492252462409802\n",
      "num_qubits = 6,     vC = 0.18791601266450958\n",
      "num_qubits = 6,     vC = 0.12048754118313387\n",
      "num_qubits = 6,     vC = 0.13719778748360467\n",
      "num_qubits = 6,     vC = 0.2467065034405312\n",
      "num_qubits = 6,     vC = 0.23334002665281045\n",
      "num_qubits = 6,     vC = 0.1864865606586255\n",
      "num_qubits = 6,     vC = 0.13421668239466117\n",
      "num_qubits = 6,     vC = 0.10580651094799387\n",
      "num_qubits = 6,     vC = 0.1514761231651135\n",
      "num_qubits = 6,     vC = 0.2611831135865933\n",
      "num_qubits = 6,     vC = 0.1491866188196156\n",
      "num_qubits = 6,     vC = 0.18020128505889277\n",
      "num_qubits = 6,     vC = 0.06472862834320336\n",
      "num_qubits = 6,     vC = 0.1507816872927754\n",
      "num_qubits = 6,     vC = 0.2287524743183103\n",
      "num_qubits = 6,     vC = 0.12724443724294765\n",
      "num_qubits = 6,     vC = 0.1934324204619582\n",
      "num_qubits = 6,     vC = 0.27837469933732784\n",
      "num_qubits = 6,     vC = 0.07156459800797693\n",
      "num_qubits = 6,     vC = 0.1300269716775982\n",
      "num_qubits = 6,     vC = 0.04200290258257855\n",
      "num_qubits = 6,     vC = 0.17283490046535888\n",
      "num_qubits = 6,     vC = 0.2812019393305679\n",
      "num_qubits = 6,     vC = 0.26083246510858715\n",
      "num_qubits = 6,     vC = 0.1653829131964049\n",
      "num_qubits = 6,     vC = 0.1076567064519609\n",
      "num_qubits = 6,     vC = 0.0525187934030662\n",
      "num_qubits = 6,     vC = 0.17897141555425466\n",
      "num_qubits = 6,     vC = 0.11840491431389599\n",
      "num_qubits = 6,     vC = 0.3000520656136228\n",
      "num_qubits = 6,     vC = 0.02480851277158086\n",
      "num_qubits = 7,     vC = 0.1424621131596978\n",
      "num_qubits = 7,     vC = 0.15119986304611344\n",
      "num_qubits = 7,     vC = 0.1400071801152461\n",
      "num_qubits = 7,     vC = 0.0911417543126572\n",
      "num_qubits = 7,     vC = 0.11864306185901818\n",
      "num_qubits = 7,     vC = 0.14662153735289973\n",
      "num_qubits = 7,     vC = 0.12003168795429059\n",
      "num_qubits = 7,     vC = 0.08395754831309604\n",
      "num_qubits = 7,     vC = 0.07052515021671635\n",
      "num_qubits = 7,     vC = 0.05875346362916911\n",
      "num_qubits = 7,     vC = 0.09183330222897679\n",
      "num_qubits = 7,     vC = 0.15834935619807822\n",
      "num_qubits = 7,     vC = 0.052012218358515494\n",
      "num_qubits = 7,     vC = 0.0860845753212931\n",
      "num_qubits = 7,     vC = 0.12548597002943934\n",
      "num_qubits = 7,     vC = 0.07813953863406287\n",
      "num_qubits = 7,     vC = 0.085053032597045\n",
      "num_qubits = 7,     vC = 0.054741526895301096\n",
      "num_qubits = 7,     vC = 0.10084352450194412\n",
      "num_qubits = 7,     vC = 0.11641001298467418\n",
      "num_qubits = 7,     vC = 0.06778158671881107\n",
      "num_qubits = 7,     vC = 0.09881620110290784\n",
      "num_qubits = 7,     vC = 0.13196745733914195\n",
      "num_qubits = 7,     vC = 0.08575406092054827\n",
      "num_qubits = 7,     vC = 0.14756086315836348\n",
      "num_qubits = 7,     vC = 0.03840904141307261\n",
      "num_qubits = 7,     vC = 0.1132460209936087\n",
      "num_qubits = 7,     vC = 0.13163092712157837\n",
      "num_qubits = 7,     vC = 0.12526064107678497\n",
      "num_qubits = 7,     vC = 0.07693592505498814\n",
      "num_qubits = 7,     vC = 0.08644905735889974\n",
      "num_qubits = 7,     vC = 0.11621952311381506\n",
      "num_qubits = 7,     vC = 0.1158853902285869\n",
      "num_qubits = 7,     vC = 0.06180794454637101\n",
      "num_qubits = 7,     vC = 0.013676725216240193\n",
      "num_qubits = 7,     vC = 0.11388896541738719\n",
      "num_qubits = 7,     vC = 0.15871262195258523\n",
      "num_qubits = 7,     vC = 0.1279252969016471\n",
      "num_qubits = 7,     vC = 0.15449537356157128\n",
      "num_qubits = 7,     vC = 0.21283102070935744\n",
      "num_qubits = 7,     vC = 0.04421881553684581\n",
      "num_qubits = 7,     vC = 0.08365746702013999\n",
      "num_qubits = 7,     vC = 0.11876037017900826\n",
      "num_qubits = 7,     vC = 0.13565956940569202\n",
      "num_qubits = 7,     vC = 0.04136190084375563\n",
      "num_qubits = 7,     vC = 0.13075292934211913\n",
      "num_qubits = 7,     vC = 0.105802626739056\n",
      "num_qubits = 7,     vC = 0.12331987637227126\n",
      "num_qubits = 7,     vC = 0.1399880133000106\n",
      "num_qubits = 7,     vC = 0.1510319339671256\n",
      "num_qubits = 7,     vC = 0.08696319357690208\n",
      "num_qubits = 7,     vC = 0.07236958568952051\n",
      "num_qubits = 7,     vC = 0.07979949170651857\n",
      "num_qubits = 7,     vC = 0.14774739264754166\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 7,     vC = 0.14011019579144135\n",
      "num_qubits = 7,     vC = 0.08985771270744702\n",
      "num_qubits = 7,     vC = 0.15743709001949902\n",
      "num_qubits = 7,     vC = 0.09583471927127651\n",
      "num_qubits = 7,     vC = 0.08999259957937006\n",
      "num_qubits = 7,     vC = 0.1328626061768649\n",
      "num_qubits = 7,     vC = 0.10497039655477491\n",
      "num_qubits = 7,     vC = 0.2537549325183931\n",
      "num_qubits = 7,     vC = 0.09375712489429494\n",
      "num_qubits = 7,     vC = 0.07462551505279835\n",
      "num_qubits = 7,     vC = 0.20569634162447753\n",
      "num_qubits = 7,     vC = 0.1478790498477296\n",
      "num_qubits = 7,     vC = 0.12597354769747127\n",
      "num_qubits = 7,     vC = 0.029810354202067124\n",
      "num_qubits = 7,     vC = 0.03939533254155425\n",
      "num_qubits = 7,     vC = 0.12793942024642402\n",
      "num_qubits = 7,     vC = 0.13253237887151137\n",
      "num_qubits = 7,     vC = 0.13658871104188997\n",
      "num_qubits = 7,     vC = 0.11110031510673024\n",
      "num_qubits = 7,     vC = 0.07009420524404003\n",
      "num_qubits = 7,     vC = 0.13110009301565073\n",
      "num_qubits = 7,     vC = 0.08186895173484254\n",
      "num_qubits = 7,     vC = 0.11592974671157552\n",
      "num_qubits = 7,     vC = 0.04196433869309091\n",
      "num_qubits = 7,     vC = 0.19522454559953256\n",
      "num_qubits = 7,     vC = 0.08458241159806124\n",
      "num_qubits = 7,     vC = 0.11389291221143405\n",
      "num_qubits = 7,     vC = 0.15197182618049287\n",
      "num_qubits = 7,     vC = 0.15436473832485964\n",
      "num_qubits = 7,     vC = 0.1406382896859235\n",
      "num_qubits = 7,     vC = 0.20869956493679193\n",
      "num_qubits = 7,     vC = 0.15681177096922344\n",
      "num_qubits = 7,     vC = 0.11230324884903897\n",
      "num_qubits = 7,     vC = 0.14623859237423703\n",
      "num_qubits = 7,     vC = 0.10446885223278513\n",
      "num_qubits = 7,     vC = 0.15693912700440327\n",
      "num_qubits = 7,     vC = 0.19447584431379306\n",
      "num_qubits = 7,     vC = 0.09325186781599454\n",
      "num_qubits = 7,     vC = 0.10708077028201257\n",
      "num_qubits = 7,     vC = 0.09798502950269783\n",
      "num_qubits = 7,     vC = 0.12305285115624931\n",
      "num_qubits = 7,     vC = 0.11035895167932297\n",
      "num_qubits = 7,     vC = 0.07810222888340063\n",
      "num_qubits = 7,     vC = 0.06636510530677492\n",
      "num_qubits = 7,     vC = 0.08171187961535586\n",
      "num_qubits = 7,     vC = 0.21186670201704727\n",
      "num_qubits = 8,     vC = 0.11786841114296315\n",
      "num_qubits = 8,     vC = 0.04236388181483841\n",
      "num_qubits = 8,     vC = 0.055807239439879086\n",
      "num_qubits = 8,     vC = 0.08128816112313969\n",
      "num_qubits = 8,     vC = 0.07519937292095025\n",
      "num_qubits = 8,     vC = 0.11511891328709112\n",
      "num_qubits = 8,     vC = 0.03074087338273923\n",
      "num_qubits = 8,     vC = 0.08847713659073397\n",
      "num_qubits = 8,     vC = 0.0342258201936938\n",
      "num_qubits = 8,     vC = 0.13616916235021592\n",
      "num_qubits = 8,     vC = 0.11159794225431258\n",
      "num_qubits = 8,     vC = 0.12218504860202334\n",
      "num_qubits = 8,     vC = 0.1024992931813049\n",
      "num_qubits = 8,     vC = 0.04579478009320981\n",
      "num_qubits = 8,     vC = 0.006841425993632189\n",
      "num_qubits = 8,     vC = 0.02475112937206192\n",
      "num_qubits = 8,     vC = 0.014626742457464093\n",
      "num_qubits = 8,     vC = 0.0680368673830481\n",
      "num_qubits = 8,     vC = 0.0512971874458778\n",
      "num_qubits = 8,     vC = 0.048595856285661154\n",
      "num_qubits = 8,     vC = 0.09105602636871057\n",
      "num_qubits = 8,     vC = 0.10445012086236793\n",
      "num_qubits = 8,     vC = 0.09325800843126142\n",
      "num_qubits = 8,     vC = 0.05955776422370768\n",
      "num_qubits = 8,     vC = 0.023897926989726204\n",
      "num_qubits = 8,     vC = 0.12509823295122285\n",
      "num_qubits = 8,     vC = 0.0886470855063094\n",
      "num_qubits = 8,     vC = 0.10471160240594002\n",
      "num_qubits = 8,     vC = 0.040033441779461\n",
      "num_qubits = 8,     vC = 0.043134353123589764\n",
      "num_qubits = 8,     vC = 0.08948999105319527\n",
      "num_qubits = 8,     vC = 0.055234135216869595\n",
      "num_qubits = 8,     vC = 0.148922267005429\n",
      "num_qubits = 8,     vC = 0.055706473864484796\n",
      "num_qubits = 8,     vC = 0.04314445865408939\n",
      "num_qubits = 8,     vC = 0.028625735863711643\n",
      "num_qubits = 8,     vC = 0.06032873243458542\n",
      "num_qubits = 8,     vC = 0.06411846705756158\n",
      "num_qubits = 8,     vC = 0.08912330572233812\n",
      "num_qubits = 8,     vC = 0.07247139854187434\n",
      "num_qubits = 8,     vC = 0.027107446816199865\n",
      "num_qubits = 8,     vC = 0.09746865105037927\n",
      "num_qubits = 8,     vC = 0.04862609872990531\n",
      "num_qubits = 8,     vC = 0.09551889439107791\n",
      "num_qubits = 8,     vC = 0.024037274062541747\n",
      "num_qubits = 8,     vC = 0.01883126585799333\n",
      "num_qubits = 8,     vC = 0.09059481902130523\n",
      "num_qubits = 8,     vC = 0.020230356671699923\n",
      "num_qubits = 8,     vC = 0.06613470715693465\n",
      "num_qubits = 8,     vC = 0.037434747151507186\n",
      "num_qubits = 8,     vC = 0.14009302094066034\n",
      "num_qubits = 8,     vC = 0.033276732251356744\n",
      "num_qubits = 8,     vC = 0.04843556513897479\n",
      "num_qubits = 8,     vC = 0.040478273886351945\n",
      "num_qubits = 8,     vC = 0.0227707948078692\n",
      "num_qubits = 8,     vC = 0.12611463038156373\n",
      "num_qubits = 8,     vC = 0.06412441640501326\n",
      "num_qubits = 8,     vC = 0.15756972752745724\n",
      "num_qubits = 8,     vC = 0.06360781206542504\n",
      "num_qubits = 8,     vC = 0.028793748773589922\n",
      "num_qubits = 8,     vC = 0.0967614871010598\n",
      "num_qubits = 8,     vC = 0.046582213362602376\n",
      "num_qubits = 8,     vC = 0.0673283110820726\n",
      "num_qubits = 8,     vC = 0.14125479337934993\n",
      "num_qubits = 8,     vC = 0.09801978704124736\n",
      "num_qubits = 8,     vC = 0.041666527256057684\n",
      "num_qubits = 8,     vC = 0.046847056544498056\n",
      "num_qubits = 8,     vC = 0.04297976238848189\n",
      "num_qubits = 8,     vC = 0.13990556143244548\n",
      "num_qubits = 8,     vC = 0.07951505402416775\n",
      "num_qubits = 8,     vC = 0.08102141783990408\n",
      "num_qubits = 8,     vC = 0.05964971541781039\n",
      "num_qubits = 8,     vC = 0.08047626511149764\n",
      "num_qubits = 8,     vC = 0.11982326364405904\n",
      "num_qubits = 8,     vC = 0.0468689411569701\n",
      "num_qubits = 8,     vC = 0.1654028117324835\n",
      "num_qubits = 8,     vC = 0.08997869289260413\n",
      "num_qubits = 8,     vC = 0.03377236548369589\n",
      "num_qubits = 8,     vC = 0.08008671174932047\n",
      "num_qubits = 8,     vC = 0.08457842906859525\n",
      "num_qubits = 8,     vC = 0.062317341668706505\n",
      "num_qubits = 8,     vC = 0.08778253176246575\n",
      "num_qubits = 8,     vC = 0.09483124011646027\n",
      "num_qubits = 8,     vC = 0.03489491814402357\n",
      "num_qubits = 8,     vC = 0.052244933894834755\n",
      "num_qubits = 8,     vC = 0.0399800100858575\n",
      "num_qubits = 8,     vC = 0.11763709706736808\n",
      "num_qubits = 8,     vC = 0.10251999366859926\n",
      "num_qubits = 8,     vC = 0.12089582931775905\n",
      "num_qubits = 8,     vC = 0.05364616817869061\n",
      "num_qubits = 8,     vC = 0.12454857408766284\n",
      "num_qubits = 8,     vC = 0.06398007415544371\n",
      "num_qubits = 8,     vC = 0.0814251017723106\n",
      "num_qubits = 8,     vC = 0.03380819789979583\n",
      "num_qubits = 8,     vC = 0.022315465559699432\n",
      "num_qubits = 8,     vC = 0.05170850799870447\n",
      "num_qubits = 8,     vC = 0.08337337066378131\n",
      "num_qubits = 8,     vC = 0.1081192424782399\n",
      "num_qubits = 8,     vC = 0.04288596617848439\n",
      "num_qubits = 8,     vC = 0.04141082673408614\n",
      "num_qubits = 9,     vC = 0.052038725267450014\n",
      "num_qubits = 9,     vC = 0.10644799270592575\n",
      "num_qubits = 9,     vC = 0.05681710265899076\n",
      "num_qubits = 9,     vC = 0.06271289161725518\n",
      "num_qubits = 9,     vC = 0.05353557892383254\n",
      "num_qubits = 9,     vC = 0.06348555873996176\n",
      "num_qubits = 9,     vC = 0.06395826576860403\n",
      "num_qubits = 9,     vC = 0.06823317231706816\n",
      "num_qubits = 9,     vC = 0.024407835193242744\n",
      "num_qubits = 9,     vC = 0.07083672978007394\n",
      "num_qubits = 9,     vC = 0.05081626454022792\n",
      "num_qubits = 9,     vC = 0.13352159689776955\n",
      "num_qubits = 9,     vC = 0.03198469212205657\n",
      "num_qubits = 9,     vC = 0.050956755747460614\n",
      "num_qubits = 9,     vC = 0.09345323635818192\n",
      "num_qubits = 9,     vC = 0.03560118178137872\n",
      "num_qubits = 9,     vC = 0.06124809949814547\n",
      "num_qubits = 9,     vC = 0.0473598320454488\n",
      "num_qubits = 9,     vC = 0.030641468903751523\n",
      "num_qubits = 9,     vC = 0.0499481418779083\n",
      "num_qubits = 9,     vC = 0.06184117809060308\n",
      "num_qubits = 9,     vC = 0.03360785136459743\n",
      "num_qubits = 9,     vC = 0.056838303173249116\n",
      "num_qubits = 9,     vC = 0.04976485473757519\n",
      "num_qubits = 9,     vC = 0.02946778720519211\n",
      "num_qubits = 9,     vC = 0.06954649532119161\n",
      "num_qubits = 9,     vC = 0.08703067080341376\n",
      "num_qubits = 9,     vC = 0.046057236398775236\n",
      "num_qubits = 9,     vC = 0.03196745125075917\n",
      "num_qubits = 9,     vC = 0.08157145694202195\n",
      "num_qubits = 9,     vC = 0.03505279858099691\n",
      "num_qubits = 9,     vC = 0.0741450492825505\n",
      "num_qubits = 9,     vC = 0.03157909514400559\n",
      "num_qubits = 9,     vC = 0.06063856402681822\n",
      "num_qubits = 9,     vC = 0.029146241651926474\n",
      "num_qubits = 9,     vC = 0.06068124175192752\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 0.07783324476969666\n",
      "num_qubits = 9,     vC = 0.060395220558310925\n",
      "num_qubits = 9,     vC = 0.06999258915601858\n",
      "num_qubits = 9,     vC = 0.05891389064774816\n",
      "num_qubits = 9,     vC = 0.0666633114388323\n",
      "num_qubits = 9,     vC = 0.007665042876780492\n",
      "num_qubits = 9,     vC = 0.06611418352499254\n",
      "num_qubits = 9,     vC = 0.05740025608801713\n",
      "num_qubits = 9,     vC = 0.042824708819901525\n",
      "num_qubits = 9,     vC = 0.06008944955608031\n",
      "num_qubits = 9,     vC = 0.04669974400075838\n",
      "num_qubits = 9,     vC = 0.042916528299648204\n",
      "num_qubits = 9,     vC = 0.05243124890851936\n",
      "num_qubits = 9,     vC = 0.03995876547165489\n",
      "num_qubits = 9,     vC = 0.03646714085612479\n",
      "num_qubits = 9,     vC = 0.07682051383656752\n",
      "num_qubits = 9,     vC = 0.04357582439270702\n",
      "num_qubits = 9,     vC = 0.059111833436527594\n",
      "num_qubits = 9,     vC = 0.05884715023058573\n",
      "num_qubits = 9,     vC = 0.042635330591889675\n",
      "num_qubits = 9,     vC = 0.06440881149062583\n",
      "num_qubits = 9,     vC = 0.04494984205800023\n",
      "num_qubits = 9,     vC = 0.10329694361142161\n",
      "num_qubits = 9,     vC = 0.053188903901748574\n",
      "num_qubits = 9,     vC = 0.06267714108634681\n",
      "num_qubits = 9,     vC = 0.09577799643446644\n",
      "num_qubits = 9,     vC = 0.04594196802179601\n",
      "num_qubits = 9,     vC = 0.04617714008473334\n",
      "num_qubits = 9,     vC = 0.03158518248148329\n",
      "num_qubits = 9,     vC = 0.04485450178474848\n",
      "num_qubits = 9,     vC = 0.04075192414224865\n",
      "num_qubits = 9,     vC = 0.039697139687521144\n",
      "num_qubits = 9,     vC = 0.05448204834967846\n",
      "num_qubits = 9,     vC = 0.03396034207625759\n",
      "num_qubits = 9,     vC = 0.0577747894992417\n",
      "num_qubits = 9,     vC = 0.0249049198969713\n",
      "num_qubits = 9,     vC = 0.029583151371045058\n",
      "num_qubits = 9,     vC = 0.03362123277712764\n",
      "num_qubits = 9,     vC = 0.04230967518893114\n",
      "num_qubits = 9,     vC = 0.09692802192337535\n",
      "num_qubits = 9,     vC = 0.07566409386276068\n",
      "num_qubits = 9,     vC = 0.0480346860450831\n",
      "num_qubits = 9,     vC = 0.05782140869110186\n",
      "num_qubits = 9,     vC = 0.05916699159108285\n",
      "num_qubits = 9,     vC = 0.047924046380329655\n",
      "num_qubits = 9,     vC = 0.09302906551688972\n",
      "num_qubits = 9,     vC = 0.028794584599121542\n",
      "num_qubits = 9,     vC = 0.0554709598461432\n",
      "num_qubits = 9,     vC = 0.07253183503034422\n",
      "num_qubits = 9,     vC = 0.028423576957076868\n",
      "num_qubits = 9,     vC = 0.033607294109307295\n",
      "num_qubits = 9,     vC = 0.04290712957431603\n",
      "num_qubits = 9,     vC = 0.05051411010835416\n",
      "num_qubits = 9,     vC = 0.03549622411596587\n",
      "num_qubits = 9,     vC = 0.05276352159100467\n",
      "num_qubits = 9,     vC = 0.024840076193884397\n",
      "num_qubits = 9,     vC = 0.06470486672962628\n",
      "num_qubits = 9,     vC = 0.040624414732456704\n",
      "num_qubits = 9,     vC = 0.050567673799945756\n",
      "num_qubits = 9,     vC = 0.07092599553881218\n",
      "num_qubits = 9,     vC = 0.046291214922398294\n",
      "num_qubits = 9,     vC = 0.04705029280964479\n",
      "num_qubits = 9,     vC = 0.06836807548065948\n",
      "num_qubits = 9,     vC = 0.018627731883281318\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",
    "        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_QAE_inside_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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LvDTT24nk0QICAige/fuREdH89dffxEcHMyYMWM4f147CIrcisSUtL9HTf9pjLkfZzuoHMkXSURSvbvv5qvWreHAAWfz9pAQeO01iI93O5kkwr333suECRNYvXo1n376KeHh4SxZskTDcEVuUmJK2hJjTFZgGLALOArMScZMIiKO++6DsWNh50749ltndMfQodpuyksUKlSIZcuWMXLkSLp3785jjz3G3r173Y4l4jUSc3fnG9ba3621H+JcixZsrX0t+aOJiCTInRumT4d165wdDAoUgAkT4Nw5t5PJDRhjqFGjBnv37uWJJ56gatWqtGnThh81dkXkhhJ7d2dZY8zTODcQPGGMeS55Y90aY0xtY8ykeC2JiPim0FBYsMDZG/Tjj51l0JkzQTO6PF7atGnp0KEDsbGxZMqUibCwMAYPHszZs2fdjibisRJzd+f7OMNrr9y7s3gy57ol1trF1to2gYGBbkcRkeRUvLizL+jUqTB+PBQp4pQ2XfPk8e68805GjhzJ5s2b2bp1KyEhIXzwwQe6Xk3kGhJzJq048LC1tr219sWER8fkDiYickMVK8LGjTB4MLz+OpQuDRqo6hUKFCjAwoULmTZtGoMGDaJcuXJs27bN7VgiHiUxJW0/cF9yBxERuSXGQK1aEBXl7FrQti08+ihs3ep2MkmESpUqsWPHDlq2bEndunVp2rQp3377rduxRDzCf5Y0Y8xiY8wi4G4g2hiz3Biz6O9HykUUEUkEPz9o0gSio6FRI2jQAOrWdXYzEI/m7+9PixYtOHjwIHny5KFo0aL06dOH06dPux1NxFXXO5M2HGcz9b5AXf65wfqI5A4mInJL0qaF1q3h4EGoUAGqVIFnn4XDh91OJjeQKVMm3njjDaKiojh8+DDBwcFMnz6dS5cuuR1NxBXXK2nfAResteuufAAXgWMpE09E5BZlyABdu8KhQ858tZIloV07beLuBR588EFmzZrFggULmDRpEiVKlGDdunVuxxJJcdcraaOBk9d4Pj7hayIini9LFuemgrg4yJjR2cT95ZfhxAm3k8kNlC5dmo0bN9K9e3eaNWvGk08+yWGdEZVU5HolLbu1dt/VTyY8lzvZEomIJIe774bhw2HvXjh5EoKC4I034NQpt5PJdRhjaNy4MTExMRQvXpySJUvy0ksv8fvvv7sdTSTZXa+kZb3O1zIk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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
}
