{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import paddle\n",
    "import paddle.fluid.layers as layers\n",
    "from paddle_quantum.utils import Hamiltonian\n",
    "from paddle_quantum.state import vec_random\n",
    "from paddle_quantum.circuit import UAnsatz\n",
    "import matplotlib.pyplot as plt\n",
    "import json\n",
    "import numpy as np"
   ]
  },
  {
   "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.run_state_vector()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def WriteJson(list_write, json_file_name):\n",
    "    with open(json_file_name + '.json', 'w') as file_save:\n",
    "        json_data = json.dumps(list_write, indent=4)\n",
    "        file_save.write(json_data)\n",
    "        file_save.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class StateNet_max(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_max, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    # loss function\n",
    "    def forward(self, N, 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(rand_rho)\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(rand_rho)\n",
    "\n",
    "        # min_luo\n",
    "        loss = (rho_luo.conj().t() @ H @ rho_luo).real()\n",
    "        \n",
    "        return loss\n",
    "\n",
    "def train_loss(N, ini_state, 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, ini_state, 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, ini_state, Herm)\n",
    "\n",
    "        loss_min.backward()\n",
    "        opt_min.minimize(loss_min)\n",
    "        opt_min.clear_grad()\n",
    "\n",
    "        # max - min\n",
    "        loss = -loss_max.numpy()[0] - loss_min.numpy()[0]\n",
    "        \n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/envs/paddle_quantum_dev/lib/python3.8/site-packages/paddle/tensor/creation.py:125: DeprecationWarning: `np.object` is a deprecated alias for the builtin `object`. To silence this warning, use `object` by itself. Doing this will not modify any behavior and is safe. \n",
      "Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations\n",
      "  if data.dtype == np.object:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.8535371597088367\n",
      "num_qubits = 2,     vC = 0.5218928385795248\n",
      "num_qubits = 2,     vC = 0.8535373980036943\n",
      "num_qubits = 2,     vC = 0.8535230472049469\n",
      "num_qubits = 2,     vC = 0.47925424488112134\n",
      "num_qubits = 2,     vC = 0.8534956416905474\n",
      "num_qubits = 2,     vC = 0.8534808032919518\n",
      "num_qubits = 2,     vC = 0.18916008402678128\n",
      "num_qubits = 2,     vC = 0.8535458531655995\n",
      "num_qubits = 2,     vC = 0.15220116377463383\n",
      "num_qubits = 2,     vC = 0.8535310157651094\n",
      "num_qubits = 2,     vC = 0.8404923754380101\n",
      "num_qubits = 2,     vC = 0.7873802558277483\n",
      "num_qubits = 2,     vC = 0.7703363101835248\n",
      "num_qubits = 2,     vC = 0.853521428456122\n",
      "num_qubits = 2,     vC = 0.8535189294761036\n",
      "num_qubits = 2,     vC = 0.50715413060259\n",
      "num_qubits = 2,     vC = 0.3665420580989977\n",
      "num_qubits = 2,     vC = 0.8183918727274765\n",
      "num_qubits = 2,     vC = 0.8535478911971776\n",
      "num_qubits = 2,     vC = 0.04975970778670635\n",
      "num_qubits = 2,     vC = 0.14988147123976844\n",
      "num_qubits = 2,     vC = 0.37662650872356646\n",
      "num_qubits = 2,     vC = 0.008327316589351548\n",
      "num_qubits = 2,     vC = 0.8185079558992211\n",
      "num_qubits = 2,     vC = 0.9644645713871498\n",
      "num_qubits = 2,     vC = 0.01606106146042187\n",
      "num_qubits = 2,     vC = 0.46534882434708913\n",
      "num_qubits = 2,     vC = 0.3401693586980835\n",
      "num_qubits = 2,     vC = 0.1492219303900258\n",
      "num_qubits = 2,     vC = 0.5845172149687949\n",
      "num_qubits = 2,     vC = 0.9701374433810921\n",
      "num_qubits = 2,     vC = 0.1544610366741765\n",
      "num_qubits = 2,     vC = 0.8535270859992061\n",
      "num_qubits = 2,     vC = 0.15677462532363345\n",
      "num_qubits = 2,     vC = 0.2528108525948467\n",
      "num_qubits = 2,     vC = 0.7712148441508505\n",
      "num_qubits = 2,     vC = 0.9860677952818769\n",
      "num_qubits = 2,     vC = 0.8104393202364781\n",
      "num_qubits = 2,     vC = 0.8532944444409687\n",
      "num_qubits = 3,     vC = 0.00195885373764231\n",
      "num_qubits = 3,     vC = 0.3277335412178783\n",
      "num_qubits = 3,     vC = 0.07533753639290094\n",
      "num_qubits = 3,     vC = 0.41589183484981557\n",
      "num_qubits = 3,     vC = 0.10949943763533558\n",
      "num_qubits = 3,     vC = 0.12500155002594643\n",
      "num_qubits = 3,     vC = 0.6475207445486897\n",
      "num_qubits = 3,     vC = 0.8408605047619391\n",
      "num_qubits = 3,     vC = 0.8309330020653165\n",
      "num_qubits = 3,     vC = 0.2516284126031483\n",
      "num_qubits = 3,     vC = 0.14476897029088953\n",
      "num_qubits = 3,     vC = 0.03075110692265296\n",
      "num_qubits = 3,     vC = 0.1647786924907724\n",
      "num_qubits = 3,     vC = 0.6021731345687672\n",
      "num_qubits = 3,     vC = 0.7325140746612758\n",
      "num_qubits = 3,     vC = 0.6822914743065867\n",
      "num_qubits = 3,     vC = 0.1879654273144183\n",
      "num_qubits = 3,     vC = 0.7274001155318841\n",
      "num_qubits = 3,     vC = 0.007396363873635176\n",
      "num_qubits = 3,     vC = 0.7269692729533629\n",
      "num_qubits = 3,     vC = 0.8375229984470267\n",
      "num_qubits = 3,     vC = 0.5392371643301708\n",
      "num_qubits = 3,     vC = 0.3593458968704541\n",
      "num_qubits = 3,     vC = 0.7284777989631886\n",
      "num_qubits = 3,     vC = 0.5721584953612273\n",
      "num_qubits = 3,     vC = 0.2999095702899229\n",
      "num_qubits = 3,     vC = 0.34679959003812116\n",
      "num_qubits = 3,     vC = 0.5038469101381716\n",
      "num_qubits = 3,     vC = 0.04205105119845869\n",
      "num_qubits = 3,     vC = 0.8189098446647165\n",
      "num_qubits = 3,     vC = 0.7285452954879553\n",
      "num_qubits = 3,     vC = 0.6135223263758924\n",
      "num_qubits = 3,     vC = 0.5013511800131539\n",
      "num_qubits = 3,     vC = 0.6094545593121121\n",
      "num_qubits = 3,     vC = 0.7285475706367739\n",
      "num_qubits = 3,     vC = 0.3655440743842202\n",
      "num_qubits = 3,     vC = 0.728063633110819\n",
      "num_qubits = 3,     vC = 0.18626435100837202\n",
      "num_qubits = 3,     vC = 0.2538169029848962\n",
      "num_qubits = 3,     vC = 0.6669919838299557\n",
      "num_qubits = 4,     vC = 0.3928789072424884\n",
      "num_qubits = 4,     vC = 0.1798747050777041\n",
      "num_qubits = 4,     vC = 0.5834506071242956\n",
      "num_qubits = 4,     vC = 0.017673029196655574\n",
      "num_qubits = 4,     vC = 0.08271648886165864\n",
      "num_qubits = 4,     vC = 0.008831789789353992\n",
      "num_qubits = 4,     vC = 0.06225446786359268\n",
      "num_qubits = 4,     vC = 0.14414865508027008\n",
      "num_qubits = 4,     vC = 0.22943325147772486\n",
      "num_qubits = 4,     vC = 0.14201212327678922\n",
      "num_qubits = 4,     vC = 0.04045868567760569\n",
      "num_qubits = 4,     vC = 0.07825982628767637\n",
      "num_qubits = 4,     vC = 0.5885679767166706\n",
      "num_qubits = 4,     vC = 0.662763725117971\n",
      "num_qubits = 4,     vC = 0.0012200707522833343\n",
      "num_qubits = 4,     vC = 0.13884544536369117\n",
      "num_qubits = 4,     vC = 0.010022367975649872\n",
      "num_qubits = 4,     vC = 0.6179372771134359\n",
      "num_qubits = 4,     vC = 0.5884427797792964\n",
      "num_qubits = 4,     vC = 0.08041375605680957\n",
      "num_qubits = 4,     vC = 0.025974773185795143\n",
      "num_qubits = 4,     vC = 0.185824990005516\n",
      "num_qubits = 4,     vC = 0.010440751842655024\n",
      "num_qubits = 4,     vC = 0.6857715776024182\n",
      "num_qubits = 4,     vC = 0.19749012773292737\n",
      "num_qubits = 4,     vC = 0.00018044733093419327\n",
      "num_qubits = 4,     vC = 0.09267425521293524\n",
      "num_qubits = 4,     vC = 0.05381653870017605\n",
      "num_qubits = 4,     vC = 0.01063393332134557\n",
      "num_qubits = 4,     vC = 0.45268631239843526\n",
      "num_qubits = 4,     vC = 0.5791829151302065\n",
      "num_qubits = 4,     vC = 0.7263989432551435\n",
      "num_qubits = 4,     vC = 0.22898455673242898\n",
      "num_qubits = 4,     vC = 0.022614035410540467\n",
      "num_qubits = 4,     vC = 0.5788174825532051\n",
      "num_qubits = 4,     vC = 0.43767608124713453\n",
      "num_qubits = 4,     vC = 0.4480908090164109\n",
      "num_qubits = 4,     vC = 0.4755780390718629\n",
      "num_qubits = 4,     vC = 0.14361611675423594\n",
      "num_qubits = 4,     vC = 0.11381142989422599\n",
      "num_qubits = 5,     vC = 0.5307642086749136\n",
      "num_qubits = 5,     vC = 1.3653977599639848e-05\n",
      "num_qubits = 5,     vC = 0.4987939886666387\n",
      "num_qubits = 5,     vC = 0.000966224320371171\n",
      "num_qubits = 5,     vC = 0.13320471649052879\n",
      "num_qubits = 5,     vC = 0.005498787230956079\n",
      "num_qubits = 5,     vC = 0.037621284971889185\n",
      "num_qubits = 5,     vC = 0.013539755209869159\n",
      "num_qubits = 5,     vC = 0.00490719489139998\n",
      "num_qubits = 5,     vC = 0.038328821274243086\n",
      "num_qubits = 5,     vC = 0.5434981592978879\n",
      "num_qubits = 5,     vC = 0.21154968036803742\n",
      "num_qubits = 5,     vC = 0.12561318136445482\n",
      "num_qubits = 5,     vC = 0.06735814128056018\n",
      "num_qubits = 5,     vC = 0.11001109935792386\n",
      "num_qubits = 5,     vC = 0.25867843908481236\n",
      "num_qubits = 5,     vC = 0.012448702188718592\n",
      "num_qubits = 5,     vC = 0.2198554485547788\n",
      "num_qubits = 5,     vC = 0.49996216605201105\n",
      "num_qubits = 5,     vC = 2.7599026775166273e-05\n",
      "num_qubits = 5,     vC = 0.5767906091930274\n",
      "num_qubits = 5,     vC = 0.1563877929071002\n",
      "num_qubits = 5,     vC = 0.007011757799635511\n",
      "num_qubits = 5,     vC = 0.02147764950407335\n",
      "num_qubits = 5,     vC = 0.18312053528923855\n",
      "num_qubits = 5,     vC = 0.06875482914925918\n",
      "num_qubits = 5,     vC = 0.4476814834206398\n",
      "num_qubits = 5,     vC = 0.1402166791380031\n",
      "num_qubits = 5,     vC = 0.39193015843323253\n",
      "num_qubits = 5,     vC = 0.00827863293281899\n",
      "num_qubits = 5,     vC = 0.07427010518159341\n",
      "num_qubits = 5,     vC = 0.017423637061382672\n",
      "num_qubits = 5,     vC = 0.0011802756480436497\n",
      "num_qubits = 5,     vC = 0.004396903143016725\n",
      "num_qubits = 5,     vC = 0.4932126468930372\n",
      "num_qubits = 5,     vC = 0.0031217433160231774\n",
      "num_qubits = 5,     vC = 0.2971646962613693\n",
      "num_qubits = 5,     vC = 0.06245483157296585\n",
      "num_qubits = 5,     vC = 0.029712266957392597\n",
      "num_qubits = 5,     vC = 0.05296665869805711\n",
      "num_qubits = 6,     vC = 0.019981465265747848\n",
      "num_qubits = 6,     vC = 0.005542964734325232\n",
      "num_qubits = 6,     vC = 0.018564092152527092\n",
      "num_qubits = 6,     vC = 0.45295436688739155\n",
      "num_qubits = 6,     vC = 9.260071763004435e-05\n",
      "num_qubits = 6,     vC = 0.022306718848508322\n",
      "num_qubits = 6,     vC = 0.030337222870510598\n",
      "num_qubits = 6,     vC = 0.04876658409339423\n",
      "num_qubits = 6,     vC = 0.2528194959777511\n",
      "num_qubits = 6,     vC = 0.04840084783633914\n",
      "num_qubits = 6,     vC = 0.05994594535600248\n",
      "num_qubits = 6,     vC = 0.018514675237962623\n",
      "num_qubits = 6,     vC = 0.00016372164341866722\n",
      "num_qubits = 6,     vC = 0.2539833312200259\n",
      "num_qubits = 6,     vC = 0.11287256692196013\n",
      "num_qubits = 6,     vC = 0.04756881874490715\n",
      "num_qubits = 6,     vC = 0.14873276727199933\n",
      "num_qubits = 6,     vC = 0.00044453233856550477\n",
      "num_qubits = 6,     vC = 0.26674194675042306\n",
      "num_qubits = 6,     vC = 0.030055429342887314\n",
      "num_qubits = 6,     vC = 0.03118186904190341\n",
      "num_qubits = 6,     vC = 0.0005346160866039044\n",
      "num_qubits = 6,     vC = 0.08974310205248799\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 6,     vC = 0.013504151432462128\n",
      "num_qubits = 6,     vC = 0.10695386593174422\n",
      "num_qubits = 6,     vC = 0.1032068978315249\n",
      "num_qubits = 6,     vC = 0.007241445434656627\n",
      "num_qubits = 6,     vC = 0.0847305298931121\n",
      "num_qubits = 6,     vC = 0.0016563939281466643\n",
      "num_qubits = 6,     vC = 6.374137987357484e-05\n",
      "num_qubits = 6,     vC = 0.2361275095208059\n",
      "num_qubits = 6,     vC = 0.0011814187323150123\n",
      "num_qubits = 6,     vC = 0.06173168699151316\n",
      "num_qubits = 6,     vC = 0.07477590736597066\n",
      "num_qubits = 6,     vC = 0.018377946697152835\n",
      "num_qubits = 6,     vC = 0.09353145688907635\n",
      "num_qubits = 6,     vC = 0.00025280401392281524\n",
      "num_qubits = 6,     vC = 0.0009070612466561696\n",
      "num_qubits = 6,     vC = 0.021143649790154893\n",
      "num_qubits = 6,     vC = 0.21437851358608567\n",
      "num_qubits = 7,     vC = 0.014354069243469629\n",
      "num_qubits = 7,     vC = 0.018088307640985724\n",
      "num_qubits = 7,     vC = 0.08674721845127964\n",
      "num_qubits = 7,     vC = 0.008488507384253897\n",
      "num_qubits = 7,     vC = 0.019642187032797458\n",
      "num_qubits = 7,     vC = 0.11474827632965746\n",
      "num_qubits = 7,     vC = 0.010897361502967492\n",
      "num_qubits = 7,     vC = 0.014783400258384583\n",
      "num_qubits = 7,     vC = 0.023404560464699978\n",
      "num_qubits = 7,     vC = 0.0010439299342655498\n",
      "num_qubits = 7,     vC = 0.0656302911710891\n",
      "num_qubits = 7,     vC = 0.10337958801147089\n",
      "num_qubits = 7,     vC = 0.004527130593671597\n",
      "num_qubits = 7,     vC = 0.0036974453043048\n",
      "num_qubits = 7,     vC = 0.005971068875404762\n",
      "num_qubits = 7,     vC = 0.00028798557076724\n",
      "num_qubits = 7,     vC = 0.026466823916562056\n",
      "num_qubits = 7,     vC = 0.0005566319072732224\n",
      "num_qubits = 7,     vC = 0.2710390408683736\n",
      "num_qubits = 7,     vC = 0.17399489648558053\n",
      "num_qubits = 7,     vC = 7.272920590544318e-06\n",
      "num_qubits = 7,     vC = 0.00016103946374083122\n",
      "num_qubits = 7,     vC = 0.0032634411201741985\n",
      "num_qubits = 7,     vC = 0.054081543630417506\n",
      "num_qubits = 7,     vC = 0.00021755205362623153\n",
      "num_qubits = 7,     vC = 0.010523812144822463\n",
      "num_qubits = 7,     vC = 0.02862637628552203\n",
      "num_qubits = 7,     vC = 0.0013079307247000304\n",
      "num_qubits = 7,     vC = 0.03255059623678973\n",
      "num_qubits = 7,     vC = 0.021064807666672\n",
      "num_qubits = 7,     vC = 0.0007558909879021894\n",
      "num_qubits = 7,     vC = 0.023881984515784164\n",
      "num_qubits = 7,     vC = 0.16667528670397183\n",
      "num_qubits = 7,     vC = 0.0043427347156433605\n",
      "num_qubits = 7,     vC = 0.0007413819001915365\n",
      "num_qubits = 7,     vC = 0.011456847191283315\n",
      "num_qubits = 7,     vC = 0.008304986313573045\n",
      "num_qubits = 7,     vC = 0.11011784495835104\n",
      "num_qubits = 7,     vC = 0.022574590543452944\n",
      "num_qubits = 7,     vC = 0.3833310096691144\n",
      "num_qubits = 8,     vC = 0.0008495218215704507\n",
      "num_qubits = 8,     vC = 0.008905618618051416\n",
      "num_qubits = 8,     vC = 0.03362481684695749\n",
      "num_qubits = 8,     vC = 0.0029142309669841467\n",
      "num_qubits = 8,     vC = 0.015009786263691769\n",
      "num_qubits = 8,     vC = 0.0005639175649345679\n",
      "num_qubits = 8,     vC = 4.6863751271058034e-05\n",
      "num_qubits = 8,     vC = 0.017867659869085877\n",
      "num_qubits = 8,     vC = 0.06304767032350077\n",
      "num_qubits = 8,     vC = 0.0002907605972962071\n",
      "num_qubits = 8,     vC = 0.00010125790047400062\n",
      "num_qubits = 8,     vC = 0.2879969535585766\n",
      "num_qubits = 8,     vC = 0.002067908838001731\n",
      "num_qubits = 8,     vC = 0.0046204971312819865\n",
      "num_qubits = 8,     vC = 0.0850454871050051\n",
      "num_qubits = 8,     vC = 0.021417199976546973\n",
      "num_qubits = 8,     vC = 0.00036150306044097725\n",
      "num_qubits = 8,     vC = 0.19686540741390163\n",
      "num_qubits = 8,     vC = 0.008413490264556048\n",
      "num_qubits = 8,     vC = 0.0015796992702168948\n",
      "num_qubits = 8,     vC = 0.016755528327109883\n",
      "num_qubits = 8,     vC = 0.0034507192317671472\n",
      "num_qubits = 8,     vC = 0.12538465779129077\n",
      "num_qubits = 8,     vC = 0.0008166875688739901\n",
      "num_qubits = 8,     vC = 0.03494342959051234\n",
      "num_qubits = 8,     vC = 0.04994805971906259\n",
      "num_qubits = 8,     vC = 0.0205741358126435\n",
      "num_qubits = 8,     vC = 0.003345271339346573\n",
      "num_qubits = 8,     vC = 0.06981473831384906\n",
      "num_qubits = 8,     vC = 0.010635525712669552\n",
      "num_qubits = 8,     vC = 0.08898661166394004\n",
      "num_qubits = 8,     vC = 0.009333833193690314\n",
      "num_qubits = 8,     vC = 0.20189275331754544\n",
      "num_qubits = 8,     vC = 0.024798995135726785\n",
      "num_qubits = 8,     vC = 0.020018327807379346\n",
      "num_qubits = 8,     vC = 0.01613600787753751\n",
      "num_qubits = 8,     vC = 0.13996658341453555\n",
      "num_qubits = 8,     vC = 0.01417473401250885\n",
      "num_qubits = 8,     vC = 0.0010197986595410207\n",
      "num_qubits = 8,     vC = 0.0026239003107984596\n",
      "num_qubits = 9,     vC = 0.0024176786597205875\n",
      "num_qubits = 9,     vC = 0.026518420236114337\n",
      "num_qubits = 9,     vC = 0.000961011493381402\n",
      "num_qubits = 9,     vC = 0.021815730829843432\n",
      "num_qubits = 9,     vC = 0.3424533657165998\n",
      "num_qubits = 9,     vC = 0.1355364625488842\n",
      "num_qubits = 9,     vC = 0.000250951616873596\n",
      "num_qubits = 9,     vC = 0.0600027079512566\n",
      "num_qubits = 9,     vC = 0.022743591626651467\n",
      "num_qubits = 9,     vC = 0.0001860433974325813\n",
      "num_qubits = 9,     vC = 0.0044802556408826905\n",
      "num_qubits = 9,     vC = 0.00841177289823417\n",
      "num_qubits = 9,     vC = 0.017611145698969582\n",
      "num_qubits = 9,     vC = 7.085424860448058e-09\n",
      "num_qubits = 9,     vC = 0.005771996684147907\n",
      "num_qubits = 9,     vC = 0.01095630152248876\n",
      "num_qubits = 9,     vC = 0.004775341954360818\n",
      "num_qubits = 9,     vC = 8.831461842781168e-08\n",
      "num_qubits = 9,     vC = 0.05570424632862969\n",
      "num_qubits = 9,     vC = 0.03788118235341624\n",
      "num_qubits = 9,     vC = 0.031782582501734866\n",
      "num_qubits = 9,     vC = 0.05258682319092408\n",
      "num_qubits = 9,     vC = 0.15307291169903905\n",
      "num_qubits = 9,     vC = 0.09684776812317222\n",
      "num_qubits = 9,     vC = 0.0007055952117105233\n",
      "num_qubits = 9,     vC = 0.010912398435373359\n",
      "num_qubits = 9,     vC = 0.00023468396430597534\n",
      "num_qubits = 9,     vC = 8.230974998290393e-05\n",
      "num_qubits = 9,     vC = 0.02956709689847706\n",
      "num_qubits = 9,     vC = 0.06762197689840847\n",
      "num_qubits = 9,     vC = 0.0005982310966864376\n",
      "num_qubits = 9,     vC = 0.006350231852152731\n",
      "num_qubits = 9,     vC = 0.000552064462830095\n",
      "num_qubits = 9,     vC = 0.018574087225921698\n",
      "num_qubits = 9,     vC = 0.023936107073905952\n",
      "num_qubits = 9,     vC = 0.0004716985848981682\n",
      "num_qubits = 9,     vC = 2.19717071225031e-07\n",
      "num_qubits = 9,     vC = 0.0002345449976028007\n",
      "num_qubits = 9,     vC = 0.0024863422943020254\n",
      "num_qubits = 9,     vC = 0.0028870622894834404\n"
     ]
    }
   ],
   "source": [
    "loss_change = []\n",
    "\n",
    "for N in range(2,10):\n",
    "\n",
    "    temp = []\n",
    "\n",
    "    H = np.zeros((2**N, 2**N))\n",
    "    H[0][0] = 1\n",
    "    \n",
    "    # spectral width of H = 1\n",
    "\n",
    "    for _ in range(400):\n",
    "\n",
    "        rand_rho = uni_2_design(N, 1)\n",
    "        Delta_C = train_loss(N, ini_state=rand_rho, Herm=paddle.to_tensor(H))\n",
    "        \n",
    "        temp.append(Delta_C)\n",
    "        if _ % 10 == 0:\n",
    "            print(f'num_qubits = {N},     vC = {Delta_C}')\n",
    "\n",
    "    WriteJson(temp,  'sample_vC_QSL_behind_Adam_'+str(N)+'qubit')\n",
    "\n",
    "    loss_change.append(np.average(temp))\n",
    "    \n",
    "WriteJson(loss_change, \"QSL_behind_Adam_1design\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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iHgLnyppxphGxpjxR48edTtKxmAM1KjhzAfduNE5mlamDLRqBVu2pPrmcuTIwfvvv8/EiRN5/PHH6d69OydPnkz17YiIiHgDnypp1toF1tpOgYGBbkfJeIoUcQa679/vLN3x8MOEPvusc91aKt+dWbduXeLj4zl27BihoaFs2LAhVb9fRETEG/hUSRMvEBgIPXrAnj383LAhvPgihIQ4662l4jD13LlzM3XqVIYMGcJDDz3ECy+8wJkzZ1Lt+0VERNymkiaekTkzv9epA7GxMGSIc3do0aLw7ruQiqcoH3zwQeLi4tizZw+RkZHExMSk2neLiIi4SSVNPMsYqF8fVq6EmTNh9WpnTuiAAam2OG6+fPmYO3cuL7zwAvXq1eO1117j3LlzqfLdIiIiblFJk7RTvjzMnQtr1zp3gRYrBk895SzpcYOMMTz66KNER0ezbt06KlWqxK5du248s4iIiEtU0iTtFS8OEyY4kwtuugkiIpx11+LibvirCxQowJIlS3j88cepVq0aI0eO5IIHF9wVERHxFJU0cU/+/M5Q9337nJsL7rvPeaxadUN3hBpj6NKlC5s2beLTTz8lKiqK/fv3p15uERGRNKCSJu4LDITevZ3lOx56CDp3/vfU6PnzKf7aoKAgVq1axQMPPEC5cuWYMGGChrWLiEi6oZIm3iNrVujYEXbudKYXDB0KJUs6p0ZPn07RV/r7+9OzZ09WrVrF2LFjadiwIT///HMqBxcREUl9Kmniffz94cEHnSkG48fDvHlQuLBzajSF0yRKlSrFpk2bKF++PGFhYcyYMUNH1URExKuppIn3MgaqV4dFi5z5oDt2OGWtd29IwdGwzJkz079/fxYtWsQbb7zBww8/zOHDhz0QXERE5MappEn6EBzsTC2IjoYzZ6B0aefU6HffJfurIiIi2L59OwULFiQkJITPP//cA4FFRERujEqapC/33OPMCN29G+66C6pWhaZNYdOmZH1NQEAAQ4cOZebMmTz33HO0b9+eoyk8lSoiIuIJKmmSPt16K/Tv79wRGhUFLVr8e2o0GdeaVa1albi4OAICAggODuarr77yYGgREZGkU0mT9C17dmdqwZ49ztIdffoke6B7jhw5GDNmDOPHj+exxx6je/funEzF+aIiIiIpoZImviFzZmjV6r8D3YsUcU6NJrFw1atXj/j4eI4dO0Zo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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**(x-2)\n",
    "plt.figure(figsize=(10,7))\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of qubit\")\n",
    "plt.ylabel(\"Change of f\")\n",
    "# 设置横轴的上下限\n",
    "# plt.xlim(2, 12)\n",
    "# 设置纵轴的上下限\n",
    "# plt.ylim(0, 1)\n",
    "\n",
    "plt.semilogy()\n",
    "plt.plot(x, loss_change, color=\"red\", linewidth=1.0, linestyle=\"-\", label=\" Delta C\")\n",
    "plt.plot(x, y, color=\"black\", linewidth=1.0, linestyle=\"-\", label=\"2^(-0.5n-1)\")\n",
    "\n",
    "\n",
    "plt.legend(loc=\"best\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "fb2e486a015784361e0077d7fcfeac02d1a431449f68aa51e1f4959008c61275"
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
