{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import paddle\n",
    "import paddle.fluid.layers as layers\n",
    "from paddle_quantum.utils import Hamiltonian\n",
    "from paddle_quantum.state import vec_random\n",
    "from paddle_quantum.circuit import UAnsatz\n",
    "import matplotlib.pyplot as plt\n",
    "import json\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def uni_2_design(N,D):\n",
    "#     theta = layers.create_parameter(shape=[D, N], default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2 * np.pi),\n",
    "#             dtype='float64',is_bias=False)\n",
    "    theta = np.random.uniform(low=0., high= 2 * np.pi, size=([D,N]))\n",
    "    theta = paddle.to_tensor(theta, stop_gradient=True, dtype='float64')\n",
    "    cir = UAnsatz(N)    \n",
    "    cir.weak_superposition_layer()\n",
    "\n",
    "    for d in range(D):\n",
    "        for i in range(N):\n",
    "            target = np.random.choice(3, N) \n",
    "            if target[i] == 0:\n",
    "                cir.rz(theta[d][i], i)\n",
    "            elif target[i] == 1:\n",
    "                cir.ry(theta[d][i], i)\n",
    "            else:\n",
    "                cir.rx(theta[d][i], i)\n",
    "\n",
    "        for i in range(N - 1):\n",
    "            cir.cz([i, i + 1])\n",
    "\n",
    "    return cir.run_state_vector()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def WriteJson(list_write, json_file_name):\n",
    "    with open(json_file_name + '.json', 'w') as file_save:\n",
    "        json_data = json.dumps(list_write, indent=4)\n",
    "        file_save.write(json_data)\n",
    "        file_save.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class StateNet_max(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_max, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    # loss function\n",
    "    def forward(self, N, rand_rho, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "\n",
    "        rho_luo = cir.run_state_vector(rand_rho)\n",
    "\n",
    "        # max_luo\n",
    "        loss = -(rho_luo.conj().T @ H @ rho_luo).real()\n",
    "        return loss\n",
    "\n",
    "class StateNet_min(paddle.nn.Layer):\n",
    "\n",
    "    def __init__(self, dtype=\"float64\"):\n",
    "        super(StateNet_min, self).__init__()\n",
    "        \n",
    "        # initialize theta\n",
    "        self.theta = self.create_parameter(shape=[3], \n",
    "                                        default_initializer=paddle.nn.initializer.Uniform(low=0.0, high=2*np.pi),\n",
    "                                        dtype=dtype, is_bias=False)\n",
    "        \n",
    "    def forward(self, N, rand_rho, H):\n",
    "        \n",
    "        cir = UAnsatz(N)\n",
    "\n",
    "        #local unitary U_A\n",
    "        cir.u3(*self.theta, 0)\n",
    "\n",
    "        rho_luo = cir.run_state_vector(rand_rho)\n",
    "\n",
    "        # min_luo\n",
    "        loss = (rho_luo.conj().T @ H @ rho_luo).real()\n",
    "        \n",
    "        return loss\n",
    "\n",
    "def train_loss(N, ini_state, Herm):\n",
    "\n",
    "    ITR = 100  # 设置训练的总迭代次数\n",
    "    LR = 0.1   # 设置学习速率\n",
    "    net_max = StateNet_max()\n",
    "    net_min = StateNet_min()\n",
    "    opt_max = paddle.optimizer.Adam(learning_rate=LR, parameters=net_max.parameters())\n",
    "    opt_min = paddle.optimizer.Adam(learning_rate=LR, parameters=net_min.parameters())\n",
    "\n",
    "    # optimization interation\n",
    "    for itr in range(1, ITR + 1):\n",
    "\n",
    "        # max_opt\n",
    "        loss_max = net_max(N, ini_state, Herm)\n",
    "\n",
    "        loss_max.backward()\n",
    "        opt_max.minimize(loss_max)\n",
    "        opt_max.clear_grad()\n",
    "\n",
    "        # min_opt\n",
    "        loss_min = net_min(N, ini_state, Herm)\n",
    "\n",
    "        loss_min.backward()\n",
    "        opt_min.minimize(loss_min)\n",
    "        opt_min.clear_grad()\n",
    "\n",
    "        # max - min\n",
    "        loss = -loss_max.numpy()[0] - loss_min.numpy()[0]\n",
    "        \n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.3936800935260413\n",
      "num_qubits = 2,     vC = 0.3318067012356951\n",
      "num_qubits = 2,     vC = 0.6197651078498535\n",
      "num_qubits = 2,     vC = 0.36626536581208474\n",
      "num_qubits = 2,     vC = 0.529130796081927\n",
      "num_qubits = 2,     vC = 0.47854983672924956\n",
      "num_qubits = 2,     vC = 0.6226542865029924\n",
      "num_qubits = 2,     vC = 0.8698361297496129\n",
      "num_qubits = 2,     vC = 0.753950668427849\n",
      "num_qubits = 2,     vC = 0.651441042224821\n",
      "num_qubits = 3,     vC = 0.013039625218580611\n",
      "num_qubits = 3,     vC = 0.20271060982960398\n",
      "num_qubits = 3,     vC = 0.010762419476771406\n",
      "num_qubits = 3,     vC = 0.2316438437562667\n",
      "num_qubits = 3,     vC = 0.4302069425803375\n",
      "num_qubits = 3,     vC = 0.3247983029077125\n",
      "num_qubits = 3,     vC = 0.2603863913825223\n",
      "num_qubits = 3,     vC = 0.10278162690592163\n",
      "num_qubits = 3,     vC = 0.19331548517543695\n",
      "num_qubits = 3,     vC = 0.13721177496911974\n",
      "num_qubits = 4,     vC = 0.18348862931812213\n",
      "num_qubits = 4,     vC = 0.06991403383760333\n",
      "num_qubits = 4,     vC = 0.2391000026753101\n",
      "num_qubits = 4,     vC = 0.07735926474696969\n",
      "num_qubits = 4,     vC = 0.1718856849361977\n",
      "num_qubits = 4,     vC = 0.08923403611661704\n",
      "num_qubits = 4,     vC = 0.048930421854517195\n",
      "num_qubits = 4,     vC = 0.10862735063905436\n",
      "num_qubits = 4,     vC = 0.10663896179762498\n",
      "num_qubits = 4,     vC = 0.03795032711031895\n",
      "num_qubits = 5,     vC = 0.15612933209873825\n",
      "num_qubits = 5,     vC = 0.10972116088833204\n",
      "num_qubits = 5,     vC = 0.12564230204237317\n",
      "num_qubits = 5,     vC = 0.07726192019005758\n",
      "num_qubits = 5,     vC = 0.08854892632881035\n",
      "num_qubits = 5,     vC = 0.13694829196910524\n",
      "num_qubits = 5,     vC = 0.09234225577548844\n",
      "num_qubits = 5,     vC = 0.08961387559896179\n",
      "num_qubits = 5,     vC = 0.08853844125180753\n",
      "num_qubits = 5,     vC = 0.03979726147073794\n",
      "num_qubits = 6,     vC = 0.014120956576556924\n",
      "num_qubits = 6,     vC = 0.04774523193093748\n",
      "num_qubits = 6,     vC = 0.05567602204643556\n",
      "num_qubits = 6,     vC = 0.04282015951570852\n",
      "num_qubits = 6,     vC = 0.02642620908761115\n",
      "num_qubits = 6,     vC = 0.021886538861929143\n",
      "num_qubits = 6,     vC = 0.03872260675915705\n",
      "num_qubits = 6,     vC = 0.08238590556105524\n",
      "num_qubits = 6,     vC = 0.049356005572954637\n",
      "num_qubits = 6,     vC = 0.06761396998037712\n",
      "num_qubits = 7,     vC = 0.0016930816352411435\n",
      "num_qubits = 7,     vC = 0.012240419418247649\n",
      "num_qubits = 7,     vC = 0.017434136474030488\n",
      "num_qubits = 7,     vC = 0.02920121190845663\n",
      "num_qubits = 7,     vC = 0.01997170034190815\n",
      "num_qubits = 7,     vC = 0.013906553840201423\n",
      "num_qubits = 7,     vC = 0.012049948848922397\n",
      "num_qubits = 7,     vC = 0.007454501452388707\n",
      "num_qubits = 7,     vC = 0.006267471755786154\n",
      "num_qubits = 7,     vC = 0.02961149171359852\n",
      "num_qubits = 8,     vC = 0.0040137517434309915\n",
      "num_qubits = 8,     vC = 0.012388738504080662\n",
      "num_qubits = 8,     vC = 0.0027736774176700322\n",
      "num_qubits = 8,     vC = 0.0007847578508964181\n",
      "num_qubits = 8,     vC = 0.0029442599194059375\n",
      "num_qubits = 8,     vC = 0.0010335046792326118\n",
      "num_qubits = 8,     vC = 0.012048982081849138\n",
      "num_qubits = 8,     vC = 0.0036284918750933066\n",
      "num_qubits = 8,     vC = 0.01959007088819831\n",
      "num_qubits = 8,     vC = 0.006913245933335679\n",
      "num_qubits = 9,     vC = 0.003016451939108374\n",
      "num_qubits = 9,     vC = 0.0005720184604429977\n",
      "num_qubits = 9,     vC = 0.01004736420167651\n",
      "num_qubits = 9,     vC = 0.007926412002949943\n",
      "num_qubits = 9,     vC = 0.0074140219628432286\n",
      "num_qubits = 9,     vC = 0.005241295695705132\n",
      "num_qubits = 9,     vC = 0.0031194545861762996\n",
      "num_qubits = 9,     vC = 0.0023901545814889774\n",
      "num_qubits = 9,     vC = 0.003393595814719355\n",
      "num_qubits = 9,     vC = 0.0034574902783120354\n"
     ]
    }
   ],
   "source": [
    "loss_change = []\n",
    "\n",
    "for N in range(2,10):\n",
    "\n",
    "    temp = []\n",
    "\n",
    "    # heisenberg model\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(100):\n",
    "\n",
    "        rand_rho = uni_2_design(N, 10*N)\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",
    "np.savetxt(\"QSL_behind_Adam\", loss_change)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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IoNXXnnlmhlPnTpFlixZkvT7JManSprXtuC4Xv7+/nTq1Im4uDiMMQQHBzNhwgTOnz/vdjQREZFkZa2lffv2BAcH06NHjyS/Ljg4mC+//PKfr5cvX86ePXuYPHkyxhiqVq3KRx99BMD7779Po0aNLnuPn3/++Z9/t3799dccPHiQ++6776qf6e/v/88igwEDBlwz4xdffHHVS7LXw6dKmq/IlSsX48aNY/ny5cyYMYNSpUqxefNmt2OJiIgkm02bNvHBBx+wZs2af85SLVu27JqvCwoK4tixY1ddcDd06FBGjRrF/fffz9GjR//ZqmPRokX/nAXbsGEDRYoUoWjRojRr1ozx48eTK1eu68rfq1cv8uXLx59//km+fPl47bXX/vW71axZ87re70oCbvodJMUULVqUDRs2MHv2bJo3b061atUYOnToFVeTiIiIpCUVKlS44cVy7dq1Y+7cuXTo0OGy7913331XXFnZsGFDGjZsCEDTpk1p2rTpFd/7xIkT//z54YcfplWrVlf8uWHDhjFs2LDLno+KiiI0NPSfy6k3Q2fSPM4YQ8uWLYmLi+Ouu+4iPDycESNGXHFzPhERkfTgmWeeIVOmTG7HuKJffvnlihvw3giVtDQiR44cDBkyhE2bNrF69WqKFCnCihUr3I4lIiJpVFre8ilz5sxXPcPltpo1a1KgQIErfu96j7lKWhrz4IMPsmzZMoYNG8YzzzxD48aN+eabb9yOJSIiaUjmzJk5evRomi5qaY21lqNHj5I5c+Ykv0b3pKVBxhgaNmxIrVq1GDFiBCVKlKBLly707t2brFmzuh1PREQ8Ll++fBw5coTff//9ukpDenPq1KlkPT6ZM2cmX758Sf55lbQ0LHPmzPTr148nn3ySnj17EhISwqhRo2jcuPF17/YsIiLpR4YMGShYsCDr1q0jMjLS7Tie5fbx8anLnWl5M9ubcc899/Dhhx8ydepUXnnlFWrVqkVcXJzbsUREROQm+FRJS+ub2d6satWqERUVRf369alUqRIvvPDCP2MuREREJG3xqZImzinsrl27sn//fn7//XeCgoJ4//33uXDhgtvRRERE5DqopPmo22+/nSlTprBgwQLGjRtH+fLl2bVrl9uxREREJIlU0nxc6dKl2bp1Kx06dKBevXp07NiRn3/+2e1YIiIicg0qaemAn58f7du3Jz4+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10LXrtCgATz7LPz+u9upPEslTURERFKPMdCqlXMJ9Px5Z1PcWbO0t9oVqKSJiIhI6suVC8aPdwa3DxsGNWvCF1+4ncpTVNJERETEPWXKOPen1asH5crBq69qb7UEKmkiIiLiroAA6N4d9uxxRkyFhcHy5W6ncp1KmoiIiHhDvnwwbx68/TY88ww8+mi63lvNp0qaxkKJiIj4gLp1Yd8+KFwYihRxStu5c26nSnU+VdI0FkpERMRHZM0KgwbB55/DggVQqhRs3+52qlTlUyVNREREfExwMKxZ48wDbdQIOndON3urqaSJiIiItxkDTzzhLCqw1tlbbeZMn99bTSVNRERE0oZbb4V333Uuf44YATVqwIEDbqdKMSppIiIikraULg07djijpcqXh5dfhr/+cjtVslNJExERkbQnIAC6dYPoaOdsWlgYfPaZ26mSlUqaiIiIpF133w0ffgjjxjkD25s3h+++cztVslBJExERkbSvTh1nb7UHH4SICHjrrTS/t5pKmoiIiPiGLFlg4EDYuBEWLoSSJWHbNrdT3TCVNBEREfEtQUGwejX07AkPP+yMmPrtN7dTXTeVNBEREfE9xsDjjzt7qxnj7K02Y0aa2ltNJU1ERER81623wjvvOJc/R42C6tUhPt7tVEmikiYiIiK+7+/Zn40aQYUK0K+f5/dW86mSZoxpYIyZeOzYMbejiIiIiNcEBEDXrs7eagcPOnurffqp26muyqdKmrV2sbW2Y2BgoNtRRERExKvuvhvmznUugz73HDzyiCf3VvOpkiYiIiKSZLVrQ0wMBAc7e6u9+aan9lZTSRMREZH0K0sWGDAANm2CJUugRAnYutXtVIBKmoiIiIgzqWDVKujVC5o0gaefJuD4cVcjqaSJiIiIgLOfWsuWzt5q/v6E9+nj6r5qAa59soiIiIgX5cwJ48YR/emnVDLGtRg6kyYiIiJyBReyZHH181XSRERERDxIJU1ERETEg1TSRERERDxIJU1ERETEg1TSRERERDxIJU1ERETEg1TSRERERDxIJU1ERETEg1TSRERERDxIJU1ERETEg3yqpBljGhhjJh47dsztKCIiIiI3xadKmrV2sbW2Y2BgoNtRRERERG6KT5U0EREREV+hkiYiIiLiQSppIiIiIh5krLVuZ0h2xpifgW9T+GPyAL+k8GekdTpGidPxSZyOz7Xp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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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "fb2e486a015784361e0077d7fcfeac02d1a431449f68aa51e1f4959008c61275"
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
