{
 "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]))\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.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": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.35248789868200403\n",
      "num_qubits = 2,     vC = 0.42869364007907934\n",
      "num_qubits = 2,     vC = 0.366232385946397\n",
      "num_qubits = 2,     vC = 0.3096654299853544\n",
      "num_qubits = 2,     vC = 0.594579726057371\n",
      "num_qubits = 2,     vC = 0.14145616967093141\n",
      "num_qubits = 2,     vC = 0.57078718018135\n",
      "num_qubits = 2,     vC = 0.37846202592378875\n",
      "num_qubits = 2,     vC = 0.45649142718130753\n",
      "num_qubits = 2,     vC = 0.517539309069\n",
      "num_qubits = 3,     vC = 0.40509626688997796\n",
      "num_qubits = 3,     vC = 0.305303651243353\n",
      "num_qubits = 3,     vC = 0.10738438621605481\n",
      "num_qubits = 3,     vC = 0.32102814121332357\n",
      "num_qubits = 3,     vC = 0.14874758331334545\n",
      "num_qubits = 3,     vC = 0.32095837898429075\n",
      "num_qubits = 3,     vC = 0.16799305928038202\n",
      "num_qubits = 3,     vC = 0.17356932296409744\n",
      "num_qubits = 3,     vC = 0.250078107212931\n",
      "num_qubits = 3,     vC = 0.07210459453289644\n",
      "num_qubits = 4,     vC = 0.16592804026234773\n",
      "num_qubits = 4,     vC = 0.22453760209483745\n",
      "num_qubits = 4,     vC = 0.08213781527002535\n",
      "num_qubits = 4,     vC = 0.14213721942486213\n",
      "num_qubits = 4,     vC = 0.1987275823382071\n",
      "num_qubits = 4,     vC = 0.18088423036820678\n",
      "num_qubits = 4,     vC = 0.037896308060856754\n",
      "num_qubits = 4,     vC = 0.16431554469789883\n",
      "num_qubits = 4,     vC = 0.1328214855642961\n",
      "num_qubits = 4,     vC = 0.08227914790194167\n",
      "num_qubits = 5,     vC = 0.04037082179379282\n",
      "num_qubits = 5,     vC = 0.03446376526562312\n",
      "num_qubits = 5,     vC = 0.04961905763154692\n",
      "num_qubits = 5,     vC = 0.044325197961569446\n",
      "num_qubits = 5,     vC = 0.1109083070452368\n",
      "num_qubits = 5,     vC = 0.04789939239063889\n",
      "num_qubits = 5,     vC = 0.04001577834180031\n",
      "num_qubits = 5,     vC = 0.2522700345437329\n",
      "num_qubits = 5,     vC = 0.04385531721081344\n",
      "num_qubits = 5,     vC = 0.04151907428899482\n",
      "num_qubits = 6,     vC = 0.010951299060888283\n",
      "num_qubits = 6,     vC = 0.01430832967399697\n",
      "num_qubits = 6,     vC = 0.02106775205515412\n",
      "num_qubits = 6,     vC = 0.08439204474313232\n",
      "num_qubits = 6,     vC = 0.03975355652624975\n",
      "num_qubits = 6,     vC = 0.02137143496243102\n",
      "num_qubits = 6,     vC = 0.029814625433089877\n",
      "num_qubits = 6,     vC = 0.02461114913845664\n",
      "num_qubits = 6,     vC = 0.012886638463998533\n",
      "num_qubits = 6,     vC = 0.07923961773018241\n",
      "num_qubits = 7,     vC = 0.005282405443515393\n",
      "num_qubits = 7,     vC = 0.03195397842638873\n",
      "num_qubits = 7,     vC = 0.009063674718696908\n",
      "num_qubits = 7,     vC = 0.026109150143687834\n",
      "num_qubits = 7,     vC = 0.0329663301069714\n",
      "num_qubits = 7,     vC = 0.011396462699358387\n",
      "num_qubits = 7,     vC = 0.006710784948565372\n",
      "num_qubits = 7,     vC = 0.004520461063823071\n",
      "num_qubits = 7,     vC = 0.027586245826555195\n",
      "num_qubits = 7,     vC = 0.01025051350574532\n",
      "num_qubits = 8,     vC = 0.007753765218374347\n",
      "num_qubits = 8,     vC = 0.0032414131089552396\n",
      "num_qubits = 8,     vC = 0.012814817264645059\n",
      "num_qubits = 8,     vC = 0.002601341962559342\n",
      "num_qubits = 8,     vC = 0.0042584612814336705\n",
      "num_qubits = 8,     vC = 0.003908885816337251\n",
      "num_qubits = 8,     vC = 0.00536734430143272\n",
      "num_qubits = 8,     vC = 0.0013488053491242172\n",
      "num_qubits = 8,     vC = 0.0035590949148831762\n",
      "num_qubits = 8,     vC = 0.007440264937923262\n",
      "num_qubits = 9,     vC = 0.0002921282581500273\n",
      "num_qubits = 9,     vC = 0.001533405340765344\n",
      "num_qubits = 9,     vC = 0.006923195091620147\n",
      "num_qubits = 9,     vC = 0.002605017775214129\n",
      "num_qubits = 9,     vC = 0.0023571609343146275\n",
      "num_qubits = 9,     vC = 0.003689622020423383\n",
      "num_qubits = 9,     vC = 0.00032016322110506556\n",
      "num_qubits = 9,     vC = 0.0035124743804334346\n",
      "num_qubits = 9,     vC = 0.0014897398702929563\n",
      "num_qubits = 9,     vC = 0.006150787003883889\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(100):\n",
    "\n",
    "        V = uni_2_design(N, 10*N)\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": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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iK5z587RpEkTPvnkEx566KF7fv+JEyd49NFHH+THJSQkhMOHD7NhwwYGDx7MU089xZkzZwBn9YW6desCUKhQIQ4ePBjjzw8KCoqVARKfKmnxaQkOT0uTJg1PP/00kydPJiIigiFDhnDhwgVatWpF+vTpad26NdOmTbvxh1JERCSuXb58mSZNmvD000/TuHHjaL0nWbJkt9zSU6NGDQoVKkTbtm1JkyYNf//9942VEI4ePUqGDBn+8xlJkiQhTZo0ABQtWpTs2bOze/duABIlSnRjJNDf358rV65w9erVG5MMevfufc+MFy5cIFmyZNH6eaLiUyUtPi/B4UkBAQFUqFDhxk2YK1asoHDhwowaNYoMGTJQrVo1PvnkE/bu3et2VBERSSCstbRp04awsDBee+21aL8vLCzslv9fzZs3j40bNzJmzBiMMVSuXJmpU6cCMGHCBBo0aPCfz/j999+5evUqAPv372fPnj1ky5btrsf09/e/Mcng/fffv2fG3bt33/WSbEz4VEmT6MmWLRudOnVi3rx5nDhxgo4dO7J161bKly/PY489xuuvv87ixYu5fPmy21FFRMRH/frrr0ycOJFFixbdGKWaM+femw499thjnD59mrNnz97x6x9//DGDBw8mR44cnDp16sZSHTNmzLgxCrZs2TIKFChAoUKFaNq0KSNGjOCRRx6JUf5u3boRGhrKv//+S2hoKO++++4tP1u1atVi9Hl34sq2UOI9UqZMScOGDWnYsCHXrl1j/fr1zJ49m27durF3716qV69O3bp1qVWrFmnTpnU7roiI+Ihy5crd99JRrVu35ttvv6Vt27b/+Vq2bNnuOLOyfv361K9fH4AmTZrQpEmTO372uXPnbvy+YcOGPPvss3f8vv79+9O/f///vL5hwwby5s1743Lqg9BImtzg5+dHsWLFeOedd1izZg3bt2+nRo0aTJ8+nezZs1OmTBk+/PBDNm/erDXZRETENS+++CJJkiRxO8Yd/fHHH3dcgPd+aCRN7iokJITWrVvTunVrLl68yNKlS5k9ezYNGzbk8uXL1K1bl7p161KlSpVYuUFSRETiTnz+x3bSpEnvOsLltqguc8b0nGskTaIlSZIkVK9enU8//ZR9+/Yxf/58smXLxoABAwgODqZu3bqMGDGCI0eOuB1VRETuIWnSpJw6dSpeF7X4xlrLqVOn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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()"
   ]
  },
  {
   "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
}
