{
 "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 = 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.U.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def WriteJson(list_write, json_file_name):\n",
    "    with open(json_file_name + '.json', 'w') as file_save:\n",
    "        json_data = json.dumps(list_write, indent=4)\n",
    "        file_save.write(json_data)\n",
    "        file_save.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class StateNet_max(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_max, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    # loss function\n",
    "    def forward(self, N, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "        \n",
    "        rho_luo = cir.run_state_vector()\n",
    "        \n",
    "        # max_luo\n",
    "        loss = - (rho_luo.conj().t() @ H @ rho_luo).real()\n",
    "        return loss\n",
    "\n",
    "class StateNet_min(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_min, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    def forward(self, N, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "        \n",
    "        rho_luo = cir.run_state_vector()\n",
    "        \n",
    "        # min_luo\n",
    "        loss = (rho_luo.conj().t() @ H @ rho_luo).real()\n",
    "\n",
    "        return loss\n",
    "\n",
    "def train_loss(N, Herm):\n",
    "\n",
    "    ITR = 100  # 设置训练的总迭代次数\n",
    "    LR = 0.1   # 设置学习速率\n",
    "    net_max = StateNet_max()\n",
    "    net_min = StateNet_min()\n",
    "    opt_max = paddle.optimizer.Adam(learning_rate=LR, parameters=net_max.parameters())\n",
    "    opt_min = paddle.optimizer.Adam(learning_rate=LR, parameters=net_min.parameters())\n",
    "\n",
    "    # optimization interation\n",
    "    for itr in range(1, ITR + 1):\n",
    "\n",
    "        # max_opt\n",
    "        loss_max = net_max(N, Herm)\n",
    "\n",
    "        loss_max.backward()\n",
    "        opt_max.minimize(loss_max)\n",
    "        opt_max.clear_grad()\n",
    "\n",
    "        # min_opt\n",
    "        loss_min = net_min(N, Herm)\n",
    "\n",
    "        loss_min.backward()\n",
    "        opt_min.minimize(loss_min)\n",
    "        opt_min.clear_grad()\n",
    "\n",
    "        # max - min\n",
    "        loss = -loss_max.numpy()[0] - loss_min.numpy()[0]\n",
    "        \n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/envs/paddle_quantum_dev/lib/python3.8/site-packages/paddle/fluid/framework.py:731: DeprecationWarning: `np.bool` is a deprecated alias for the builtin `bool`. To silence this warning, use `bool` by itself. Doing this will not modify any behavior and is safe. If you specifically wanted the numpy scalar type, use `np.bool_` here.\n",
      "Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations\n",
      "  elif dtype == np.bool:\n",
      "/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.26536676061884895\n",
      "num_qubits = 2,     vC = 0.7077752832770082\n",
      "num_qubits = 2,     vC = 0.13470730038836456\n",
      "num_qubits = 2,     vC = 0.3034123017017544\n",
      "num_qubits = 2,     vC = 0.7834914591927473\n",
      "num_qubits = 2,     vC = 0.26381884790399146\n",
      "num_qubits = 2,     vC = 0.6313954749473205\n",
      "num_qubits = 2,     vC = 0.6749579605294753\n",
      "num_qubits = 2,     vC = 0.9871873002373017\n",
      "num_qubits = 2,     vC = 0.1305529111918043\n",
      "num_qubits = 2,     vC = 0.06346102898586882\n",
      "num_qubits = 2,     vC = 0.6453765009068257\n",
      "num_qubits = 2,     vC = 0.7416580159133332\n",
      "num_qubits = 2,     vC = 0.8056211772381423\n",
      "num_qubits = 2,     vC = 0.05290509297518888\n",
      "num_qubits = 2,     vC = 0.3362632762905478\n",
      "num_qubits = 2,     vC = 0.2710142935567145\n",
      "num_qubits = 2,     vC = 0.8948872198263556\n",
      "num_qubits = 2,     vC = 0.8343450472878551\n",
      "num_qubits = 2,     vC = 0.20507919077824235\n",
      "num_qubits = 2,     vC = 0.7321584097371716\n",
      "num_qubits = 2,     vC = 0.7339253109197831\n",
      "num_qubits = 2,     vC = 0.0911100121357185\n",
      "num_qubits = 2,     vC = 0.2569976079619846\n",
      "num_qubits = 2,     vC = 0.5426827095903982\n",
      "num_qubits = 2,     vC = 0.40954052379472194\n",
      "num_qubits = 2,     vC = 0.33273320485513563\n",
      "num_qubits = 2,     vC = 0.526592262870638\n",
      "num_qubits = 2,     vC = 0.8247962161407759\n",
      "num_qubits = 2,     vC = 0.6679840005692126\n",
      "num_qubits = 2,     vC = 0.8564566123327646\n",
      "num_qubits = 2,     vC = 0.8385103736620573\n",
      "num_qubits = 2,     vC = 0.6965499795681593\n",
      "num_qubits = 2,     vC = 0.46746913975436394\n",
      "num_qubits = 2,     vC = 0.7714778497587879\n",
      "num_qubits = 2,     vC = 0.11204550603373678\n",
      "num_qubits = 2,     vC = 0.38519499593468326\n",
      "num_qubits = 2,     vC = 0.2485352552983666\n",
      "num_qubits = 2,     vC = 0.14333693706446965\n",
      "num_qubits = 2,     vC = 0.909541024862612\n",
      "num_qubits = 2,     vC = 0.09169757970385818\n",
      "num_qubits = 2,     vC = 0.8050995376824267\n",
      "num_qubits = 2,     vC = 0.1375430888073747\n",
      "num_qubits = 2,     vC = 0.4361042808052622\n",
      "num_qubits = 2,     vC = 0.5719332063098773\n",
      "num_qubits = 2,     vC = 0.11668680976338555\n",
      "num_qubits = 2,     vC = 0.5722364700728128\n",
      "num_qubits = 2,     vC = 0.2890489095989312\n",
      "num_qubits = 2,     vC = 0.6173725676354127\n",
      "num_qubits = 2,     vC = 0.017341973955280917\n",
      "num_qubits = 3,     vC = 0.039215205013431405\n",
      "num_qubits = 3,     vC = 0.01757397816785166\n",
      "num_qubits = 3,     vC = 0.4795252086690119\n",
      "num_qubits = 3,     vC = 0.15385806465534305\n",
      "num_qubits = 3,     vC = 0.35661942996661294\n",
      "num_qubits = 3,     vC = 0.0517803526041923\n",
      "num_qubits = 3,     vC = 0.7248694789961064\n",
      "num_qubits = 3,     vC = 0.000818939086818356\n",
      "num_qubits = 3,     vC = 0.3333943564112351\n",
      "num_qubits = 3,     vC = 0.13023129365440947\n",
      "num_qubits = 3,     vC = 0.2630613163991419\n",
      "num_qubits = 3,     vC = 0.14133198324297946\n",
      "num_qubits = 3,     vC = 0.5591719111847896\n",
      "num_qubits = 3,     vC = 0.401629248692041\n",
      "num_qubits = 3,     vC = 0.35918167392566097\n",
      "num_qubits = 3,     vC = 0.754272880187871\n",
      "num_qubits = 3,     vC = 0.07373567725978664\n",
      "num_qubits = 3,     vC = 0.1587666175132237\n",
      "num_qubits = 3,     vC = 0.8944620421003638\n",
      "num_qubits = 3,     vC = 0.5515881320741629\n",
      "num_qubits = 3,     vC = 0.4428338264531349\n",
      "num_qubits = 3,     vC = 0.5627191826073509\n",
      "num_qubits = 3,     vC = 0.09436979850998531\n",
      "num_qubits = 3,     vC = 0.4407760887305436\n",
      "num_qubits = 3,     vC = 0.0007547935132234746\n",
      "num_qubits = 3,     vC = 0.17983227803484111\n",
      "num_qubits = 3,     vC = 0.0043421932402011405\n",
      "num_qubits = 3,     vC = 0.039983035136322564\n",
      "num_qubits = 3,     vC = 0.01073026444568412\n",
      "num_qubits = 3,     vC = 0.7690083215727436\n",
      "num_qubits = 3,     vC = 0.13291828261196267\n",
      "num_qubits = 3,     vC = 0.021885655364446883\n",
      "num_qubits = 3,     vC = 0.09069000698331398\n",
      "num_qubits = 3,     vC = 0.36941709674725276\n",
      "num_qubits = 3,     vC = 0.12197382553365725\n",
      "num_qubits = 3,     vC = 0.5750761219523444\n",
      "num_qubits = 3,     vC = 0.2034967560063589\n",
      "num_qubits = 3,     vC = 0.6008620672237409\n",
      "num_qubits = 3,     vC = 0.26162697515819744\n",
      "num_qubits = 3,     vC = 0.7901416523854562\n",
      "num_qubits = 3,     vC = 0.5543875345600784\n",
      "num_qubits = 3,     vC = 0.098688648045109\n",
      "num_qubits = 3,     vC = 0.038978013336825545\n",
      "num_qubits = 3,     vC = 0.4482448673336422\n",
      "num_qubits = 3,     vC = 0.6367484067323412\n",
      "num_qubits = 3,     vC = 0.4511422351886804\n",
      "num_qubits = 3,     vC = 0.0347171272645417\n",
      "num_qubits = 3,     vC = 0.4244860765944366\n",
      "num_qubits = 3,     vC = 0.17022719030803346\n",
      "num_qubits = 3,     vC = 0.11598874765793668\n",
      "num_qubits = 4,     vC = 0.1049013498290333\n",
      "num_qubits = 4,     vC = 0.17110935332845037\n",
      "num_qubits = 4,     vC = 0.10019746193973796\n",
      "num_qubits = 4,     vC = 0.04987772783514926\n",
      "num_qubits = 4,     vC = 0.02437298472435718\n",
      "num_qubits = 4,     vC = 0.13735622805875705\n",
      "num_qubits = 4,     vC = 0.007385019376793739\n",
      "num_qubits = 4,     vC = 0.010123780889236296\n",
      "num_qubits = 4,     vC = 0.01163748619969916\n",
      "num_qubits = 4,     vC = 0.33880504674541206\n",
      "num_qubits = 4,     vC = 0.10063707915793589\n",
      "num_qubits = 4,     vC = 0.013926532651448257\n",
      "num_qubits = 4,     vC = 0.08166345809601151\n",
      "num_qubits = 4,     vC = 0.24291919183160027\n",
      "num_qubits = 4,     vC = 0.21502436396818284\n",
      "num_qubits = 4,     vC = 0.6150519659608253\n",
      "num_qubits = 4,     vC = 0.018162372761043245\n",
      "num_qubits = 4,     vC = 0.007249605264532042\n",
      "num_qubits = 4,     vC = 0.28452401054395055\n",
      "num_qubits = 4,     vC = 0.13314118385845053\n",
      "num_qubits = 4,     vC = 0.06112908829969061\n",
      "num_qubits = 4,     vC = 0.10364608950638293\n",
      "num_qubits = 4,     vC = 0.06828477586890969\n",
      "num_qubits = 4,     vC = 0.2612570996448643\n",
      "num_qubits = 4,     vC = 0.001305212357508812\n",
      "num_qubits = 4,     vC = 0.2506725628898849\n",
      "num_qubits = 4,     vC = 0.015036941665971004\n",
      "num_qubits = 4,     vC = 0.00902592585973157\n",
      "num_qubits = 4,     vC = 0.020777666865070925\n",
      "num_qubits = 4,     vC = 0.0042022875430603015\n",
      "num_qubits = 4,     vC = 0.17597970114101497\n",
      "num_qubits = 4,     vC = 0.01813492762841128\n",
      "num_qubits = 4,     vC = 0.0016151459354480178\n",
      "num_qubits = 4,     vC = 0.05814913921934094\n",
      "num_qubits = 4,     vC = 0.45029134818331507\n",
      "num_qubits = 4,     vC = 0.4201787403102286\n",
      "num_qubits = 4,     vC = 0.6848362474324001\n",
      "num_qubits = 4,     vC = 0.21712481217842639\n",
      "num_qubits = 4,     vC = 0.20475569035748184\n",
      "num_qubits = 4,     vC = 0.15962579066193605\n",
      "num_qubits = 4,     vC = 0.26082451362641984\n",
      "num_qubits = 4,     vC = 0.009700391849110044\n",
      "num_qubits = 4,     vC = 0.12557558769381075\n",
      "num_qubits = 4,     vC = 0.0063668098926296865\n",
      "num_qubits = 4,     vC = 0.034198232379675\n",
      "num_qubits = 4,     vC = 0.05124165282036933\n",
      "num_qubits = 4,     vC = 0.03350509163447363\n",
      "num_qubits = 4,     vC = 0.08138063759462678\n",
      "num_qubits = 4,     vC = 0.015449438247026897\n",
      "num_qubits = 4,     vC = 0.09437608632275905\n",
      "num_qubits = 5,     vC = 0.02557608864469421\n",
      "num_qubits = 5,     vC = 0.0020844234703008735\n",
      "num_qubits = 5,     vC = 0.0011002873297542312\n",
      "num_qubits = 5,     vC = 0.06990902478449548\n",
      "num_qubits = 5,     vC = 0.002013888737869663\n",
      "num_qubits = 5,     vC = 0.2283187750793722\n",
      "num_qubits = 5,     vC = 3.338349616401448e-05\n",
      "num_qubits = 5,     vC = 0.02478824504995718\n",
      "num_qubits = 5,     vC = 0.3549449927838392\n",
      "num_qubits = 5,     vC = 0.1022864636712204\n",
      "num_qubits = 5,     vC = 0.04170496097780192\n",
      "num_qubits = 5,     vC = 0.0015493909861552992\n",
      "num_qubits = 5,     vC = 0.028091928294787585\n",
      "num_qubits = 5,     vC = 0.26102673484957656\n",
      "num_qubits = 5,     vC = 0.15224403021043184\n",
      "num_qubits = 5,     vC = 0.0006977451307430217\n",
      "num_qubits = 5,     vC = 0.03236320846535889\n",
      "num_qubits = 5,     vC = 0.3196161027708848\n",
      "num_qubits = 5,     vC = 0.0003372227831883899\n",
      "num_qubits = 5,     vC = 0.0006272831767765606\n",
      "num_qubits = 5,     vC = 0.00014268130046159172\n",
      "num_qubits = 5,     vC = 0.013990723963331255\n",
      "num_qubits = 5,     vC = 0.02254007631503232\n",
      "num_qubits = 5,     vC = 0.0020900410960386635\n",
      "num_qubits = 5,     vC = 0.24546449391702876\n",
      "num_qubits = 5,     vC = 1.3784794762472583e-05\n",
      "num_qubits = 5,     vC = 0.016755815853235285\n",
      "num_qubits = 5,     vC = 0.09721290181150352\n",
      "num_qubits = 5,     vC = 0.011192769410181304\n",
      "num_qubits = 5,     vC = 0.012424120553265961\n",
      "num_qubits = 5,     vC = 0.012759788979571123\n",
      "num_qubits = 5,     vC = 0.15550483833374365\n",
      "num_qubits = 5,     vC = 0.16899000473948722\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.00025910655712116045\n",
      "num_qubits = 5,     vC = 0.05603719414898245\n",
      "num_qubits = 5,     vC = 0.05590459876115139\n",
      "num_qubits = 5,     vC = 0.014658161362410218\n",
      "num_qubits = 5,     vC = 3.7175572598915588e-06\n",
      "num_qubits = 5,     vC = 0.0001902220834755656\n",
      "num_qubits = 5,     vC = 0.003464487599026891\n",
      "num_qubits = 5,     vC = 0.010807299848414595\n",
      "num_qubits = 5,     vC = 0.012502736570469858\n",
      "num_qubits = 5,     vC = 0.015934008637510304\n",
      "num_qubits = 5,     vC = 0.0011042449425358513\n",
      "num_qubits = 5,     vC = 0.0573388044967698\n",
      "num_qubits = 5,     vC = 0.11535290990823738\n",
      "num_qubits = 5,     vC = 0.00019795435902736897\n",
      "num_qubits = 5,     vC = 0.019949492089727225\n",
      "num_qubits = 5,     vC = 0.0019164560585870666\n",
      "num_qubits = 5,     vC = 0.003962979901816051\n",
      "num_qubits = 6,     vC = 0.00028822583215977655\n",
      "num_qubits = 6,     vC = 0.020143224195971733\n",
      "num_qubits = 6,     vC = 0.033973180854020735\n",
      "num_qubits = 6,     vC = 0.010207578437696228\n",
      "num_qubits = 6,     vC = 0.021431766550881786\n",
      "num_qubits = 6,     vC = 0.01671111641554929\n",
      "num_qubits = 6,     vC = 0.07015599840342344\n",
      "num_qubits = 6,     vC = 0.10319886952038441\n",
      "num_qubits = 6,     vC = 0.00269526426308662\n",
      "num_qubits = 6,     vC = 0.00010166964460892783\n",
      "num_qubits = 6,     vC = 0.20296006935725816\n",
      "num_qubits = 6,     vC = 5.561501933731175e-06\n",
      "num_qubits = 6,     vC = 0.007306646550727587\n",
      "num_qubits = 6,     vC = 0.001418337676909236\n",
      "num_qubits = 6,     vC = 0.001711417209509281\n",
      "num_qubits = 6,     vC = 0.0017946758355090887\n",
      "num_qubits = 6,     vC = 0.0017996245389857205\n",
      "num_qubits = 6,     vC = 0.011248634977985261\n",
      "num_qubits = 6,     vC = 0.0006826845468722827\n",
      "num_qubits = 6,     vC = 0.052251355698138595\n",
      "num_qubits = 6,     vC = 0.04719726755470345\n",
      "num_qubits = 6,     vC = 0.0005070188098134781\n",
      "num_qubits = 6,     vC = 0.0012841856124465754\n",
      "num_qubits = 6,     vC = 0.005167869890774506\n",
      "num_qubits = 6,     vC = 0.0426805795512732\n",
      "num_qubits = 6,     vC = 0.0011708706910399573\n",
      "num_qubits = 6,     vC = 0.05859516486517768\n",
      "num_qubits = 6,     vC = 0.0034540310592855003\n",
      "num_qubits = 6,     vC = 0.1199478743728438\n",
      "num_qubits = 6,     vC = 0.0006638718764315166\n",
      "num_qubits = 6,     vC = 2.9593251703285143e-05\n",
      "num_qubits = 6,     vC = 0.008562167741431422\n",
      "num_qubits = 6,     vC = 0.0003170720619419801\n",
      "num_qubits = 6,     vC = 0.0017194306794477013\n",
      "num_qubits = 6,     vC = 0.0031512576135334838\n",
      "num_qubits = 6,     vC = 0.00037004002384480577\n",
      "num_qubits = 6,     vC = 0.060469022606392676\n",
      "num_qubits = 6,     vC = 0.0003433248063313121\n",
      "num_qubits = 6,     vC = 0.03788969075160833\n",
      "num_qubits = 6,     vC = 0.006705594451189952\n",
      "num_qubits = 6,     vC = 0.013670292575160859\n",
      "num_qubits = 6,     vC = 0.038782905822090145\n",
      "num_qubits = 6,     vC = 0.002828546624235137\n",
      "num_qubits = 6,     vC = 0.00038118658327040246\n",
      "num_qubits = 6,     vC = 5.254244168252954e-05\n",
      "num_qubits = 6,     vC = 0.0026891031956186432\n",
      "num_qubits = 6,     vC = 0.00091179390118759\n",
      "num_qubits = 6,     vC = 0.008020118092273106\n",
      "num_qubits = 6,     vC = 0.014330217772461629\n",
      "num_qubits = 6,     vC = 0.009485808908434892\n",
      "num_qubits = 7,     vC = 0.0042825434053789975\n",
      "num_qubits = 7,     vC = 0.0016781020297838606\n",
      "num_qubits = 7,     vC = 0.005285628666301464\n",
      "num_qubits = 7,     vC = 0.003301829680001789\n",
      "num_qubits = 7,     vC = 0.001335399351166579\n",
      "num_qubits = 7,     vC = 0.04204050106858949\n",
      "num_qubits = 7,     vC = 9.271593348579526e-07\n",
      "num_qubits = 7,     vC = 0.0002630880918982739\n",
      "num_qubits = 7,     vC = 8.800238573116056e-05\n",
      "num_qubits = 7,     vC = 0.022194936310079984\n",
      "num_qubits = 7,     vC = 0.079478041693532\n",
      "num_qubits = 7,     vC = 0.036946132108976966\n",
      "num_qubits = 7,     vC = 0.013296616991788572\n",
      "num_qubits = 7,     vC = 0.004479280410461749\n",
      "num_qubits = 7,     vC = 0.0661577337756391\n",
      "num_qubits = 7,     vC = 0.005711682562979859\n",
      "num_qubits = 7,     vC = 0.00577943553913171\n",
      "num_qubits = 7,     vC = 0.004611857533892042\n",
      "num_qubits = 7,     vC = 0.0012552239880431223\n",
      "num_qubits = 7,     vC = 1.386777374797909e-07\n",
      "num_qubits = 7,     vC = 0.0064917198289355695\n",
      "num_qubits = 7,     vC = 0.00011730828071167467\n",
      "num_qubits = 7,     vC = 1.7472891738801024e-05\n",
      "num_qubits = 7,     vC = 0.018322162228473597\n",
      "num_qubits = 7,     vC = 0.006429023853595006\n",
      "num_qubits = 7,     vC = 0.039476959750807714\n",
      "num_qubits = 7,     vC = 0.0036811762603431043\n",
      "num_qubits = 7,     vC = 0.0018876050948818878\n",
      "num_qubits = 7,     vC = 0.009457221649592161\n",
      "num_qubits = 7,     vC = 0.029189054752847214\n",
      "num_qubits = 7,     vC = 0.0019650380301609216\n",
      "num_qubits = 7,     vC = 0.024198637454196287\n",
      "num_qubits = 7,     vC = 0.0007973718369030262\n",
      "num_qubits = 7,     vC = 0.01824710257027113\n",
      "num_qubits = 7,     vC = 0.006204222785960741\n",
      "num_qubits = 7,     vC = 0.003544854566420426\n",
      "num_qubits = 7,     vC = 0.02256029317021949\n",
      "num_qubits = 7,     vC = 0.0004405980705623585\n",
      "num_qubits = 7,     vC = 6.894300501191874e-05\n",
      "num_qubits = 7,     vC = 0.02688380205872225\n",
      "num_qubits = 7,     vC = 0.018551788970448867\n",
      "num_qubits = 7,     vC = 0.005160780139116939\n",
      "num_qubits = 7,     vC = 0.0001044314567183966\n",
      "num_qubits = 7,     vC = 0.1349423911071333\n",
      "num_qubits = 7,     vC = 0.001337040733142247\n",
      "num_qubits = 7,     vC = 0.0007106291861963152\n",
      "num_qubits = 7,     vC = 0.0011941342031276773\n",
      "num_qubits = 7,     vC = 0.05330368255360824\n",
      "num_qubits = 7,     vC = 0.0001843504624452162\n",
      "num_qubits = 7,     vC = 0.0041787800409952645\n",
      "num_qubits = 8,     vC = 0.010578628497290892\n",
      "num_qubits = 8,     vC = 0.0002686716490393279\n",
      "num_qubits = 8,     vC = 0.0001556287681012\n",
      "num_qubits = 8,     vC = 0.0007704568603451109\n",
      "num_qubits = 8,     vC = 5.285938838630179e-06\n",
      "num_qubits = 8,     vC = 4.466746885130424e-05\n",
      "num_qubits = 8,     vC = 0.12704006339876509\n",
      "num_qubits = 8,     vC = 0.023014425975691713\n",
      "num_qubits = 8,     vC = 5.859418064080354e-05\n",
      "num_qubits = 8,     vC = 0.0013602756852711144\n",
      "num_qubits = 8,     vC = 0.002089985274602975\n",
      "num_qubits = 8,     vC = 0.020416121764404115\n",
      "num_qubits = 8,     vC = 0.024021370433562516\n",
      "num_qubits = 8,     vC = 5.416134774893218e-05\n",
      "num_qubits = 8,     vC = 0.00023485884545563853\n",
      "num_qubits = 8,     vC = 0.00018214814601079038\n",
      "num_qubits = 8,     vC = 0.17543565802574423\n",
      "num_qubits = 8,     vC = 0.008551373459390586\n",
      "num_qubits = 8,     vC = 0.0027870754325681523\n",
      "num_qubits = 8,     vC = 0.0005563244189567527\n",
      "num_qubits = 8,     vC = 0.0218070042680324\n",
      "num_qubits = 8,     vC = 0.003163521479078674\n",
      "num_qubits = 8,     vC = 0.0006851413813516575\n",
      "num_qubits = 8,     vC = 0.017629041724229515\n",
      "num_qubits = 8,     vC = 0.01020109762413119\n",
      "num_qubits = 8,     vC = 2.749366174148123e-05\n",
      "num_qubits = 8,     vC = 0.0011314002131491776\n",
      "num_qubits = 8,     vC = 2.7704877244782953e-06\n",
      "num_qubits = 8,     vC = 0.003694123511594144\n",
      "num_qubits = 8,     vC = 3.935730218676774e-05\n",
      "num_qubits = 8,     vC = 0.0017231174601105503\n",
      "num_qubits = 8,     vC = 0.00010156619733179215\n",
      "num_qubits = 8,     vC = 0.0003131989458841067\n",
      "num_qubits = 8,     vC = 0.04029559770900344\n",
      "num_qubits = 8,     vC = 0.03563226047522111\n",
      "num_qubits = 8,     vC = 0.004600993745299252\n",
      "num_qubits = 8,     vC = 0.024781514100256228\n",
      "num_qubits = 8,     vC = 0.0007897263571501914\n",
      "num_qubits = 8,     vC = 0.0005954342490365016\n",
      "num_qubits = 8,     vC = 0.00030668011840973296\n",
      "num_qubits = 8,     vC = 0.023601882993934932\n",
      "num_qubits = 8,     vC = 0.00033051543174261337\n",
      "num_qubits = 8,     vC = 0.0006654588974459142\n",
      "num_qubits = 8,     vC = 0.00012463561937783976\n",
      "num_qubits = 8,     vC = 0.01564986947593253\n",
      "num_qubits = 8,     vC = 0.09266214968662767\n",
      "num_qubits = 8,     vC = 0.0016501277991050262\n",
      "num_qubits = 8,     vC = 0.0004078440898365653\n",
      "num_qubits = 8,     vC = 0.0008588796411866905\n",
      "num_qubits = 8,     vC = 0.00038562032394509106\n",
      "num_qubits = 9,     vC = 0.000825459687663188\n",
      "num_qubits = 9,     vC = 0.0008158667676414795\n",
      "num_qubits = 9,     vC = 0.0004083429353916677\n",
      "num_qubits = 9,     vC = 3.410736728138964e-05\n",
      "num_qubits = 9,     vC = 3.90860605396231e-05\n",
      "num_qubits = 9,     vC = 0.0022456809963343895\n",
      "num_qubits = 9,     vC = 4.458743762069024e-05\n",
      "num_qubits = 9,     vC = 0.000978181613332707\n",
      "num_qubits = 9,     vC = 0.0012666418402328327\n",
      "num_qubits = 9,     vC = 7.471750126448802e-06\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 0.0012817581194708772\n",
      "num_qubits = 9,     vC = 0.00042204027095262426\n",
      "num_qubits = 9,     vC = 0.00023594429000838293\n",
      "num_qubits = 9,     vC = 0.0017061163214880045\n",
      "num_qubits = 9,     vC = 0.00025020825747599536\n",
      "num_qubits = 9,     vC = 0.0017978102352186397\n",
      "num_qubits = 9,     vC = 0.004290235192188546\n",
      "num_qubits = 9,     vC = 0.00010624225133331866\n",
      "num_qubits = 9,     vC = 4.119281066442398e-05\n",
      "num_qubits = 9,     vC = 0.030330171251576398\n",
      "num_qubits = 9,     vC = 0.0027284845708152442\n",
      "num_qubits = 9,     vC = 0.008953953387648542\n",
      "num_qubits = 9,     vC = 5.362446963317317e-05\n",
      "num_qubits = 9,     vC = 0.0023155398926137626\n",
      "num_qubits = 9,     vC = 7.881792346461767e-05\n",
      "num_qubits = 9,     vC = 0.01892274819825657\n",
      "num_qubits = 9,     vC = 0.003979639417643513\n",
      "num_qubits = 9,     vC = 0.0006616704982155609\n",
      "num_qubits = 9,     vC = 0.0001608984755391536\n",
      "num_qubits = 9,     vC = 0.0005612563996960957\n",
      "num_qubits = 9,     vC = 0.0014937032404930722\n",
      "num_qubits = 9,     vC = 0.00011575494121898576\n",
      "num_qubits = 9,     vC = 0.0014881555479862153\n",
      "num_qubits = 9,     vC = 0.027064641297001254\n",
      "num_qubits = 9,     vC = 0.00657046590643297\n",
      "num_qubits = 9,     vC = 1.1052168670725774e-07\n",
      "num_qubits = 9,     vC = 7.685852416837152e-05\n",
      "num_qubits = 9,     vC = 9.70280468206942e-06\n",
      "num_qubits = 9,     vC = 3.072200477241653e-05\n",
      "num_qubits = 9,     vC = 0.0012342667140825103\n",
      "num_qubits = 9,     vC = 5.423635907483877e-08\n",
      "num_qubits = 9,     vC = 0.0016372307097212082\n",
      "num_qubits = 9,     vC = 0.019150779777251072\n",
      "num_qubits = 9,     vC = 2.2190234102944454e-05\n",
      "num_qubits = 9,     vC = 6.570849062506788e-05\n",
      "num_qubits = 9,     vC = 0.0027614289416406754\n",
      "num_qubits = 9,     vC = 4.534717636450526e-05\n",
      "num_qubits = 9,     vC = 7.193475964614569e-05\n",
      "num_qubits = 9,     vC = 1.3818356647368272e-06\n",
      "num_qubits = 9,     vC = 0.00017510494075715814\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",
    "    for _ in range(500):\n",
    "\n",
    "        V = uni_2_design(N, 1)\n",
    "        rand_H = paddle.to_tensor(V @ H @ V.conjugate().T)\n",
    "        \n",
    "        Delta_C = train_loss(N, Herm=rand_H)\n",
    "\n",
    "        temp.append(Delta_C)\n",
    "        if _ % 10 == 0:\n",
    "            print(f'num_qubits = {N},     vC = {Delta_C}')\n",
    "\n",
    "    WriteJson(temp,  'sample_vC_QSL_ahead_Adam_'+str(N)+'qubit')\n",
    "\n",
    "    loss_change.append(np.average(temp))\n",
    "    \n",
    "WriteJson(loss_change, \"QSL_ahead_Adam_1design\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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nf+ZMaaxMWby5XdNuKFo0aIsXLiQyZMnM2DAAOrVq0dsbKzbsURERMRH+FVJs9YutdZ2yZkzp9tR/lanTh327dtH48aNufPOO+nduze//fab27FERETE4/yqpHlVhgwZ6NmzJ7GxsZw6dYrg4GCmTJly1QnIIiIi6cE333xDrVq1CA0NJSwsjLFjx/7j+7NnzyZjxowMGTLkitfu3buXjh07XvV9v/zySypWrEjx4sV54IEHOHv27BU/c/jwYbJkyUJERAQRERF07do12fkHDBhA4cKFr5jFN378eKZNm5bs97salbQ0lC9fPt58802WL1/O9OnTqVixIlu3bnU7loiISJoLCgpi1KhRxMbGsn37dt54442/Lwv6+OOPGTlyJLGxsaxZs4Z33nnnH68dNmwYPXv2vOr7Pv300/Tu3ZtDhw6RO3dupk6detWfK1asGPv27WPfvn1MmjQp2fkbN27Mzp07r3i+Q4cOjBs3LtnvdzUqaS4oW7Ysmzdvpnfv3rRs2ZK2bdvy3XffuR1LREQkzRQsWJCyZcsCzt6bISEhHDlyhAMHDjBw4EBWrlxJ8eLFWb58ObNnz2blypWAM2B2//79lC5d+or3tNby8ccf06JFCwAefvhhFi1alKxc2bNnZ8CAAZQuXZratWvz448/XvXnKlWqRMGCBa94PmvWrBQpUuSqBS65VNJcYozhwQcfJD4+nsKFC1OqVClefvllzpw543Y0ERFJZ4wxKf5IjsOHD7N3714qVqxIeHg4W7duJX/+/IAzNWHlypXUr18fgN27d1OyZMmrvs+xY8fIlSsXQUHOhkqFChXiyJGrz8X/8ssvKVOmDHfeeec/NlX/448/qFSpEtHR0VStWpW33norWb8LQLly5VJko3aVNJdlz56dYcOGsX37drZu3UrJkiVZtmyZRnaIiEiasdam+COpTp48SfPmzXnttdeStA/2999/T758+f7Lr0vBggX5+uuv2bt3L6NHj6ZNmzb8/vvvAGTMmJFGjRoBEBERweHDh5P9/jfddFOKrJD5VUnz0giO5CpevDiLFy9m3Lhx9O3bl4YNG/LJJ5+4HUtERCTVnDt3jubNm/Pggw/SrFmzJL0mS5Ys/xgUX79+fSIiIujUqRN58+blt99+4/z58wB8++23/O9//7viPTJlykTevHkBiIyMpFixYnz66aeAc7Pf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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
}
