{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import paddle\n",
    "from paddle_quantum.utils import Hamiltonian\n",
    "from paddle_quantum.circuit import UAnsatz\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def uni_2_design(N,D):\n",
    "#     theta = layers.create_parameter(shape=[D, N], default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2 * np.pi),\n",
    "#             dtype='float64',is_bias=False)\n",
    "    theta = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N,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.1261312164784138\n",
      "num_qubits = 2,     vC = 0.8686985539648444\n",
      "num_qubits = 2,     vC = 0.184973145153148\n",
      "num_qubits = 2,     vC = 0.3144531971856894\n",
      "num_qubits = 2,     vC = 0.5851453985689181\n",
      "num_qubits = 2,     vC = 0.7049484285758001\n",
      "num_qubits = 2,     vC = 0.9029437362226335\n",
      "num_qubits = 2,     vC = 0.7278649053433126\n",
      "num_qubits = 2,     vC = 0.45570437933734104\n",
      "num_qubits = 2,     vC = 0.8496520397306954\n",
      "num_qubits = 2,     vC = 0.3987712203063717\n",
      "num_qubits = 2,     vC = 0.779663924923976\n",
      "num_qubits = 2,     vC = 0.879916532289518\n",
      "num_qubits = 2,     vC = 0.5877556683112479\n",
      "num_qubits = 2,     vC = 0.0004942229635303512\n",
      "num_qubits = 2,     vC = 0.6548593917006462\n",
      "num_qubits = 2,     vC = 0.6709776601265819\n",
      "num_qubits = 2,     vC = 0.16726958915757043\n",
      "num_qubits = 2,     vC = 0.5098747016171187\n",
      "num_qubits = 2,     vC = 0.9562049736198381\n",
      "num_qubits = 2,     vC = 0.7984421346128493\n",
      "num_qubits = 2,     vC = 0.616740203799628\n",
      "num_qubits = 2,     vC = 0.7832287973529221\n",
      "num_qubits = 2,     vC = 0.36350926917243465\n",
      "num_qubits = 2,     vC = 0.5082119134918708\n",
      "num_qubits = 2,     vC = 0.9546653695002385\n",
      "num_qubits = 2,     vC = 0.4750419716895577\n",
      "num_qubits = 2,     vC = 0.03374680587205575\n",
      "num_qubits = 2,     vC = 0.6032297117073259\n",
      "num_qubits = 2,     vC = 0.3961162284625446\n",
      "num_qubits = 2,     vC = 0.09005989602480902\n",
      "num_qubits = 2,     vC = 0.2320612687146227\n",
      "num_qubits = 2,     vC = 0.1728135530697614\n",
      "num_qubits = 2,     vC = 0.7958779015999329\n",
      "num_qubits = 2,     vC = 0.8362551542436832\n",
      "num_qubits = 2,     vC = 0.7465390367375497\n",
      "num_qubits = 2,     vC = 0.9292973689541487\n",
      "num_qubits = 2,     vC = 0.15523064512239526\n",
      "num_qubits = 2,     vC = 0.4369975412020694\n",
      "num_qubits = 2,     vC = 0.7333536597262077\n",
      "num_qubits = 2,     vC = 0.9346371560127037\n",
      "num_qubits = 2,     vC = 0.2086360115301935\n",
      "num_qubits = 2,     vC = 0.1524124217491985\n",
      "num_qubits = 2,     vC = 0.859529813633024\n",
      "num_qubits = 2,     vC = 0.0299884379431004\n",
      "num_qubits = 2,     vC = 0.3268058402329783\n",
      "num_qubits = 2,     vC = 0.258734056797039\n",
      "num_qubits = 2,     vC = 0.9924497155401022\n",
      "num_qubits = 2,     vC = 0.0818845548233426\n",
      "num_qubits = 2,     vC = 0.2964200711384099\n",
      "num_qubits = 3,     vC = 0.051719745263638595\n",
      "num_qubits = 3,     vC = 0.255915438156296\n",
      "num_qubits = 3,     vC = 0.17825513210394148\n",
      "num_qubits = 3,     vC = 0.1812720687513093\n",
      "num_qubits = 3,     vC = 0.02672192931322879\n",
      "num_qubits = 3,     vC = 0.5072715829983172\n",
      "num_qubits = 3,     vC = 0.8693714791072448\n",
      "num_qubits = 3,     vC = 0.12220652228264028\n",
      "num_qubits = 3,     vC = 0.2230798556730852\n",
      "num_qubits = 3,     vC = 0.1949089662561235\n",
      "num_qubits = 3,     vC = 0.05814851937204166\n",
      "num_qubits = 3,     vC = 0.08376661863512445\n",
      "num_qubits = 3,     vC = 0.2172622934467212\n",
      "num_qubits = 3,     vC = 0.3463752571268682\n",
      "num_qubits = 3,     vC = 0.34683445309714256\n",
      "num_qubits = 3,     vC = 0.010865985231621023\n",
      "num_qubits = 3,     vC = 0.018250359842631014\n",
      "num_qubits = 3,     vC = 0.009450835582640978\n",
      "num_qubits = 3,     vC = 0.33613943323794365\n",
      "num_qubits = 3,     vC = 0.6095002738934776\n",
      "num_qubits = 3,     vC = 0.18800208636568327\n",
      "num_qubits = 3,     vC = 0.17285640353059625\n",
      "num_qubits = 3,     vC = 0.017334799804021146\n",
      "num_qubits = 3,     vC = 0.217960874340819\n",
      "num_qubits = 3,     vC = 0.3013665687155221\n",
      "num_qubits = 3,     vC = 0.09203719005302007\n",
      "num_qubits = 3,     vC = 0.8208006085964948\n",
      "num_qubits = 3,     vC = 0.7859898233686153\n",
      "num_qubits = 3,     vC = 0.030300645023099683\n",
      "num_qubits = 3,     vC = 0.029132509432524836\n",
      "num_qubits = 3,     vC = 0.1801162672548154\n",
      "num_qubits = 3,     vC = 0.07459097622077517\n",
      "num_qubits = 3,     vC = 0.20808495251453216\n",
      "num_qubits = 3,     vC = 0.007190911723894259\n",
      "num_qubits = 3,     vC = 0.5640951619384817\n",
      "num_qubits = 3,     vC = 0.12039694694092062\n",
      "num_qubits = 3,     vC = 0.7115682266863692\n",
      "num_qubits = 3,     vC = 0.13050775107355617\n",
      "num_qubits = 3,     vC = 0.06246709565726297\n",
      "num_qubits = 3,     vC = 0.5890795026808708\n",
      "num_qubits = 3,     vC = 0.692135355734491\n",
      "num_qubits = 3,     vC = 0.035004915732982346\n",
      "num_qubits = 3,     vC = 0.7376949764511083\n",
      "num_qubits = 3,     vC = 0.3921623912471187\n",
      "num_qubits = 3,     vC = 0.13483479800888865\n",
      "num_qubits = 3,     vC = 0.32211166167304706\n",
      "num_qubits = 3,     vC = 0.10512736058715087\n",
      "num_qubits = 3,     vC = 0.4210027918273058\n",
      "num_qubits = 3,     vC = 0.7631673628270218\n",
      "num_qubits = 3,     vC = 0.5557666536614809\n",
      "num_qubits = 4,     vC = 0.1504221619937212\n",
      "num_qubits = 4,     vC = 0.8396382228527287\n",
      "num_qubits = 4,     vC = 0.043515828738333394\n",
      "num_qubits = 4,     vC = 0.005065543266096916\n",
      "num_qubits = 4,     vC = 0.11596401839268791\n",
      "num_qubits = 4,     vC = 0.13935164672065078\n",
      "num_qubits = 4,     vC = 0.0721553547729726\n",
      "num_qubits = 4,     vC = 0.49158853247152423\n",
      "num_qubits = 4,     vC = 0.08357014042154667\n",
      "num_qubits = 4,     vC = 0.04604347109616926\n",
      "num_qubits = 4,     vC = 0.20616842355291606\n",
      "num_qubits = 4,     vC = 0.02844386581482781\n",
      "num_qubits = 4,     vC = 0.028480615851665465\n",
      "num_qubits = 4,     vC = 0.39629881574094367\n",
      "num_qubits = 4,     vC = 0.021183509874497554\n",
      "num_qubits = 4,     vC = 0.007337688860204145\n",
      "num_qubits = 4,     vC = 0.00864653637323672\n",
      "num_qubits = 4,     vC = 0.028617648628882286\n",
      "num_qubits = 4,     vC = 0.01985522049063863\n",
      "num_qubits = 4,     vC = 0.45684350630949494\n",
      "num_qubits = 4,     vC = 0.5738277126545286\n",
      "num_qubits = 4,     vC = 0.025521010473069053\n",
      "num_qubits = 4,     vC = 0.00919067101357627\n",
      "num_qubits = 4,     vC = 0.01332949918522672\n",
      "num_qubits = 4,     vC = 0.036340543360403925\n",
      "num_qubits = 4,     vC = 0.53990514436915\n",
      "num_qubits = 4,     vC = 0.023082636905954818\n",
      "num_qubits = 4,     vC = 0.16174404411709037\n",
      "num_qubits = 4,     vC = 0.05591517939711832\n",
      "num_qubits = 4,     vC = 0.012771384580911002\n",
      "num_qubits = 4,     vC = 0.007672929137754721\n",
      "num_qubits = 4,     vC = 0.5569432406842482\n",
      "num_qubits = 4,     vC = 0.44657498851135263\n",
      "num_qubits = 4,     vC = 0.024028283198914552\n",
      "num_qubits = 4,     vC = 0.019206742208273328\n",
      "num_qubits = 4,     vC = 0.15252074756339815\n",
      "num_qubits = 4,     vC = 0.3530672965898317\n",
      "num_qubits = 4,     vC = 0.007542001636510858\n",
      "num_qubits = 4,     vC = 0.062467229885384695\n",
      "num_qubits = 4,     vC = 0.22222575076012682\n",
      "num_qubits = 4,     vC = 0.005595372995774504\n",
      "num_qubits = 4,     vC = 0.3712288726971176\n",
      "num_qubits = 4,     vC = 0.3185801664387707\n",
      "num_qubits = 4,     vC = 0.05341082042804731\n",
      "num_qubits = 4,     vC = 0.09127777609232918\n",
      "num_qubits = 4,     vC = 0.2417111070929656\n",
      "num_qubits = 4,     vC = 0.0011971286303796755\n",
      "num_qubits = 4,     vC = 0.3170527719806954\n",
      "num_qubits = 4,     vC = 0.18558691124375215\n",
      "num_qubits = 4,     vC = 0.012876140859238274\n",
      "num_qubits = 5,     vC = 0.0074096626714521465\n",
      "num_qubits = 5,     vC = 0.03507286524733107\n",
      "num_qubits = 5,     vC = 0.016362591891040328\n",
      "num_qubits = 5,     vC = 0.009789758759935452\n",
      "num_qubits = 5,     vC = 0.48262450060518\n",
      "num_qubits = 5,     vC = 0.019664881997755533\n",
      "num_qubits = 5,     vC = 0.0024078302762014234\n",
      "num_qubits = 5,     vC = 0.008171107180858223\n",
      "num_qubits = 5,     vC = 0.013868222504556056\n",
      "num_qubits = 5,     vC = 0.5375909797711107\n",
      "num_qubits = 5,     vC = 0.0001357559131810283\n",
      "num_qubits = 5,     vC = 0.13975945662775285\n",
      "num_qubits = 5,     vC = 0.10294282695357813\n",
      "num_qubits = 5,     vC = 0.004176748928660241\n",
      "num_qubits = 5,     vC = 0.003523442843400231\n",
      "num_qubits = 5,     vC = 0.0015287659325313248\n",
      "num_qubits = 5,     vC = 0.004109205051225865\n",
      "num_qubits = 5,     vC = 0.012433762426595392\n",
      "num_qubits = 5,     vC = 0.011695934142303232\n",
      "num_qubits = 5,     vC = 0.0033255031253587642\n",
      "num_qubits = 5,     vC = 0.018118074015587793\n",
      "num_qubits = 5,     vC = 0.07865868000490038\n",
      "num_qubits = 5,     vC = 0.0009297762208903384\n",
      "num_qubits = 5,     vC = 0.0064274280119851505\n",
      "num_qubits = 5,     vC = 0.0003623550079094291\n",
      "num_qubits = 5,     vC = 0.004547131649080855\n",
      "num_qubits = 5,     vC = 0.06000761715893839\n",
      "num_qubits = 5,     vC = 0.06925621447002886\n",
      "num_qubits = 5,     vC = 0.09563184372498114\n",
      "num_qubits = 5,     vC = 0.01559802806211374\n",
      "num_qubits = 5,     vC = 0.07511127527925486\n",
      "num_qubits = 5,     vC = 0.005554324732553729\n",
      "num_qubits = 5,     vC = 0.004636139461522837\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 5,     vC = 0.17831239374594182\n",
      "num_qubits = 5,     vC = 0.029639664625955298\n",
      "num_qubits = 5,     vC = 0.0080534106137516\n",
      "num_qubits = 5,     vC = 0.27594188529132196\n",
      "num_qubits = 5,     vC = 0.14223165165995819\n",
      "num_qubits = 5,     vC = 0.002621332522020577\n",
      "num_qubits = 5,     vC = 0.0031037297767079366\n",
      "num_qubits = 5,     vC = 0.09145274507458023\n",
      "num_qubits = 5,     vC = 0.08775852109151126\n",
      "num_qubits = 5,     vC = 0.002450189505959295\n",
      "num_qubits = 5,     vC = 0.033448436882954576\n",
      "num_qubits = 5,     vC = 0.0025758853632935493\n",
      "num_qubits = 5,     vC = 0.037751295226543656\n",
      "num_qubits = 5,     vC = 0.5258022691525553\n",
      "num_qubits = 5,     vC = 0.011686838562593104\n",
      "num_qubits = 5,     vC = 0.23040031460440477\n",
      "num_qubits = 5,     vC = 0.0006954700957330829\n",
      "num_qubits = 6,     vC = 0.0004243564752643987\n",
      "num_qubits = 6,     vC = 0.048364642499345536\n",
      "num_qubits = 6,     vC = 0.02088264540399772\n",
      "num_qubits = 6,     vC = 0.16884579537936847\n",
      "num_qubits = 6,     vC = 0.056653848099584715\n",
      "num_qubits = 6,     vC = 2.636845224875111e-05\n",
      "num_qubits = 6,     vC = 0.0013691198146117657\n",
      "num_qubits = 6,     vC = 0.0007187362991945584\n",
      "num_qubits = 6,     vC = 0.006737433736419553\n",
      "num_qubits = 6,     vC = 0.014538750435031474\n",
      "num_qubits = 6,     vC = 0.0757396546631282\n",
      "num_qubits = 6,     vC = 0.008607909872417191\n",
      "num_qubits = 6,     vC = 0.00231075498030655\n",
      "num_qubits = 6,     vC = 0.010302900342880237\n",
      "num_qubits = 6,     vC = 0.06717083944913958\n",
      "num_qubits = 6,     vC = 0.0182815201440266\n",
      "num_qubits = 6,     vC = 0.00144525809295905\n",
      "num_qubits = 6,     vC = 0.0006252889006614886\n",
      "num_qubits = 6,     vC = 5.0568649441498546e-05\n",
      "num_qubits = 6,     vC = 0.007538551906329679\n",
      "num_qubits = 6,     vC = 0.002364319153734014\n",
      "num_qubits = 6,     vC = 0.0001567035202531891\n",
      "num_qubits = 6,     vC = 0.0027206398175776535\n",
      "num_qubits = 6,     vC = 0.00039278689520936546\n",
      "num_qubits = 6,     vC = 1.645431274695566e-05\n",
      "num_qubits = 6,     vC = 0.042226548633671965\n",
      "num_qubits = 6,     vC = 0.1574593946319833\n",
      "num_qubits = 6,     vC = 0.0008345481329546354\n",
      "num_qubits = 6,     vC = 0.00044253794379691725\n",
      "num_qubits = 6,     vC = 0.00014216641438348797\n",
      "num_qubits = 6,     vC = 0.2353624536908379\n",
      "num_qubits = 6,     vC = 0.002834436695485774\n",
      "num_qubits = 6,     vC = 5.887422543259242e-05\n",
      "num_qubits = 6,     vC = 0.0050789269131851274\n",
      "num_qubits = 6,     vC = 0.003818116792248019\n",
      "num_qubits = 6,     vC = 0.0007502058219544846\n",
      "num_qubits = 6,     vC = 0.0025696586003600692\n",
      "num_qubits = 6,     vC = 0.0026377099800514664\n",
      "num_qubits = 6,     vC = 0.002927174710371539\n",
      "num_qubits = 6,     vC = 0.04686640239587776\n",
      "num_qubits = 6,     vC = 0.019738583531679017\n",
      "num_qubits = 6,     vC = 0.0027680826785036745\n",
      "num_qubits = 6,     vC = 0.014538425735783567\n",
      "num_qubits = 6,     vC = 0.009571535699802276\n",
      "num_qubits = 6,     vC = 0.003717952609328365\n",
      "num_qubits = 6,     vC = 0.004073901679500199\n",
      "num_qubits = 6,     vC = 0.0008833310437954753\n",
      "num_qubits = 6,     vC = 0.0033011342811209367\n",
      "num_qubits = 6,     vC = 7.083379428800436e-05\n",
      "num_qubits = 6,     vC = 0.0027676341009455294\n",
      "num_qubits = 7,     vC = 0.001801347230572235\n",
      "num_qubits = 7,     vC = 0.0007494393918737598\n",
      "num_qubits = 7,     vC = 0.003946708231191994\n",
      "num_qubits = 7,     vC = 4.9513426028765034e-06\n",
      "num_qubits = 7,     vC = 0.0026852304378478056\n",
      "num_qubits = 7,     vC = 0.0001364001076125395\n",
      "num_qubits = 7,     vC = 0.056521117208243564\n",
      "num_qubits = 7,     vC = 0.01235815445907276\n",
      "num_qubits = 7,     vC = 0.05225379310800524\n",
      "num_qubits = 7,     vC = 0.012950903540721691\n",
      "num_qubits = 7,     vC = 0.01216254125028667\n",
      "num_qubits = 7,     vC = 0.0035952873442193656\n",
      "num_qubits = 7,     vC = 0.006759547200129273\n",
      "num_qubits = 7,     vC = 0.00034774802499107436\n",
      "num_qubits = 7,     vC = 0.011958161699032598\n",
      "num_qubits = 7,     vC = 0.00036735913762256335\n",
      "num_qubits = 7,     vC = 0.0007572350960627174\n",
      "num_qubits = 7,     vC = 0.0065881879159952585\n",
      "num_qubits = 7,     vC = 2.1952487760378927e-05\n",
      "num_qubits = 7,     vC = 0.0003761363778992561\n",
      "num_qubits = 7,     vC = 0.01745718020308231\n",
      "num_qubits = 7,     vC = 0.018662647118895506\n",
      "num_qubits = 7,     vC = 5.896627468963651e-05\n",
      "num_qubits = 7,     vC = 0.00014412861077572062\n",
      "num_qubits = 7,     vC = 0.0006947201985143399\n",
      "num_qubits = 7,     vC = 0.042769252603071135\n",
      "num_qubits = 7,     vC = 0.0009712209922943341\n",
      "num_qubits = 7,     vC = 0.0010208680660960805\n",
      "num_qubits = 7,     vC = 0.0023800016050937317\n",
      "num_qubits = 7,     vC = 0.021600992973228157\n",
      "num_qubits = 7,     vC = 0.12715025306587233\n",
      "num_qubits = 7,     vC = 0.0026993678892921137\n",
      "num_qubits = 7,     vC = 0.0002445009234457314\n",
      "num_qubits = 7,     vC = 0.0072449506700740995\n",
      "num_qubits = 7,     vC = 0.005902558749291369\n",
      "num_qubits = 7,     vC = 0.017598349801517806\n",
      "num_qubits = 7,     vC = 0.0023620508435909823\n",
      "num_qubits = 7,     vC = 0.07178897509138658\n",
      "num_qubits = 7,     vC = 0.0006752392522932131\n",
      "num_qubits = 7,     vC = 1.09018556427409e-06\n",
      "num_qubits = 7,     vC = 0.00034869597910931163\n",
      "num_qubits = 7,     vC = 5.82971663029302e-05\n",
      "num_qubits = 7,     vC = 0.0003642955561457707\n",
      "num_qubits = 7,     vC = 0.024058106853123803\n",
      "num_qubits = 7,     vC = 0.004086019352686623\n",
      "num_qubits = 7,     vC = 0.004471882432612254\n",
      "num_qubits = 7,     vC = 0.0007089070734057439\n",
      "num_qubits = 7,     vC = 0.025595502074645754\n",
      "num_qubits = 7,     vC = 0.006458997987298065\n",
      "num_qubits = 7,     vC = 0.08857025183547199\n",
      "num_qubits = 8,     vC = 0.00013705041711179971\n",
      "num_qubits = 8,     vC = 0.0068443394476755065\n",
      "num_qubits = 8,     vC = 0.04573215837353049\n",
      "num_qubits = 8,     vC = 0.09180699522942544\n",
      "num_qubits = 8,     vC = 0.001674475887033773\n",
      "num_qubits = 8,     vC = 0.0002025189346566624\n",
      "num_qubits = 8,     vC = 0.0010966504224249809\n",
      "num_qubits = 8,     vC = 1.3350722129815064e-05\n",
      "num_qubits = 8,     vC = 0.1406380633155467\n",
      "num_qubits = 8,     vC = 0.0022297250307519007\n",
      "num_qubits = 8,     vC = 0.001151423107227479\n",
      "num_qubits = 8,     vC = 0.004419698578061781\n",
      "num_qubits = 8,     vC = 0.08275191254994538\n",
      "num_qubits = 8,     vC = 0.027741811414779945\n",
      "num_qubits = 8,     vC = 0.0001581169961785982\n",
      "num_qubits = 8,     vC = 0.0002244569198029649\n",
      "num_qubits = 8,     vC = 0.0006357084383241422\n",
      "num_qubits = 8,     vC = 0.0009349393697812882\n",
      "num_qubits = 8,     vC = 0.00037742411314559246\n",
      "num_qubits = 8,     vC = 0.0020875473790725797\n",
      "num_qubits = 8,     vC = 0.0008177581903732115\n",
      "num_qubits = 8,     vC = 0.0001523796254643354\n",
      "num_qubits = 8,     vC = 0.00012970275509589557\n",
      "num_qubits = 8,     vC = 3.2098899523364092e-06\n",
      "num_qubits = 8,     vC = 0.00031460208317581664\n",
      "num_qubits = 8,     vC = 0.011044722634377831\n",
      "num_qubits = 8,     vC = 0.00010518265226723378\n",
      "num_qubits = 8,     vC = 4.938230449717945e-05\n",
      "num_qubits = 8,     vC = 2.662944086015102e-05\n",
      "num_qubits = 8,     vC = 1.1718321713349644e-05\n",
      "num_qubits = 8,     vC = 0.016222108730034084\n",
      "num_qubits = 8,     vC = 0.0025306965654604344\n",
      "num_qubits = 8,     vC = 0.0011214365198360854\n",
      "num_qubits = 8,     vC = 8.79688186885646e-05\n",
      "num_qubits = 8,     vC = 0.0038548967042368637\n",
      "num_qubits = 8,     vC = 0.00012245929746729914\n",
      "num_qubits = 8,     vC = 0.00022976386225054314\n",
      "num_qubits = 8,     vC = 0.011960458349890735\n",
      "num_qubits = 8,     vC = 0.06828855196690088\n",
      "num_qubits = 8,     vC = 0.023235500267177585\n",
      "num_qubits = 8,     vC = 0.00539196922492543\n",
      "num_qubits = 8,     vC = 0.004007018773598355\n",
      "num_qubits = 8,     vC = 5.0920149218875964e-06\n",
      "num_qubits = 8,     vC = 0.0005323806816623887\n",
      "num_qubits = 8,     vC = 9.531087113558424e-05\n",
      "num_qubits = 8,     vC = 0.04217311311943489\n",
      "num_qubits = 8,     vC = 0.00022657936894099134\n",
      "num_qubits = 8,     vC = 0.005160021376702055\n",
      "num_qubits = 8,     vC = 0.0011609759220075468\n",
      "num_qubits = 8,     vC = 5.907104363574918e-06\n",
      "num_qubits = 9,     vC = 1.3575499835191543e-05\n",
      "num_qubits = 9,     vC = 0.003628554588734821\n",
      "num_qubits = 9,     vC = 0.00016523780579846362\n",
      "num_qubits = 9,     vC = 0.0033244535769957127\n",
      "num_qubits = 9,     vC = 4.049402163975087e-05\n",
      "num_qubits = 9,     vC = 2.2073817850913637e-05\n",
      "num_qubits = 9,     vC = 6.860355198591648e-05\n",
      "num_qubits = 9,     vC = 0.0019493951202112138\n",
      "num_qubits = 9,     vC = 0.0016729773121191376\n",
      "num_qubits = 9,     vC = 0.006154035914342451\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 9,     vC = 2.194032091971272e-05\n",
      "num_qubits = 9,     vC = 0.0021061840158338708\n",
      "num_qubits = 9,     vC = 0.025858037001506882\n",
      "num_qubits = 9,     vC = 8.336106192804213e-05\n",
      "num_qubits = 9,     vC = 0.0009996071604248525\n",
      "num_qubits = 9,     vC = 2.1303652466004957e-05\n",
      "num_qubits = 9,     vC = 0.0017344521014180931\n",
      "num_qubits = 9,     vC = 8.02204507305328e-06\n",
      "num_qubits = 9,     vC = 7.945414073636972e-05\n",
      "num_qubits = 9,     vC = 3.806278289447967e-05\n",
      "num_qubits = 9,     vC = 0.008380432881280946\n",
      "num_qubits = 9,     vC = 0.0008366877840681446\n",
      "num_qubits = 9,     vC = 0.00019078070794646066\n",
      "num_qubits = 9,     vC = 0.000645702573625564\n",
      "num_qubits = 9,     vC = 3.732435234157275e-05\n",
      "num_qubits = 9,     vC = 0.10333673054115866\n",
      "num_qubits = 9,     vC = 0.0003325068043085377\n",
      "num_qubits = 9,     vC = 0.0003639063809609666\n",
      "num_qubits = 9,     vC = 0.0016797461235432889\n",
      "num_qubits = 9,     vC = 0.01103793982993846\n",
      "num_qubits = 9,     vC = 0.00015592145897512898\n",
      "num_qubits = 9,     vC = 0.000162525638086749\n",
      "num_qubits = 9,     vC = 9.952395532013455e-05\n",
      "num_qubits = 9,     vC = 1.206942575853611e-05\n",
      "num_qubits = 9,     vC = 1.7333382750388094e-05\n",
      "num_qubits = 9,     vC = 9.209748979260517e-08\n",
      "num_qubits = 9,     vC = 1.8221647219381168e-05\n",
      "num_qubits = 9,     vC = 0.00038559014792362203\n",
      "num_qubits = 9,     vC = 0.00016968720955387188\n",
      "num_qubits = 9,     vC = 0.00815598192817866\n",
      "num_qubits = 9,     vC = 0.00014387992390974919\n",
      "num_qubits = 9,     vC = 0.0007938018200288745\n",
      "num_qubits = 9,     vC = 0.00011374407598145973\n",
      "num_qubits = 9,     vC = 4.064656904489506e-06\n",
      "num_qubits = 9,     vC = 0.0007818351796618688\n",
      "num_qubits = 9,     vC = 0.01665370208854644\n",
      "num_qubits = 9,     vC = 2.6980397346617593e-05\n",
      "num_qubits = 9,     vC = 0.0003143316129675538\n",
      "num_qubits = 9,     vC = 0.0019431292656972548\n",
      "num_qubits = 9,     vC = 3.980456390750964e-06\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",
    "np.savetxt(\"QSL_ahead_Adam\", loss_change)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.linspace(2, 9, 8)\n",
    "y = 1/2**(0.5*x-1)\n",
    "plt.figure(figsize=(10,7))\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of qubit\")\n",
    "plt.ylabel(\"Change of f\")\n",
    "# 设置横轴的上下限\n",
    "# plt.xlim(2, 12)\n",
    "# 设置纵轴的上下限\n",
    "# plt.ylim(0, 1)\n",
    "\n",
    "plt.semilogy()\n",
    "plt.plot(x, loss_change, color=\"red\", linewidth=1.0, linestyle=\"-\", label=\" Delta C\")\n",
    "plt.plot(x, y, color=\"black\", linewidth=1.0, linestyle=\"-\", label=\"2^(-0.5n-1)\")\n",
    "\n",
    "\n",
    "plt.legend(loc=\"best\")\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
