{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "59b88cad",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "91f732bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "import qiskit\n",
    "from qiskit import QuantumCircuit, Aer, execute, transpile\n",
    "from qiskit_aer import AerSimulator\n",
    "from qiskit.quantum_info import Operator\n",
    "\n",
    "import pennylane as qml\n",
    "from pennylane import numpy as np\n",
    "from pennylane.templates import RandomLayers\n",
    "from pennylane.transforms import commute_controlled, cancel_inverses\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "35d4f4ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pruned_circuit():\n",
    "    qml.RY(1.56196162,wires=0)\n",
    "    qml.RY(1.85389218,wires=1)\n",
    "    qml.RY(2.10833927,wires=2)\n",
    "    qml.RY(1.6481354,wires=3)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(-0.55818495,wires=2)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(0.146037,wires=2)\n",
    "    qml.RY(-0.04154526,wires=3)\n",
    "    qml.CNOT(wires=[1,3])\n",
    "    qml.RY(0.51167075,wires=3)\n",
    "    qml.CNOT(wires=[0,3])\n",
    "    qml.RY(0.18881247,wires=3)\n",
    "    qml.CNOT(wires=[1,3])\n",
    "    qml.RY(0.5747956,wires=3)\n",
    "    qml.RY(0.05966411,wires=3)\n",
    "    qml.CNOT(wires=[0,3])\n",
    "    return qml.state()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "bcd2d26c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.02815955+0.j 0.28057206+0.j 0.03193209+0.j 0.31816035+0.j\n",
      " 0.06676807+0.j 0.0647796 +0.j 0.40217807+0.j 0.39020048+0.j\n",
      " 0.22292963+0.j 0.16859236+0.j 0.25279555+0.j 0.19117871+0.j\n",
      " 0.08739415+0.j 0.02941185+0.j 0.52641946+0.j 0.17716255+0.j]\n"
     ]
    }
   ],
   "source": [
    "dev = qml.device('default.qubit', wires=4)\n",
    "pruned_cir = qml.QNode(pruned_circuit,dev)\n",
    "pruned_res = pruned_cir()\n",
    "print(pruned_res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "7a303dc4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OPENQASM 2.0;\n",
      "include \"qelib1.inc\";\n",
      "qreg q[4];\n",
      "creg c[4];\n",
      "ry(1.56196162) q[0];\n",
      "ry(1.85389218) q[1];\n",
      "ry(2.10833927) q[2];\n",
      "ry(1.6481354) q[3];\n",
      "cx q[1],q[2];\n",
      "ry(-0.55818495) q[2];\n",
      "cx q[1],q[2];\n",
      "ry(0.146037) q[2];\n",
      "ry(-0.04154526) q[3];\n",
      "cx q[1],q[3];\n",
      "ry(0.51167075) q[3];\n",
      "cx q[0],q[3];\n",
      "ry(0.18881247) q[3];\n",
      "cx q[1],q[3];\n",
      "ry(0.5747956) q[3];\n",
      "ry(0.05966411) q[3];\n",
      "cx q[0],q[3];\n",
      "measure q[0] -> c[0];\n",
      "measure q[1] -> c[1];\n",
      "measure q[2] -> c[2];\n",
      "measure q[3] -> c[3];\n",
      "\n"
     ]
    }
   ],
   "source": [
    "t = pruned_cir.qtape.to_openqasm()\n",
    "print(t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "id": "f7385088",
   "metadata": {},
   "outputs": [],
   "source": [
    "openqasm_code='''\n",
    "OPENQASM 2.0;\n",
    "include \"qelib1.inc\";\n",
    "qreg q[4];\n",
    "creg c[4];\n",
    "ry(1.56196162) q[3];\n",
    "ry(1.85389218) q[2];\n",
    "ry(2.10833927) q[1];\n",
    "ry(1.6481354) q[0];\n",
    "cx q[2],q[1];\n",
    "ry(-0.55818495) q[1];\n",
    "cx q[2],q[1];\n",
    "ry(0.146037) q[1];\n",
    "ry(-0.04154526) q[0];\n",
    "cx q[2],q[0];\n",
    "ry(0.51167075) q[0];\n",
    "cx q[3],q[0];\n",
    "ry(0.18881247) q[0];\n",
    "cx q[2],q[0];\n",
    "ry(0.5747956) q[0];\n",
    "ry(0.05966411) q[0];\n",
    "cx q[3],q[0];\n",
    "'''\n",
    "\n",
    "# openqasm_code='''\n",
    "# OPENQASM 2.0;\n",
    "# include \"qelib1.inc\";\n",
    "# qreg q[4];\n",
    "# creg c[4];\n",
    "# ry(1.56196162) q[0];\n",
    "# ry(1.85389218) q[1];\n",
    "# ry(2.10833927) q[2];\n",
    "# ry(1.6481354) q[3];\n",
    "# cx q[1],q[2];\n",
    "# ry(-0.55818495) q[2];\n",
    "# cx q[1],q[2];\n",
    "# ry(0.146037) q[2];\n",
    "# ry(-0.04154526) q[3];\n",
    "# cx q[1],q[3];\n",
    "# ry(0.51167075) q[3];\n",
    "# cx q[0],q[3];\n",
    "# ry(0.18881247) q[3];\n",
    "# cx q[1],q[3];\n",
    "# ry(0.5747956) q[3];\n",
    "# ry(0.05966411) q[3];\n",
    "# cx q[0],q[3];\n",
    "# '''\n",
    "\n",
    "qc = QuantumCircuit.from_qasm_str(openqasm_code)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 207,
   "id": "91befd26",
   "metadata": {},
   "outputs": [],
   "source": [
    "operator = Operator(qc)\n",
    "m =operator.data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 208,
   "id": "ce0d1619",
   "metadata": {},
   "outputs": [],
   "source": [
    "b = m @ np.array([1,0,0,0,0,0,0,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "id": "217e1d06",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.82018607+0.j, 0.56111948+0.j, 0.09772112+0.j, 0.01980905+0.j,\n",
       "        0.04104351+0.j, 0.02807938+0.j, 0.00489013+0.j, 0.00099128+0.j], requires_grad=True)"
      ]
     },
     "execution_count": 209,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "id": "314f493b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Statevector([0.82018607+0.j, 0.56111948+0.j, 0.09772112+0.j,\n",
      "             0.01980905+0.j, 0.04104351+0.j, 0.02807938+0.j,\n",
      "             0.00489013+0.j, 0.00099128+0.j],\n",
      "            dims=(2, 2, 2))\n"
     ]
    }
   ],
   "source": [
    "simulator = AerSimulator()\n",
    "compiled_circuit = transpile(qc, simulator)\n",
    "backend = Aer.get_backend('statevector_simulator')\n",
    "job = execute(compiled_circuit, backend=backend)\n",
    "# job = execute(qc, backend=backend)\n",
    "# Grab results from the job\n",
    "result1 = job.result()\n",
    "\n",
    "\n",
    "# Returns counts\n",
    "statevector = result1.get_statevector()\n",
    "\n",
    "print(statevector)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 202,
   "id": "375850cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.28198163+0.j 0.31975876+0.j 0.09302888+0.j 0.56036026+0.j\n",
      " 0.27950135+0.j 0.31694619+0.j 0.0922106 +0.j 0.55543138+0.j]\n"
     ]
    }
   ],
   "source": [
    "def circuit():\n",
    "    qml.RY(1.56196162,wires=0)\n",
    "    qml.RY(1.85389218,wires=1)\n",
    "    qml.RY(2.10833927,wires=2)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(-0.55818495,wires=2)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(0.146037,wires=2)\n",
    "    return qml.state()\n",
    "dev = qml.device('default.qubit', wires=3)\n",
    "cir = qml.QNode(circuit,dev)\n",
    "res = cir()\n",
    "print(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "b111f492",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import replace\n",
    "new_angle = [0.1,0.2,0.3,0.4,0.5]\n",
    "qc = replace(cir,new_angle,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 204,
   "id": "0778f1b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.82018607+0.j 0.56111948+0.j 0.09772112+0.j 0.01980905+0.j\n",
      " 0.04104351+0.j 0.02807938+0.j 0.00489013+0.j 0.00099128+0.j]\n"
     ]
    }
   ],
   "source": [
    "def r_circuit():\n",
    "    qml.RY(0.1,wires=0)\n",
    "    qml.RY(0.2,wires=1)\n",
    "    qml.RY(0.3,wires=2)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(0.4,wires=2)\n",
    "    qml.CNOT(wires=[1,2])\n",
    "    qml.RY(0.5,wires=2)\n",
    "    return qml.state()\n",
    "dev = qml.device('default.qubit', wires=3)\n",
    "r_cir = qml.QNode(r_circuit,dev)\n",
    "res = r_cir()\n",
    "print(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 205,
   "id": "7d57baf7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0: ──RY(0.10)───────────────────────────┤  State\n",
      "1: ──RY(0.20)─╭●───────────╭●───────────┤  State\n",
      "2: ──RY(0.30)─╰X──RY(0.40)─╰X──RY(0.50)─┤  State\n"
     ]
    }
   ],
   "source": [
    "print(qml.draw(r_cir)())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "id": "e22b943d",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"word-wrap: normal;white-space: pre;background: #fff0;line-height: 1.1;font-family: &quot;Courier New&quot;,Courier,monospace\">     ┌─────────┐┌───┐┌─────────┐┌───┐┌─────────┐\n",
       "q_0: ┤ Ry(0.3) ├┤ X ├┤ Ry(0.4) ├┤ X ├┤ Ry(0.5) ├\n",
       "     ├─────────┤└─┬─┘└─────────┘└─┬─┘└─────────┘\n",
       "q_1: ┤ Ry(0.2) ├──■───────────────■─────────────\n",
       "     ├─────────┤                                \n",
       "q_2: ┤ Ry(0.1) ├────────────────────────────────\n",
       "     └─────────┘                                \n",
       "c: 3/═══════════════════════════════════════════\n",
       "                                                </pre>"
      ],
      "text/plain": [
       "     ┌─────────┐┌───┐┌─────────┐┌───┐┌─────────┐\n",
       "q_0: ┤ Ry(0.3) ├┤ X ├┤ Ry(0.4) ├┤ X ├┤ Ry(0.5) ├\n",
       "     ├─────────┤└─┬─┘└─────────┘└─┬─┘└─────────┘\n",
       "q_1: ┤ Ry(0.2) ├──■───────────────■─────────────\n",
       "     ├─────────┤                                \n",
       "q_2: ┤ Ry(0.1) ├────────────────────────────────\n",
       "     └─────────┘                                \n",
       "c: 3/═══════════════════════════════════════════\n",
       "                                                "
      ]
     },
     "execution_count": 206,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "qc.draw()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8651b4c8",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.9.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
