{
 "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 = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N,3]))\n",
    "    theta = paddle.to_tensor(theta, stop_gradient=True, dtype='float64')\n",
    "    cir = UAnsatz(N)    \n",
    "    cir.weak_superposition_layer()\n",
    "\n",
    "    for d in range(D):\n",
    "        for i in range(N):\n",
    "            cir.rz(theta[d][i][0], i)\n",
    "            cir.ry(theta[d][i][1], i)\n",
    "            cir.rz(theta[d][i][2], i)\n",
    "\n",
    "    return cir.run_state_vector()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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": 7,
   "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.7783534401044561\n",
      "num_qubits = 2,     vC = 0.7474267681404074\n",
      "num_qubits = 2,     vC = 0.8602874947236684\n",
      "num_qubits = 2,     vC = 0.9276086460418655\n",
      "num_qubits = 2,     vC = 0.2583799779759426\n",
      "num_qubits = 2,     vC = 0.023257977234251746\n",
      "num_qubits = 2,     vC = 0.13003765888340998\n",
      "num_qubits = 2,     vC = 0.061313944252695075\n",
      "num_qubits = 2,     vC = 0.07531674600762331\n",
      "num_qubits = 2,     vC = 0.6405519697901249\n",
      "num_qubits = 2,     vC = 0.18218952266363\n",
      "num_qubits = 2,     vC = 0.6289538432495192\n",
      "num_qubits = 2,     vC = 0.11605169161621065\n",
      "num_qubits = 2,     vC = 0.2590471639488335\n",
      "num_qubits = 2,     vC = 0.8184931481295469\n",
      "num_qubits = 2,     vC = 0.614134460665279\n",
      "num_qubits = 2,     vC = 0.0954154153148475\n",
      "num_qubits = 2,     vC = 0.4442622454735228\n",
      "num_qubits = 2,     vC = 0.671399779533658\n",
      "num_qubits = 2,     vC = 0.46980647711688617\n",
      "num_qubits = 2,     vC = 0.12061743729402197\n",
      "num_qubits = 2,     vC = 0.25233829974156274\n",
      "num_qubits = 2,     vC = 0.8892857117502116\n",
      "num_qubits = 2,     vC = 0.4832496955657031\n",
      "num_qubits = 2,     vC = 0.8822885082514136\n",
      "num_qubits = 2,     vC = 0.36912043736647243\n",
      "num_qubits = 2,     vC = 0.7614410088676972\n",
      "num_qubits = 2,     vC = 0.305988070935668\n",
      "num_qubits = 2,     vC = 0.8112475006062151\n",
      "num_qubits = 2,     vC = 0.033169726290885236\n",
      "num_qubits = 2,     vC = 0.9177020984911627\n",
      "num_qubits = 2,     vC = 0.9971220475160473\n",
      "num_qubits = 2,     vC = 0.0652726347107547\n",
      "num_qubits = 2,     vC = 0.13544396091006894\n",
      "num_qubits = 2,     vC = 0.3940253389001575\n",
      "num_qubits = 2,     vC = 0.16411905874116473\n",
      "num_qubits = 2,     vC = 0.0036156259912957993\n",
      "num_qubits = 2,     vC = 0.5927043525905134\n",
      "num_qubits = 2,     vC = 0.7392353134772273\n",
      "num_qubits = 2,     vC = 0.8994107201243251\n",
      "num_qubits = 2,     vC = 0.8144281613632359\n",
      "num_qubits = 2,     vC = 0.6944113799228494\n",
      "num_qubits = 2,     vC = 0.7635962651089545\n",
      "num_qubits = 2,     vC = 0.7788613233503091\n",
      "num_qubits = 2,     vC = 0.6347303216688294\n",
      "num_qubits = 2,     vC = 0.20264711317209108\n",
      "num_qubits = 2,     vC = 0.7334619236442727\n",
      "num_qubits = 2,     vC = 0.7374213043585771\n",
      "num_qubits = 2,     vC = 0.6770818949432067\n",
      "num_qubits = 2,     vC = 0.02492947402335223\n",
      "num_qubits = 3,     vC = 0.2746304759116556\n",
      "num_qubits = 3,     vC = 0.06725871408664225\n",
      "num_qubits = 3,     vC = 0.04107926049305568\n",
      "num_qubits = 3,     vC = 0.03873907163299884\n",
      "num_qubits = 3,     vC = 0.009264928937883733\n",
      "num_qubits = 3,     vC = 0.008142811301423558\n",
      "num_qubits = 3,     vC = 0.027759857628561504\n",
      "num_qubits = 3,     vC = 0.15922695297031336\n",
      "num_qubits = 3,     vC = 0.11037441706444993\n",
      "num_qubits = 3,     vC = 0.03330389498912526\n",
      "num_qubits = 3,     vC = 0.010668890492058162\n",
      "num_qubits = 3,     vC = 0.7874665423780656\n",
      "num_qubits = 3,     vC = 0.023641313090591726\n",
      "num_qubits = 3,     vC = 0.295424105582446\n",
      "num_qubits = 3,     vC = 0.11929929831349055\n",
      "num_qubits = 3,     vC = 0.04935929568548461\n",
      "num_qubits = 3,     vC = 0.0925678992277121\n",
      "num_qubits = 3,     vC = 0.7910697906065302\n",
      "num_qubits = 3,     vC = 0.021758847813870514\n",
      "num_qubits = 3,     vC = 0.20076008383652483\n",
      "num_qubits = 3,     vC = 0.14991443959846096\n",
      "num_qubits = 3,     vC = 0.13540380780698616\n",
      "num_qubits = 3,     vC = 0.08065260627501328\n",
      "num_qubits = 3,     vC = 0.08359215616146534\n",
      "num_qubits = 3,     vC = 0.592925589115343\n",
      "num_qubits = 3,     vC = 0.025426535476886933\n",
      "num_qubits = 3,     vC = 0.7742312372858362\n",
      "num_qubits = 3,     vC = 0.21243515207007183\n",
      "num_qubits = 3,     vC = 0.8055495100640168\n",
      "num_qubits = 3,     vC = 0.1019485483193723\n",
      "num_qubits = 3,     vC = 0.5767560626904977\n",
      "num_qubits = 3,     vC = 0.10246985430103482\n",
      "num_qubits = 3,     vC = 0.09392405497708685\n",
      "num_qubits = 3,     vC = 0.12076040160904573\n",
      "num_qubits = 3,     vC = 0.0005038028987850501\n",
      "num_qubits = 3,     vC = 0.8547236185709627\n",
      "num_qubits = 3,     vC = 0.17764952713349214\n",
      "num_qubits = 3,     vC = 0.27595739922998547\n",
      "num_qubits = 3,     vC = 0.8777776084316025\n",
      "num_qubits = 3,     vC = 0.1094728774302283\n",
      "num_qubits = 3,     vC = 0.0776400001230104\n",
      "num_qubits = 3,     vC = 0.30767706360748925\n",
      "num_qubits = 3,     vC = 0.2151942266287325\n",
      "num_qubits = 3,     vC = 0.20955208026900213\n",
      "num_qubits = 3,     vC = 0.5246550361126762\n",
      "num_qubits = 3,     vC = 0.714359842354817\n",
      "num_qubits = 3,     vC = 0.5103779120513141\n",
      "num_qubits = 3,     vC = 0.02609195239189342\n",
      "num_qubits = 3,     vC = 0.17366997350288116\n",
      "num_qubits = 3,     vC = 0.0048320262733783734\n",
      "num_qubits = 4,     vC = 0.09286618159430675\n",
      "num_qubits = 4,     vC = 0.08190277838024837\n",
      "num_qubits = 4,     vC = 0.11554711142108451\n",
      "num_qubits = 4,     vC = 0.3225444646084371\n",
      "num_qubits = 4,     vC = 0.001042199304368227\n",
      "num_qubits = 4,     vC = 0.0011294810841432643\n",
      "num_qubits = 4,     vC = 0.11834875592053219\n",
      "num_qubits = 4,     vC = 0.25798320273761255\n",
      "num_qubits = 4,     vC = 0.0815648222233718\n",
      "num_qubits = 4,     vC = 0.1809387157767904\n",
      "num_qubits = 4,     vC = 0.0683310797600458\n",
      "num_qubits = 4,     vC = 0.011035588933208254\n",
      "num_qubits = 4,     vC = 0.37900453611736984\n",
      "num_qubits = 4,     vC = 0.054447041371607344\n",
      "num_qubits = 4,     vC = 0.004958797918581651\n",
      "num_qubits = 4,     vC = 0.0005031945398810185\n",
      "num_qubits = 4,     vC = 0.07484996799302278\n",
      "num_qubits = 4,     vC = 3.514733184677182e-05\n",
      "num_qubits = 4,     vC = 0.6634211213539016\n",
      "num_qubits = 4,     vC = 0.045269985169101225\n",
      "num_qubits = 4,     vC = 0.2071863867144578\n",
      "num_qubits = 4,     vC = 0.0064837208894301095\n",
      "num_qubits = 4,     vC = 0.0875056379848174\n",
      "num_qubits = 4,     vC = 0.018227650703418474\n",
      "num_qubits = 4,     vC = 0.07806997735347473\n",
      "num_qubits = 4,     vC = 0.003264839897375435\n",
      "num_qubits = 4,     vC = 0.0455032160434034\n",
      "num_qubits = 4,     vC = 0.0019083747886360198\n",
      "num_qubits = 4,     vC = 0.3189078108941635\n",
      "num_qubits = 4,     vC = 0.06960969844618486\n",
      "num_qubits = 4,     vC = 0.004863041373316478\n",
      "num_qubits = 4,     vC = 0.02111954714107493\n",
      "num_qubits = 4,     vC = 0.5784312481610571\n",
      "num_qubits = 4,     vC = 0.00037970964405441987\n",
      "num_qubits = 4,     vC = 0.010638731298999777\n",
      "num_qubits = 4,     vC = 0.061317607462949286\n",
      "num_qubits = 4,     vC = 0.07255971720378175\n",
      "num_qubits = 4,     vC = 0.1150480880374528\n",
      "num_qubits = 4,     vC = 0.009420807571259722\n",
      "num_qubits = 4,     vC = 0.10588040415168737\n",
      "num_qubits = 4,     vC = 0.28495715292420815\n",
      "num_qubits = 4,     vC = 0.020451244446422885\n",
      "num_qubits = 4,     vC = 0.08044843559428524\n",
      "num_qubits = 4,     vC = 0.050442631558176854\n",
      "num_qubits = 4,     vC = 0.14340291559660562\n",
      "num_qubits = 4,     vC = 0.37891118954464886\n",
      "num_qubits = 4,     vC = 1.447048427326446e-08\n",
      "num_qubits = 4,     vC = 0.013723840360911453\n",
      "num_qubits = 4,     vC = 0.010759411137026366\n",
      "num_qubits = 4,     vC = 0.0963819339553624\n",
      "num_qubits = 5,     vC = 0.17475788948337106\n",
      "num_qubits = 5,     vC = 0.23375590887428654\n",
      "num_qubits = 5,     vC = 0.001343333762802481\n",
      "num_qubits = 5,     vC = 0.00599796281056301\n",
      "num_qubits = 5,     vC = 0.08298713714176487\n",
      "num_qubits = 5,     vC = 0.11891758702431672\n",
      "num_qubits = 5,     vC = 0.02437074002479324\n",
      "num_qubits = 5,     vC = 0.0978516271391442\n",
      "num_qubits = 5,     vC = 0.07361342224104862\n",
      "num_qubits = 5,     vC = 0.02847587278150097\n",
      "num_qubits = 5,     vC = 0.03525578296752505\n",
      "num_qubits = 5,     vC = 0.009325363733543979\n",
      "num_qubits = 5,     vC = 0.13004442783787074\n",
      "num_qubits = 5,     vC = 0.04820645414126578\n",
      "num_qubits = 5,     vC = 0.0005149425434693854\n",
      "num_qubits = 5,     vC = 0.007033133366995704\n",
      "num_qubits = 5,     vC = 0.05551458722130541\n",
      "num_qubits = 5,     vC = 0.04996397281711882\n",
      "num_qubits = 5,     vC = 0.3370854944662155\n",
      "num_qubits = 5,     vC = 0.055002925639318\n",
      "num_qubits = 5,     vC = 0.05164253552769197\n",
      "num_qubits = 5,     vC = 0.011641495189906403\n",
      "num_qubits = 5,     vC = 0.03291922139727873\n",
      "num_qubits = 5,     vC = 0.016642857180643886\n",
      "num_qubits = 5,     vC = 0.019116529562406035\n",
      "num_qubits = 5,     vC = 0.007395093041685866\n",
      "num_qubits = 5,     vC = 0.16942729412856677\n",
      "num_qubits = 5,     vC = 0.09551233323281567\n",
      "num_qubits = 5,     vC = 0.003786503186357376\n",
      "num_qubits = 5,     vC = 0.00817653115513244\n",
      "num_qubits = 5,     vC = 0.0009440413843980702\n",
      "num_qubits = 5,     vC = 0.0374214264153064\n",
      "num_qubits = 5,     vC = 0.03296427976319178\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.004462620607473193\n",
      "num_qubits = 5,     vC = 0.0007937457525561387\n",
      "num_qubits = 5,     vC = 0.026315099900875938\n",
      "num_qubits = 5,     vC = 0.05196484509295598\n",
      "num_qubits = 5,     vC = 0.008516388151822941\n",
      "num_qubits = 5,     vC = 0.00488820707040395\n",
      "num_qubits = 5,     vC = 0.09147412015521474\n",
      "num_qubits = 5,     vC = 0.011205936495719233\n",
      "num_qubits = 5,     vC = 0.09719492389717987\n",
      "num_qubits = 5,     vC = 0.2699853721036156\n",
      "num_qubits = 5,     vC = 0.007121523511387943\n",
      "num_qubits = 5,     vC = 0.01390653674858434\n",
      "num_qubits = 5,     vC = 0.10248902197704338\n",
      "num_qubits = 5,     vC = 0.00404196534907506\n",
      "num_qubits = 5,     vC = 0.00782348750333163\n",
      "num_qubits = 5,     vC = 0.1118301525906424\n",
      "num_qubits = 5,     vC = 0.004477909377649516\n",
      "num_qubits = 6,     vC = 0.01873283308117872\n",
      "num_qubits = 6,     vC = 0.04529430722448088\n",
      "num_qubits = 6,     vC = 0.017203551079297275\n",
      "num_qubits = 6,     vC = 0.028702510713590507\n",
      "num_qubits = 6,     vC = 0.02066968408803301\n",
      "num_qubits = 6,     vC = 0.0003652408523150828\n",
      "num_qubits = 6,     vC = 1.7086871748542448e-05\n",
      "num_qubits = 6,     vC = 0.0035108186923864426\n",
      "num_qubits = 6,     vC = 0.005890394906773016\n",
      "num_qubits = 6,     vC = 0.049817541580908134\n",
      "num_qubits = 6,     vC = 0.05329749057439755\n",
      "num_qubits = 6,     vC = 0.010843005642572718\n",
      "num_qubits = 6,     vC = 0.014703005607933944\n",
      "num_qubits = 6,     vC = 0.019634368105486417\n",
      "num_qubits = 6,     vC = 0.007592931813876297\n",
      "num_qubits = 6,     vC = 0.14924647593248286\n",
      "num_qubits = 6,     vC = 0.00504549158150633\n",
      "num_qubits = 6,     vC = 0.006529951156548943\n",
      "num_qubits = 6,     vC = 0.0006137359278596639\n",
      "num_qubits = 6,     vC = 0.04723074486026111\n",
      "num_qubits = 6,     vC = 0.0005180784147214335\n",
      "num_qubits = 6,     vC = 0.09766061190663942\n",
      "num_qubits = 6,     vC = 0.014775850788641996\n",
      "num_qubits = 6,     vC = 0.0016127186316982865\n",
      "num_qubits = 6,     vC = 0.018687987456272193\n",
      "num_qubits = 6,     vC = 0.004162482159849003\n",
      "num_qubits = 6,     vC = 0.0997008524937294\n",
      "num_qubits = 6,     vC = 0.0005729751934695441\n",
      "num_qubits = 6,     vC = 0.0003483664384951587\n",
      "num_qubits = 6,     vC = 0.012705378947234896\n",
      "num_qubits = 6,     vC = 0.0032764996599956462\n",
      "num_qubits = 6,     vC = 0.005781917132082243\n",
      "num_qubits = 6,     vC = 0.013483733896302585\n",
      "num_qubits = 6,     vC = 0.0029674956963804456\n",
      "num_qubits = 6,     vC = 0.008236138243175938\n",
      "num_qubits = 6,     vC = 0.01973620702107126\n",
      "num_qubits = 6,     vC = 0.0024569164765118213\n",
      "num_qubits = 6,     vC = 0.04195276605599808\n",
      "num_qubits = 6,     vC = 0.0002971211049608845\n",
      "num_qubits = 6,     vC = 0.07366822296837686\n",
      "num_qubits = 6,     vC = 1.633582426894895e-05\n",
      "num_qubits = 6,     vC = 0.01370434405521062\n",
      "num_qubits = 6,     vC = 0.01715133725830693\n",
      "num_qubits = 6,     vC = 0.04013264447746508\n",
      "num_qubits = 6,     vC = 0.004107351529076741\n",
      "num_qubits = 6,     vC = 0.0007631000866540653\n",
      "num_qubits = 6,     vC = 0.14546854416738705\n",
      "num_qubits = 6,     vC = 0.08983040785986271\n",
      "num_qubits = 6,     vC = 0.0003102926724465916\n",
      "num_qubits = 6,     vC = 0.13980242457679276\n",
      "num_qubits = 7,     vC = 0.011286794948245244\n",
      "num_qubits = 7,     vC = 0.03411509652075558\n",
      "num_qubits = 7,     vC = 0.00048585310488815097\n",
      "num_qubits = 7,     vC = 0.022207549268115172\n",
      "num_qubits = 7,     vC = 7.059486600177159e-05\n",
      "num_qubits = 7,     vC = 0.001284042790204884\n",
      "num_qubits = 7,     vC = 0.00017613017186929845\n",
      "num_qubits = 7,     vC = 0.1666441893741549\n",
      "num_qubits = 7,     vC = 0.000131874242641193\n",
      "num_qubits = 7,     vC = 0.00038778428814654814\n",
      "num_qubits = 7,     vC = 0.0036321319945227444\n",
      "num_qubits = 7,     vC = 0.008288062814061106\n",
      "num_qubits = 7,     vC = 9.027378077668766e-07\n",
      "num_qubits = 7,     vC = 0.0002242547099440999\n",
      "num_qubits = 7,     vC = 0.005544139849557586\n",
      "num_qubits = 7,     vC = 0.0032248631182769513\n",
      "num_qubits = 7,     vC = 0.010400225075453377\n",
      "num_qubits = 7,     vC = 0.07739540211312493\n",
      "num_qubits = 7,     vC = 0.04331785250883049\n",
      "num_qubits = 7,     vC = 0.008824223860751997\n",
      "num_qubits = 7,     vC = 0.03351480320532209\n",
      "num_qubits = 7,     vC = 0.0004548817887523739\n",
      "num_qubits = 7,     vC = 0.012854908837253978\n",
      "num_qubits = 7,     vC = 0.02801810929040076\n",
      "num_qubits = 7,     vC = 0.009351667128027999\n",
      "num_qubits = 7,     vC = 0.004387458947879963\n",
      "num_qubits = 7,     vC = 4.721128553857824e-06\n",
      "num_qubits = 7,     vC = 0.02943221565204414\n",
      "num_qubits = 7,     vC = 0.004747067229219626\n",
      "num_qubits = 7,     vC = 0.0034387457348250923\n",
      "num_qubits = 7,     vC = 0.002193839085762058\n",
      "num_qubits = 7,     vC = 0.0023879775822133265\n",
      "num_qubits = 7,     vC = 0.019464371401644733\n",
      "num_qubits = 7,     vC = 0.0005464845258783974\n",
      "num_qubits = 7,     vC = 0.003298272385611761\n",
      "num_qubits = 7,     vC = 0.00015210421597452233\n",
      "num_qubits = 7,     vC = 0.027031164222486394\n",
      "num_qubits = 7,     vC = 0.016940209003025807\n",
      "num_qubits = 7,     vC = 0.0698066655952426\n",
      "num_qubits = 7,     vC = 0.006916922969757765\n",
      "num_qubits = 7,     vC = 0.0014934005824799928\n",
      "num_qubits = 7,     vC = 0.0017431560449633905\n",
      "num_qubits = 7,     vC = 0.002188924430015004\n",
      "num_qubits = 7,     vC = 0.001898187672096104\n",
      "num_qubits = 7,     vC = 0.001815338046256201\n",
      "num_qubits = 7,     vC = 0.0001457530450297917\n",
      "num_qubits = 7,     vC = 0.00020140140732895735\n",
      "num_qubits = 7,     vC = 0.004935029347929516\n",
      "num_qubits = 7,     vC = 0.004993983872344906\n",
      "num_qubits = 7,     vC = 0.001055629708560015\n",
      "num_qubits = 8,     vC = 3.279061702348294e-05\n",
      "num_qubits = 8,     vC = 0.00037003951376223746\n",
      "num_qubits = 8,     vC = 0.017374545759552967\n",
      "num_qubits = 8,     vC = 0.00015407087663521146\n",
      "num_qubits = 8,     vC = 0.0005632344180980501\n",
      "num_qubits = 8,     vC = 0.0011794706999984645\n",
      "num_qubits = 8,     vC = 0.00010853520093524623\n",
      "num_qubits = 8,     vC = 9.762673327405175e-06\n",
      "num_qubits = 8,     vC = 4.194574962789693e-05\n",
      "num_qubits = 8,     vC = 0.002832201690296975\n",
      "num_qubits = 8,     vC = 0.1590778363985129\n",
      "num_qubits = 8,     vC = 0.018464857521326636\n",
      "num_qubits = 8,     vC = 4.876140782002348e-06\n",
      "num_qubits = 8,     vC = 0.00022569510533175673\n",
      "num_qubits = 8,     vC = 3.948106212301159e-06\n",
      "num_qubits = 8,     vC = 0.00016502014615397352\n",
      "num_qubits = 8,     vC = 0.014188581027050477\n",
      "num_qubits = 8,     vC = 0.002774925589140937\n",
      "num_qubits = 8,     vC = 0.0013508204334164576\n",
      "num_qubits = 8,     vC = 0.06880940229892012\n",
      "num_qubits = 8,     vC = 0.006957211571257902\n",
      "num_qubits = 8,     vC = 0.00023770473991278156\n",
      "num_qubits = 8,     vC = 0.0003099118081042192\n",
      "num_qubits = 8,     vC = 0.0019735548865148856\n",
      "num_qubits = 8,     vC = 0.00010417715915220617\n",
      "num_qubits = 8,     vC = 0.005818905190646037\n",
      "num_qubits = 8,     vC = 0.0010858412513550316\n",
      "num_qubits = 8,     vC = 2.0976342357358944e-05\n",
      "num_qubits = 8,     vC = 0.0020733772158639846\n",
      "num_qubits = 8,     vC = 0.006932069586905031\n",
      "num_qubits = 8,     vC = 0.0003742768365487232\n",
      "num_qubits = 8,     vC = 0.10222805488787229\n",
      "num_qubits = 8,     vC = 2.28224744349429e-06\n",
      "num_qubits = 8,     vC = 0.0002405108021435971\n",
      "num_qubits = 8,     vC = 0.0001003412980764041\n",
      "num_qubits = 8,     vC = 0.0010310952696268548\n",
      "num_qubits = 8,     vC = 0.0001646148016314673\n",
      "num_qubits = 8,     vC = 0.009097186766882488\n",
      "num_qubits = 8,     vC = 0.0004311426887327662\n",
      "num_qubits = 8,     vC = 0.010753659569023877\n",
      "num_qubits = 8,     vC = 0.03049754026082332\n",
      "num_qubits = 8,     vC = 0.00256455036045926\n",
      "num_qubits = 8,     vC = 1.0925680891295468e-05\n",
      "num_qubits = 8,     vC = 0.002298841709935893\n",
      "num_qubits = 8,     vC = 0.002241283913552175\n",
      "num_qubits = 8,     vC = 5.572591237062733e-05\n",
      "num_qubits = 8,     vC = 0.00397240163834902\n",
      "num_qubits = 8,     vC = 0.0011998951797443863\n",
      "num_qubits = 8,     vC = 0.013655029424768228\n",
      "num_qubits = 8,     vC = 0.001151145823876641\n",
      "num_qubits = 9,     vC = 0.0002283091754555119\n",
      "num_qubits = 9,     vC = 0.0021549690134551216\n",
      "num_qubits = 9,     vC = 7.377966853492519e-05\n",
      "num_qubits = 9,     vC = 0.0008212030569762098\n",
      "num_qubits = 9,     vC = 0.0028082454250251045\n",
      "num_qubits = 9,     vC = 0.0023488183959737984\n",
      "num_qubits = 9,     vC = 1.2321533788835068e-05\n",
      "num_qubits = 9,     vC = 0.0034251410442243755\n",
      "num_qubits = 9,     vC = 0.03163012674884093\n",
      "num_qubits = 9,     vC = 0.000832868101774019\n",
      "num_qubits = 9,     vC = 0.00011511614933158966\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 3.571816229308317e-06\n",
      "num_qubits = 9,     vC = 4.5507095460110956e-05\n",
      "num_qubits = 9,     vC = 0.0007008760356509898\n",
      "num_qubits = 9,     vC = 3.5076085193154056e-06\n",
      "num_qubits = 9,     vC = 2.618688007776051e-06\n",
      "num_qubits = 9,     vC = 0.0030522880088909568\n",
      "num_qubits = 9,     vC = 0.0005356090703812485\n",
      "num_qubits = 9,     vC = 0.0015522131996801981\n",
      "num_qubits = 9,     vC = 0.00095930008211483\n",
      "num_qubits = 9,     vC = 0.002003079360291693\n",
      "num_qubits = 9,     vC = 0.002084029857965989\n",
      "num_qubits = 9,     vC = 0.0009914407087382743\n",
      "num_qubits = 9,     vC = 1.6545636057377634e-05\n",
      "num_qubits = 9,     vC = 6.023768180222755e-05\n",
      "num_qubits = 9,     vC = 5.663255759130676e-06\n",
      "num_qubits = 9,     vC = 5.840903149114207e-06\n",
      "num_qubits = 9,     vC = 4.163736598192704e-06\n",
      "num_qubits = 9,     vC = 0.0005695720841216473\n",
      "num_qubits = 9,     vC = 0.0015429219229037136\n",
      "num_qubits = 9,     vC = 0.0002483239396797307\n",
      "num_qubits = 9,     vC = 0.00039807768083906426\n",
      "num_qubits = 9,     vC = 0.0001505906297909889\n",
      "num_qubits = 9,     vC = 0.016867005075651538\n",
      "num_qubits = 9,     vC = 0.00018468948051224654\n",
      "num_qubits = 9,     vC = 0.0005976384410808278\n",
      "num_qubits = 9,     vC = 0.00010078883687938777\n",
      "num_qubits = 9,     vC = 0.02076161364429058\n",
      "num_qubits = 9,     vC = 7.722834084855827e-07\n",
      "num_qubits = 9,     vC = 0.002861874138415988\n",
      "num_qubits = 9,     vC = 0.0008712139690602302\n",
      "num_qubits = 9,     vC = 0.0015300599024051721\n",
      "num_qubits = 9,     vC = 0.03348457110570071\n",
      "num_qubits = 9,     vC = 0.00048549556648417897\n",
      "num_qubits = 9,     vC = 0.0012615369001619345\n",
      "num_qubits = 9,     vC = 8.467852656227655e-07\n",
      "num_qubits = 9,     vC = 2.5798948127924465e-05\n",
      "num_qubits = 9,     vC = 0.001779935279568635\n",
      "num_qubits = 9,     vC = 0.010003833453119174\n",
      "num_qubits = 9,     vC = 2.14714713073706e-05\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(500):\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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+HHX0URERCQV8dPlzv/MGNPYGDP233dNuHDNNdfw2muvsWHDBqKioggLC2PmzJlaryYiIiKJElAlzVo711rbJUeOHK6j/K1w4cLMnj2byZMnM2jQIKpXr87GjRtdxxIRERGfC6iS5mc1a9Zk48aNdOzYkaZNm9KhQwf27/f1zasiIiLJZu/evdSuXZvw8HCKFy/OiBEj/vH9adOmkSFDBvr373/ea6OioujUqdMF3/fbb7+lYsWKFC1alFatWvHnn3+e9zN79uwhc+bMREZGEhkZSbdu3a44f58+fbjpppvOm8U3atQoJk6ceMXvdyEqaSkoODiYjh07Eh8fT4ECBYiIiKB///4cO3bMdTQREZEUlS5dOoYOHUpMTAzr1q1j9OjRxMTEALBkyRIGDx5MTEwMX3zxBZMnT/7Ha1999VUeffTRC75v79696dmzJ19//TW5cuViwoQJF/y5IkWKsHXrVrZu3cqYMWOuOH/jxo3ZsGHDec937NiRN99884rf70JU0hzInj07AwYMYNOmTezcuZPQ0FCmT5+u9WoiIpJm5M+fnzJlygDe/y+GhYWxf/9+duzYQd++fVm4cCFFixbls88+Y9q0aSxcuBDwBsxu376diIiI897TWsuSJUto2bIlAB06dODjjz++olzZsmWjT58+REREUKdOHX766acL/lylSpXInz//ec9nyZKFggULXrDAXSmVNIcKFizIzJkzmTZtGkOHDqVKlSqsW7fOdSwREUljjDFJ/rgSe/bsISoqiooVK1KyZEnWrFlDvnz5AMiaNSsLFy6kfv36AGzatIkSJUpc8H0OHDhAzpw5SZfO21CpQIECF11a9O2331K6dGlq1qz5j03V//jjDypVqsS2bduoWrUq48aNu6LfBaBcuXJJslG7SpoPVKtWjQ0bNtCtWzdatGhBu3bt2Lt3r+tYIiKSRlhrk/yRWEePHqVFixYMHz6ca6655rI//+OPP5I3b97/8uuSP39+vv/+e6Kiohg2bBht2rTh8OHDAGTIkIFGjRoBEBkZyZ49e674/a+77jp++OGH/5QRAqyk+WkEx5UKCgqiQ4cOxMfHU6hQISIjI3nxxRf5448/XEcTERFJFqdOnaJFixa0bduW5s2bJ+o1mTNn5sSJE39/Xb9+fSIjI+ncuTO5c+fm4MGDnD59GoB9+/Zx4403nvceGTNm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rZQuXZrnn3+eo0ePuo4mIpKqqKSJJFa+fDBuHHz+OUybBmXLwrJlrlP5VtasWXnppZeIiorim2++ITQ0lPfee0/r1UREEkklTeRKlS7tlbO+feH++6FFC9i923Uq37r55pt5//33mTVrFm+99RYVK1Zk9erVrmOJiPieSprI1TAGWrb0RnaUKQMVKngDcY8ccZ3MtypXrsyaNWvo2bMnrVu3plWrVuzZs8d1LBER31JJE/kvMmeGPn1g2zbYt89brzZ5MuiS3gUFBQXRpk0b4uLiKF68OGXLlqVPnz4cUbkVETmPSppIUrjxRnjvPfjoI3j7bahUCdascZ3Kt7JkycLzzz/Ptm3b2Lt3L6GhoUyaNEnr1UREzqGSJpKUKlb0ytmjj8I990DbtrB3r+tUvlWgQAHee+895syZw/jx4ylfvjwrVqxwHUtExBdU0kSSWlAQtGvnDb8tUgQiI+Gll0BbJl1UhQoVWLVqFU8//TT33Xcfd999Nz/++KPrWCIiTqmkiSSXrFnh5ZdhyxaIifH2A50xA6x1ncyXjDG0atWKuLg4IiMj6datG8888wyHDx92HU1ExAmVNJHkdsstMHMmTJ0KgwdD9eqwebPrVL6VOXNm+vTpw4QJE/jpp58ICQlh/PjxnNHwYBFJY1TSRFJK9eqwcSM88AA0akTIoEHwww+uU/lWnjx5mDRpEvPmzWPy5MmULVuWpUuXuo4lIpJiVNJEUlJwMHTqBPHxnMqVC0qVgldegePHXSfzrbJly7JixQr69u1Lx44dad68Od98843rWCIiyU4lTcSFa65hd5cusGGDN2MtNNTbakrr1S7IGEPLli2JjY2lQoUKVKxYkaeffppDhw65jiYikmxU0kRcKlwYZs3y1qsNGwaVK8O6da5T+VamTJl45pln2LlzJ7/99hshISG88847Wq8mIgFJJU3ED6pX986qde/ubTfVpg18/73rVL51/fXXM378eD7//HOmT59O6dKl+fLLL13HEhFJUippIn4RFATt23vz1W691dvIvW9fOHrUdTLfKl26NEuXLuXFF1+kS5cuNG3alF27drmOJSKSJFTSRPwma1Zv+O3WrfDddxASApMmaT/QizDG0Lx5c2JiYqhWrRqVK1fmySef5ODBg66jiYj8JyppIn51000wZQrMmQPjx0O5crB8uetUvpUxY0aeeuop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eWOJiPxLZCRMnQpbtsCff3p7hHbsCDExrpP5ToECBZgyZQpz5sxh3LhxlC9fnhUrVriOJSJXKDF3d5YBbgF+BH4AbjbGFDHGpEvucCIi57nlFhg+HHbt8s6q1akDjRvDypW6I/RfKlSowOrVq3nqqae47777uPvuu/n2229dxxKRRErM5c63gHXAWGAcsBaYBcQbY+olYzYRkYvLnRv69oVvv/U2c+/YEapU8babOnPGdTrfMMZw7733EhcXR0REBOXKlePZZ5/l8GFtICPid4kpaT8Apa215ay1ZYHSwG6gLjA4OcOJiFxW5szeUNy4OOjVC157zdvIfexYOHHCdTrfyJw5M3379mXHjh38+OOPhIaGMn78eM6o0Ir4VmJKWjFrbfRfX1hrY4BQa+3u5IslInKFgoOhRQtYtw7GjYNPP4VCheDVV+H3312n840bbriBd999l08//ZTJkydTtmxZli1b5jqWiFxAYkpatDHmbWNMzYTHW0CMMSYjCbPTRER8wxhv1tq8ebB4MXz1FRQpAk88Ad9/7zqdb5QrV44VK1bQp08fHnjgAZo3b84333zjOpaInCMxJe1+4Gvg8YTH7oTnTgG1kyeWiEgSKFEC3n3XG90RHAylS8N993lfC8YY7r77bmJjYylfvjwVK1bk6aefRgPBRfwhMSM4jltrh1pr70p4DLHWHrPWnrXWalKiiPhfgQLw+uvwzTdecWvQABo2hKVLdUcokClTJp599ll27NjBgQMHCA0N5Z133tF6NRHHEjOCo6oxZrEx5itjzO6/HikR7kppWygRuaScOaF3b++O0Lvvhu7doXx5+OADOH3adTrn8ufPz4QJE/jss8+YNm0apUuX5ssvv3QdSyTNSszlzgnAMKAaUP6ch+9oWygRSZSMGb2RHdHR8PzzMHIkhITAW2/BsWOu0zlXunRpli1bxosvvsiDDz5I06ZN2bVrl+tYImlOYkraIWvt59ban621B/56JHsyEZHkFhQETZrAqlUwZYp3o0GhQvDSS/Drr67TOWWMoXnz5sTExFC1alUqV67Mk08+ycGDB11HE0kzElPSlhpjXjfGVDbGlPnrkezJRERS0l+DcJcvh337oFgxeOQR79JoGpYpUyaefvppoqOjOXLkCCEhIbz99tuc1uVhkWSXmJJWESgHvAoMTXgMSc5QIiLOhIZ6c9ai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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
}
