{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import numpy as np\n",
    "import random\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.mlab as mlab\n",
    "import seaborn as sns\n",
    "from qiskit import QuantumRegister, ClassicalRegister\n",
    "from qiskit import QuantumRegister\n",
    "from qiskit import QuantumCircuit\n",
    "from qiskit import Aer, execute\n",
    "from math import pi\n",
    "from qiskit import *  \n",
    "from qutip import *\n",
    "from math import log2\n",
    "from scipy.stats import norm\n",
    "backend = Aer.get_backend('qasm_simulator')\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_circular_point(r,cx,cy,noise_factor,num_points):\n",
    "    X = []\n",
    "    Y = []\n",
    "    for _ in range(num_points):\n",
    "        circle_r = np.random.random() * r\n",
    "        alpha = 2*math.pi*random.random()\n",
    "        x = circle_r*math.cos(alpha) + cx\n",
    "        y = circle_r*math.sin(alpha) + cy\n",
    "        X.append(x)\n",
    "        Y.append(y)\n",
    "    return np.array([X,Y])\n",
    "def generate_not_circular_point(r,cx,cy,noise_factor,num_points,gap_factor,scaling_fac):\n",
    "    X = []\n",
    "    Y = []\n",
    "    for _ in range(num_points):\n",
    "        circle_r = (np.random.random() * r * scaling_fac) + r*gap_factor\n",
    "        alpha = 2*math.pi*random.random()\n",
    "        x = circle_r*math.cos(alpha) + cx\n",
    "        y = circle_r*math.sin(alpha) + cy\n",
    "        X.append(x)\n",
    "        Y.append(y)\n",
    "    return np.array([X,Y])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def kernel(data,cx,cy):\n",
    "    k_data = []\n",
    "    for point in data:\n",
    "        dist = np.sqrt((cx-point[0])**2 + (cy-point[1])**2)\n",
    "        rotation = get_real_angle(point[0]-cx,point[1]-cy)\n",
    "        k_data.append([dist,rotation])\n",
    "    return np.array(k_data)\n",
    "def qubitization(data):\n",
    "    ry = []\n",
    "    rz = []\n",
    "    q_data = []\n",
    "    for point in data:\n",
    "        ry = 2*np.arcsin(np.sqrt(point[0]))\n",
    "        rz = point[1]\n",
    "        q_data.append([ry,rz])\n",
    "    return np.array(q_data)\n",
    "\n",
    "def get_real_angle(point0,point1):\n",
    "    value = np.arctan(point1/point0)\n",
    "    print(value)\n",
    "    if value < 0:\n",
    "        print(\"Val less than 0\")\n",
    "        #We know that the angle is between 90-180 or 270-360\n",
    "        if point1 < 0:\n",
    "            return abs(np.arctan(point1/point0)) + 3*np.pi/2 \n",
    "        else:\n",
    "            return abs(np.arctan(point1/point0)) + np.pi/2 \n",
    "    elif value > 0:\n",
    "        if point1 > 0 :\n",
    "            print(\"C\")\n",
    "            return np.arctan(point1/point0) + 0\n",
    "        else:\n",
    "            print(\"D\")\n",
    "            return abs(np.arctan(point1/point0)) + np.pi "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.7853981633974483\n",
      "Val less than 0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "2.356194490192345"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_real_angle(-1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cx = 0.5\n",
    "plt.style.use(\"ggplot\")\n",
    "cy = 0.5\n",
    "r = 0.2\n",
    "data = generate_circular_point(r,cx,cy,1,100).T\n",
    "data2 = generate_not_circular_point(r,cx,cy,1,100,1.7, 1.6).T\n",
    "#data = np.concatenate((data,data2))\n",
    "bad_points = data2[:,0]<0\n",
    "bad_points += data2[:,0]>1\n",
    "bad_points += data2[:,1]<0\n",
    "bad_points += data2[:,1]>1\n",
    "good_points = [True if x == False else False for x in bad_points]\n",
    "data2 = data2[good_points]\n",
    "sns.scatterplot(x=data[:,0],y=data[:,1],label=\"Class 1\")\n",
    "sns.scatterplot(x=data2[:,0],y=data2[:,1],label=\"Class 0\")\n",
    "plt.ylim([0,1])\n",
    "plt.xlim([0,1])\n",
    "plt.savefig(\"circles_dataset_classical.eps\",format=\"eps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6695632583913314\n",
      "C\n",
      "0.9696947650775631\n",
      "C\n",
      "1.0256321981976122\n",
      "C\n",
      "-0.7674603928982011\n",
      "Val less than 0\n",
      "-0.8575735989880208\n",
      "Val less than 0\n",
      "-0.6616838186450129\n",
      "Val less than 0\n",
      "-0.5827785336118866\n",
      "Val less than 0\n",
      "0.7267876903516285\n",
      "D\n",
      "0.8981671834503063\n",
      "C\n",
      "0.08479094759330666\n",
      "D\n",
      "0.09839499543283413\n",
      "C\n",
      "0.7344141702972984\n",
      "C\n",
      "0.9590020365751027\n",
      "D\n",
      "0.9824252460013796\n",
      "C\n",
      "-0.5457903741537464\n",
      "Val less than 0\n",
      "0.1204711095766581\n",
      "D\n",
      "1.2083416083938152\n",
      "D\n",
      "0.41612720884910975\n",
      "C\n",
      "0.546763693146473\n",
      "C\n",
      "-0.6271677035459949\n",
      "Val less than 0\n",
      "0.5225132268786249\n",
      "C\n",
      "-0.3015485346636809\n",
      "Val less than 0\n",
      "-0.38205008591223866\n",
      "Val less than 0\n",
      "0.9060274264185456\n",
      "D\n",
      "-1.196040914453705\n",
      "Val less than 0\n",
      "0.4772652796928804\n",
      "C\n",
      "0.3108159122343998\n",
      "C\n",
      "0.5652253233462854\n",
      "D\n",
      "0.5090361483475693\n",
      "D\n",
      "-0.3945549222239697\n",
      "Val less than 0\n",
      "-0.6701723311931789\n",
      "Val less than 0\n",
      "0.8829856689727086\n",
      "C\n",
      "-1.3516931084053578\n",
      "Val less than 0\n",
      "0.7469499924991083\n",
      "D\n",
      "0.08505244721765884\n",
      "D\n",
      "-0.7520806033084172\n",
      "Val less than 0\n",
      "-0.8237335095619412\n",
      "Val less than 0\n",
      "1.1801838813502499\n",
      "D\n",
      "0.8397036148626594\n",
      "D\n",
      "-0.77661932815982\n",
      "Val less than 0\n",
      "-0.8100717797998487\n",
      "Val less than 0\n",
      "-1.1549609978705389\n",
      "Val less than 0\n",
      "0.3971511386868354\n",
      "C\n",
      "0.10574813769627224\n",
      "D\n",
      "1.198042355650533\n",
      "D\n",
      "0.8453730140003564\n",
      "D\n",
      "1.116878840886155\n",
      "D\n",
      "-1.1770870710893402\n",
      "Val less than 0\n",
      "-1.186793880660889\n",
      "Val less than 0\n",
      "1.1575583709675161\n",
      "D\n",
      "-1.105201593393611\n",
      "Val less than 0\n",
      "-1.1723017331034555\n",
      "Val less than 0\n",
      "0.5612502674949695\n",
      "D\n",
      "0.5370735509267417\n",
      "C\n",
      "1.3570340681821946\n",
      "D\n",
      "0.4119562763055481\n",
      "D\n",
      "1.4284421006599197\n",
      "D\n",
      "1.0347481060574673\n",
      "D\n",
      "0.33327685575672994\n",
      "D\n",
      "0.9558922791593919\n",
      "C\n",
      "-1.3273238152221345\n",
      "Val less than 0\n",
      "-0.18942660104685474\n",
      "Val less than 0\n",
      "-0.30619935166080325\n",
      "Val less than 0\n",
      "0.5728754407382953\n",
      "D\n",
      "-0.4515329645874683\n",
      "Val less than 0\n",
      "0.9115144807113726\n",
      "C\n",
      "-0.3516558283457987\n",
      "Val less than 0\n",
      "0.0921754005877422\n",
      "D\n",
      "-0.0032211344719635143\n",
      "Val less than 0\n",
      "0.7145032047291089\n",
      "D\n",
      "0.06991586135641532\n",
      "D\n",
      "1.2805334867930604\n",
      "D\n",
      "0.1818030198191702\n",
      "D\n",
      "-1.178021838470384\n",
      "Val less than 0\n",
      "1.3556587717683293\n",
      "D\n",
      "-0.03342714050740856\n",
      "Val less than 0\n",
      "-0.22842972353021518\n",
      "Val less than 0\n",
      "-0.30359478966623626\n",
      "Val less than 0\n",
      "-0.027443199296598757\n",
      "Val less than 0\n",
      "0.6639219830507941\n",
      "C\n",
      "-1.4238842734715926\n",
      "Val less than 0\n",
      "0.7309099305322957\n",
      "D\n",
      "-0.8942154684093603\n",
      "Val less than 0\n",
      "-0.979064479925784\n",
      "Val less than 0\n",
      "0.06141670736526041\n",
      "C\n",
      "-0.19555124877841942\n",
      "Val less than 0\n",
      "0.7299924454602791\n",
      "D\n",
      "-0.815602874180429\n",
      "Val less than 0\n",
      "-0.5737585239668196\n",
      "Val less than 0\n",
      "-1.1850962926899946\n",
      "Val less than 0\n",
      "-0.26485733308043363\n",
      "Val less than 0\n",
      "-0.0023395933428782233\n",
      "Val less than 0\n",
      "1.0988591837208517\n",
      "D\n",
      "-0.6020082398143963\n",
      "Val less than 0\n",
      "1.4882086781021522\n",
      "C\n",
      "1.1652310024554597\n",
      "D\n",
      "0.5521075137850031\n",
      "D\n",
      "1.188906547171971\n",
      "C\n",
      "-1.3766090892189695\n",
      "Val less than 0\n",
      "-1.4010864656636877\n",
      "Val less than 0\n",
      "-0.044697209024016415\n",
      "Val less than 0\n",
      "0.16462893264283598\n",
      "D\n",
      "0.7444580100745566\n",
      "C\n",
      "-1.2443644883012936\n",
      "Val less than 0\n",
      "0.49396692985115104\n",
      "D\n",
      "0.6571826021714396\n",
      "D\n",
      "0.056676373430109714\n",
      "D\n",
      "0.25672537957115193\n",
      "D\n",
      "-0.35468971217900475\n",
      "Val less than 0\n",
      "-0.912606530171656\n",
      "Val less than 0\n",
      "1.0360220967275469\n",
      "C\n",
      "0.5298208016180287\n",
      "C\n",
      "0.8286185624379274\n",
      "C\n",
      "1.3025741571727059\n",
      "D\n",
      "1.499708573995644\n",
      "D\n",
      "-1.1175060282437002\n",
      "Val less than 0\n",
      "1.543363942047839\n",
      "C\n",
      "0.012549344930145215\n",
      "D\n",
      "-1.4937988297097795\n",
      "Val less than 0\n",
      "1.3716057232921126\n",
      "C\n",
      "-0.0493677124155158\n",
      "Val less than 0\n",
      "0.43312092309302774\n",
      "D\n",
      "-0.6730454335351646\n",
      "Val less than 0\n",
      "0.931195335874203\n",
      "D\n",
      "-1.4457224774864819\n",
      "Val less than 0\n",
      "-1.1878317108218528\n",
      "Val less than 0\n",
      "-0.3743158516727471\n",
      "Val less than 0\n",
      "-0.9916877975816563\n",
      "Val less than 0\n",
      "1.0805822936680785\n",
      "C\n",
      "0.8567919076176465\n",
      "D\n",
      "-0.9941272788251405\n",
      "Val less than 0\n",
      "0.884679538982258\n",
      "D\n",
      "-1.4438717997077144\n",
      "Val less than 0\n",
      "0.6262528784181676\n",
      "D\n",
      "0.23146711237121712\n",
      "D\n",
      "0.5249643331434156\n",
      "D\n",
      "-0.5409822605982497\n",
      "Val less than 0\n",
      "1.4112503125148945\n",
      "D\n",
      "-0.6289635843938024\n",
      "Val less than 0\n",
      "0.9176690807571264\n",
      "C\n",
      "0.4085759720495764\n",
      "C\n",
      "-0.1817687835934306\n",
      "Val less than 0\n",
      "1.3442405549529672\n",
      "D\n",
      "-0.1371701431735397\n",
      "Val less than 0\n",
      "-0.2503328532732422\n",
      "Val less than 0\n",
      "-1.2340762948294577\n",
      "Val less than 0\n",
      "0.16223273160119567\n",
      "D\n",
      "0.37102024419432195\n",
      "D\n",
      "0.5879394637878483\n",
      "D\n",
      "1.3264631486880933\n",
      "D\n",
      "-0.39550210272971076\n",
      "Val less than 0\n",
      "-0.18841345210873506\n",
      "Val less than 0\n",
      "-1.0749008256715917\n",
      "Val less than 0\n",
      "-0.37636690904168385\n",
      "Val less than 0\n",
      "-0.29362825603483006\n",
      "Val less than 0\n",
      "-0.011575825298908441\n",
      "Val less than 0\n",
      "-1.4330772042750932\n",
      "Val less than 0\n",
      "0.37408113941285437\n",
      "C\n",
      "-0.5558554875798525\n",
      "Val less than 0\n",
      "0.1679912394850178\n",
      "D\n",
      "0.28388716691703203\n",
      "C\n",
      "-0.9309166760184483\n",
      "Val less than 0\n",
      "-0.5535791296311298\n",
      "Val less than 0\n",
      "1.559153067928527\n",
      "D\n",
      "0.08733395278581227\n",
      "C\n"
     ]
    }
   ],
   "source": [
    "#Class 1 data\n",
    "kernel_data = kernel(data2,cx,cy)\n",
    "new_max = np.max(kernel_data[:,0])\n",
    "kernel_data[:,0] = kernel_data[:,0]/new_max\n",
    "q_kernel_data2 = qubitization(kernel_data)\n",
    "\n",
    "#Class 0 data\n",
    "kernel_data = kernel(data,cx,cy)\n",
    "kernel_data[:,0] = kernel_data[:,0]/new_max\n",
    "q_kernel_data = qubitization(kernel_data)\n",
    "temp_max = np.max(kernel_data[:,0])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.style.use(\"default\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "points = []\n",
    "k =3 \n",
    "x,y,z = [],[],[]\n",
    "g = Bloch()\n",
    "for point in q_kernel_data:\n",
    "    vert_angle = point[0]\n",
    "    hor_angle = point[1]\n",
    "    x.append(np.sin(vert_angle)*np.cos(hor_angle))\n",
    "    y.append(np.sin(vert_angle)*np.sin(hor_angle))\n",
    "    z.append(np.cos(vert_angle))\n",
    "\n",
    "\n",
    "g.add_points([x,y,z])\n",
    "\n",
    "x,y,z = [],[],[]\n",
    "for point in q_kernel_data2:\n",
    "    vert_angle = point[0]\n",
    "    hor_angle = point[1]\n",
    "    x.append(np.sin(vert_angle)*np.cos(hor_angle))\n",
    "    y.append(np.sin(vert_angle)*np.sin(hor_angle))\n",
    "    z.append(np.cos(vert_angle))\n",
    "\n",
    "g.add_points([x,y,z])\n",
    "g.save(\"circle_dataset_on_qubit.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.1 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.2 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "Classification : 0.3 | Class : 0\n",
      "Classification : 0.0 | Class : 0\n",
      "     ┌──────────────┐┌──────────────┐┌─┐\n",
      "q_0: ┤ RY(0.076978) ├┤ RZ(0.087334) ├┤M├\n",
      "     └──────────────┘└──────────────┘└╥┘\n",
      "c_0: ═════════════════════════════════╩═\n",
      "                                        \n"
     ]
    }
   ],
   "source": [
    "q = 1\n",
    "c = 1\n",
    "right = 0\n",
    "wrong = 0\n",
    "for point in q_kernel_data:\n",
    "    circ = QuantumCircuit(q,c)\n",
    "    circ.ry(point[0],0)\n",
    "    circ.rz(point[1],0)\n",
    "    circ.measure(0,0)\n",
    "    #print(circ.qasm())\n",
    "    result = execute(circ, backend).result()\n",
    "    counts = result.get_counts(circ)\n",
    "    \n",
    "    try:\n",
    "        confidence = counts['1']/(counts['1']+counts['0'])\n",
    "    except:\n",
    "        if '1' in counts.keys():\n",
    "            confidence = 1\n",
    "        else:\n",
    "            confidence = 0 \n",
    "    print(f\"Classification : {round(confidence,1)} | Class : 0\")\n",
    "    if confidence >= 0.5:\n",
    "        right+=1\n",
    "print(circ)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'OPENQASM 2.0;\\ninclude \"qelib1.inc\";\\nqreg q[1];\\ncreg c[1];\\nry(0.076978091) q[0];\\nrz(0.087333953) q[0];\\nmeasure q[0] -> c[0];\\n'"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "circ.qasm()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
