diff --git a/template-exercise-05.ipynb b/template-exercise-05.ipynb new file mode 100644 index 0000000..96f8794 --- /dev/null +++ b/template-exercise-05.ipynb @@ -0,0 +1,228 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 2, + "id": "3ad81093-9f6a-4d8d-a85b-7f5e056f42a6", + "metadata": {}, + "outputs": [], + "source": [ + "import qiskit\n", + "# numerics\n", + "import numpy as np\n", + "# functional programmin tools\n", + "import itertools\n", + "import functools\n", + "import operator\n", + "# plotting\n", + "import matplotlib.pyplot as plt\n", + "%matplotlib inline\n", + "plt.rcParams['figure.dpi'] = 125\n", + "import seaborn\n", + "# data analysis\n", + "import pandas as pd\n", + "# qiskit \n", + "from qiskit import QuantumCircuit, transpile, assemble\n", + "from qiskit_aer import QasmSimulator, AerSimulator\n", + "from qiskit.quantum_info import Pauli\n", + "from qiskit.visualization import array_to_latex, plot_histogram\n", + "from qiskit.quantum_info import Kraus, SuperOp, SparsePauliOp, Operator, DensityMatrix, Statevector\n", + "from qiskit_aer.noise import NoiseModel, QuantumError, ReadoutError, depolarizing_error\n", + "from qiskit.circuit import ParameterVector" + ] + }, + { + "cell_type": "markdown", + "id": "473f6a05-7b38-4c95-b4be-3896dce7e718", + "metadata": {}, + "source": [ + "## Exercise 5" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "id": "b4d52ecc-63e2-4064-be7c-022310e0ea9c", + "metadata": {}, + "outputs": [], + "source": [ + "#Circuit 1: Single CNOT gate\n", + "circ_1=list([list((0,3))])\n", + "circ_2=list([list((0,1)), list((2,3)), list((0,3)), list((1,2))])\n", + "\n", + "mapping_1 = [(0,0), (1,1), (2,2), (3,3)]\n", + "\n", + "def create_CNOT_circuit(CNOT_list):\n", + " qc = QuantumCircuit(4)\n", + " \n", + " # Apply the Ising-type gates for each edge\n", + " for item in CNOT_list:\n", + " qc.cx(item[0], item[1])\n", + " return qc" + ] + }, + { + "cell_type": "markdown", + "id": "a758ae9a-6360-4a1a-ac10-a7cf2557db39", + "metadata": {}, + "source": [ + "### 5.1 (a)\n", + "\n", + "Consider the following CNOT gate and the intuitive qubit mapping $q_i \\rightarrow q_i$ :" + ] + }, + { + "cell_type": "code", + "execution_count": 14, + "id": "8c8f8a12-c59f-4d35-9c26-4e4f150083e8", + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "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c2dg72tJmOw9aZymci+MbozMZvOI99AtWrQIUVFR+OCDD/D+++9bft7V1YXNmzcDAJ566imRWV1BpVLhtexE/HaLDrPCAkZcNihgMv5vphaHC5YgKODOuaeOdxmMkdFoRGxsLADb99B9+OGHSE5OhqIoWLlyJWbOnImysjJ88sknWLNmDXbu3Ck9tkv09PSi4k8X8Jt3GnD60yu4+PU3l0myH9fiZz95CH4abxdO6CIKjcnu3bsVAAoApbq62uZyp0+fVlJSUpSpU6cqPj4+SmxsrJKfn6/09vYKTus+Kk9fUqDdZfmqPH3J1SO5DM9ejlH/SRS1Wm3Z4lkzZ84cHDx4UGos8iA8phuj/pMovIeO7MUt3RhVVFS4egTycNzSEQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdETCGB2RMEZHJIzREQljdKNw5MgRpKenIywsDD4+PggPD0dmZiYaGxsBADqdDiqVComJiS6elDyBl6sHcGft7e3Q6/UoLS0d9POmpiYYDAYcPHgQJ06cQH19PQAgLi7OBVOSp+GWzoaenh4sW7bMElxycjL27NmDU6dOoby8HGlpabh69Sr0ej1aWloAMDoaHW7pbMjJycGxY8cAANu3b0dWVtag5xcvXozly5dj3759lp8xOhoNbumsMBqNyMvLAwCsW7duWHD9cnJyLI/VajViY2NF5iPPxuis2LJlCxRFQUhICLZu3WpzuZiYGMvjqKgoaDQaifHIwzG6IUwmEw4cOAAA0Ov18Pf3t7msRqOBt7c3gOG7lr/73e+wZs0aJCYmQqPRQKVS4cUXXxyvscmD8JhuiPLycvT29gIAUlJSRly2ra0NZrMZwPDoXnjhBXzxxReYNm0a7r77bnz++efjMi95HkY3RE1NjeXxvHnzRly2trbW8nhodLt27UJkZCQiIiJQXFyMxx9/3JljorW1FUaj0anrHE9159oH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", + "text/plain": [ + "
" + ] + }, + "execution_count": 14, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "qc=create_CNOT_circuit(circ_1)\n", + "qc.draw('mpl')" + ] + }, + { + "cell_type": "code", + "execution_count": 15, + "id": "3f35ef37-d8ab-45e2-81e0-b0eb21691723", + "metadata": {}, + "outputs": [], + "source": [ + "#Algorithm:\n", + "def qubit_routing_algorithm(CNOT_list, mapping):\n", + " qc = QuantumCircuit(4)\n", + " cnot_count=0\n", + " #To Do: Write an algrithm that creates the circuit in the given topology using swap gates \n", + " # and evaluates the cnot count of the resulting circuit\n", + " return qc, cnot_count" + ] + }, + { + "cell_type": "code", + "execution_count": 13, + "id": "49712309-599f-4ca2-a5c3-1b1e324b3104", + "metadata": {}, + "outputs": [], + "source": [ + "#To Do: Run your algortihm for a single CNOT gate in the given topology" + ] + }, + { + "cell_type": "markdown", + "id": "94286203-8eb2-421c-a8d4-b5dc453a4376", + "metadata": {}, + "source": [ + "## 5.1 (b)\n", + "\n", + "Consider the following CNOT circuit" + ] + }, + { + "cell_type": "code", + "execution_count": 8, + "id": "3e3d8260-c60a-4435-ab98-f44f1daeb10e", + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "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", + "text/plain": [ + "
" + ] + }, + "execution_count": 8, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "qc=create_CNOT_circuit(circ_2)\n", + "qc.draw('mpl')" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "id": "6bab68ba-0d49-4c2b-adb7-374ca7b0491f", + "metadata": {}, + "outputs": [], + "source": [ + "#To Do: Run your algorithm with the intuitive mapping for the above CNOT circuit" + ] + }, + { + "cell_type": "markdown", + "id": "b0e66068-fe20-4571-98ee-8896a3f94513", + "metadata": {}, + "source": [ + "## 5.1 (c)" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "id": "7fd9821e-a2fd-4767-8c48-89f210ddbd87", + "metadata": {}, + "outputs": [], + "source": [ + "mapping_2 = [(0,1), (1,0), (2,2), (3,3)]\n", + "\n", + "#To Do: Run the algorithm with an other mapping" + ] + }, + { + "cell_type": "markdown", + "id": "8cd54e30-0755-42d5-8bef-2d374bf9a986", + "metadata": {}, + "source": [ + "## 5.1 (d)" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "id": "c0ca6a90-ef9b-4946-b536-7db9de7ad9a3", + "metadata": {}, + "outputs": [], + "source": [ + "mapping_3 = [(0,0), (1,2), (2,1), (3,3)]\n", + "\n", + "#To Do: Run the algorithm with an other mapping" + ] + } + ], + "metadata": { + "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.12.3" + } + }, + "nbformat": 4, + "nbformat_minor": 5 +}