{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import paddle\n",
    "import paddle.fluid.layers as layers\n",
    "from paddle_quantum.utils import Hamiltonian, haar_unitary\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": 7,
   "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": 8,
   "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": 9,
   "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 = -cir.expecval(H)\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 = cir.expecval(H)\n",
    "#         loss = rho_luo.matmul(H).trace().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": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_qubits = 2,     vC = 0.7361470331050064\n",
      "num_qubits = 2,     vC = 0.8880181416348669\n",
      "num_qubits = 2,     vC = 0.6386268147339853\n",
      "num_qubits = 2,     vC = 0.8313044837957435\n",
      "num_qubits = 2,     vC = 0.9835454756357028\n",
      "num_qubits = 2,     vC = 0.926093316196611\n",
      "num_qubits = 2,     vC = 0.7318887379891118\n",
      "num_qubits = 2,     vC = 0.4502324506280036\n",
      "num_qubits = 2,     vC = 0.5758896101478735\n",
      "num_qubits = 2,     vC = 0.8707879491911857\n",
      "num_qubits = 3,     vC = 0.5107998790799648\n",
      "num_qubits = 3,     vC = 0.8690920407356101\n",
      "num_qubits = 3,     vC = 0.6277135435604457\n",
      "num_qubits = 3,     vC = 0.6245344239250248\n",
      "num_qubits = 3,     vC = 0.3581723001138823\n",
      "num_qubits = 3,     vC = 0.8288677636063667\n",
      "num_qubits = 3,     vC = 0.2734401046627898\n",
      "num_qubits = 3,     vC = 0.27109771337653227\n",
      "num_qubits = 3,     vC = 0.8880569712769408\n",
      "num_qubits = 3,     vC = 0.2961976557145588\n",
      "num_qubits = 4,     vC = 0.5169131288766728\n",
      "num_qubits = 4,     vC = 0.5387607978449042\n",
      "num_qubits = 4,     vC = 0.25993353881747283\n",
      "num_qubits = 4,     vC = 0.6213385995098901\n",
      "num_qubits = 4,     vC = 0.4543977047182618\n",
      "num_qubits = 4,     vC = 0.12627929871472388\n",
      "num_qubits = 4,     vC = 0.19405003537231014\n",
      "num_qubits = 4,     vC = 0.5222312352365421\n",
      "num_qubits = 4,     vC = 0.5569257785182979\n",
      "num_qubits = 4,     vC = 0.5045385459824825\n",
      "num_qubits = 5,     vC = 0.3029318050413751\n",
      "num_qubits = 5,     vC = 0.2715191658529711\n",
      "num_qubits = 5,     vC = 0.3013738061405197\n",
      "num_qubits = 5,     vC = 0.3064531575714982\n",
      "num_qubits = 5,     vC = 0.3004202460357607\n",
      "num_qubits = 5,     vC = 0.36882535633153896\n",
      "num_qubits = 5,     vC = 0.3673004279345677\n",
      "num_qubits = 5,     vC = 0.3422493374618417\n",
      "num_qubits = 5,     vC = 0.27399707991077715\n",
      "num_qubits = 5,     vC = 0.20886116450838682\n",
      "num_qubits = 6,     vC = 0.059334264821885085\n",
      "num_qubits = 6,     vC = 0.23199989388366987\n",
      "num_qubits = 6,     vC = 0.26386986179851635\n",
      "num_qubits = 6,     vC = 0.2713944560106525\n",
      "num_qubits = 6,     vC = 0.09578483045130592\n",
      "num_qubits = 6,     vC = 0.2230021730472439\n",
      "num_qubits = 6,     vC = 0.29878534089283443\n",
      "num_qubits = 6,     vC = 0.14052034590608747\n",
      "num_qubits = 6,     vC = 0.1877607583448329\n",
      "num_qubits = 6,     vC = 0.2533527304529239\n",
      "num_qubits = 7,     vC = 0.06117600981786131\n",
      "num_qubits = 7,     vC = 0.04861390976319918\n",
      "num_qubits = 7,     vC = 0.18827376243254051\n",
      "num_qubits = 7,     vC = 0.1478992706749621\n",
      "num_qubits = 7,     vC = 0.14437087792381342\n",
      "num_qubits = 7,     vC = 0.29783641132639327\n",
      "num_qubits = 7,     vC = 0.14293333416712894\n",
      "num_qubits = 7,     vC = 0.29314161681398876\n",
      "num_qubits = 7,     vC = 0.27749781827480974\n",
      "num_qubits = 7,     vC = 0.07176406372300254\n",
      "num_qubits = 8,     vC = 0.05691876818838587\n",
      "num_qubits = 8,     vC = 0.16977011366498224\n",
      "num_qubits = 8,     vC = 0.10659234380882265\n",
      "num_qubits = 8,     vC = 0.08115988219833392\n",
      "num_qubits = 8,     vC = 0.20696103467655125\n",
      "num_qubits = 8,     vC = 0.12063718431721193\n",
      "num_qubits = 8,     vC = 0.0845162885535033\n",
      "num_qubits = 8,     vC = 0.13613847987849387\n",
      "num_qubits = 8,     vC = 0.1403128540562481\n",
      "num_qubits = 8,     vC = 0.06226067717121969\n",
      "num_qubits = 9,     vC = 0.11064718313078153\n",
      "num_qubits = 9,     vC = 0.0700705571911937\n",
      "num_qubits = 9,     vC = 0.031585391539276475\n",
      "num_qubits = 9,     vC = 0.10691763500137391\n",
      "num_qubits = 9,     vC = 0.11046188839934074\n",
      "num_qubits = 9,     vC = 0.06493788618349167\n",
      "num_qubits = 9,     vC = 0.048869895290118204\n",
      "num_qubits = 9,     vC = 0.03439803829222182\n",
      "num_qubits = 9,     vC = 0.12230319303213621\n",
      "num_qubits = 9,     vC = 0.010905597340774675\n"
     ]
    }
   ],
   "source": [
    "loss_change = []\n",
    "\n",
    "for N in range(2,10):\n",
    "\n",
    "    temp = []\n",
    "\n",
    "    # heisenberg model\n",
    "    H = [(0.5, 'Z0'), (0.5, 'I')]\n",
    "    \n",
    "    # spectral width of H = 1\n",
    "\n",
    "    for _ in range(100):\n",
    "\n",
    "        rand_rho = uni_2_design(N, 10*N)\n",
    "#         rand_rho.stop_gradient = True\n",
    "        Delta_C = train_loss(N, ini_state=rand_rho, Herm=H)\n",
    "        \n",
    "        # Delta C / w(H)\n",
    "        temp.append(Delta_C)\n",
    "        if _ % 10 == 0:\n",
    "            print(f'num_qubits = {N},     vC = {Delta_C}')\n",
    "\n",
    "    WriteJson(temp,  'sample_vC_QAE_behind_Adam_'+str(N)+'qubit')\n",
    "\n",
    "    loss_change.append(np.average(temp))\n",
    "np.savetxt(\"QAE_Adam\", loss_change)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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()"
   ]
  },
  {
   "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
}
