3 Created on Fri Jun 26 14:42:56 2020 4 Copyright 2020 Peter Rakyta, Ph.D. 6 Licensed under the Apache License, Version 2.0 (the "License"); 7 you may not use this file except in compliance with the License. 8 You may obtain a copy of the License at 10 http://www.apache.org/licenses/LICENSE-2.0 12 Unless required by applicable law or agreed to in writing, software 13 distributed under the License is distributed on an "AS IS" BASIS, 14 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 See the License for the specific language governing permissions and 16 limitations under the License. 18 You should have received a copy of the GNU General Public License 19 along with this program. If not, see http://www.gnu.org/licenses/. 21 @author: Peter Rakyta, Ph.D. 29 from scipy.stats
import unitary_group
31 from squander
import utils
34 from mpi4py
import MPI
36 except ModuleNotFoundError:
41 """This is a test class of the python iterface to the decompsition classes of the QGD package""" 45 This method is called by pytest. 46 Test to create an instance of class N_Qubit_Decomposition. 50 from squander
import N_Qubit_Decomposition
56 matrix_size =
int(2**qbit_num)
59 Umtx = unitary_group.rvs(matrix_size)
66 This method is called by pytest. 67 Test to decompose a 3-qubit unitary 71 from squander
import N_Qubit_Decomposition
77 matrix_size =
int(2**qbit_num)
80 Umtx = unitary_group.rvs(matrix_size)
86 decomp.Start_Decomposition()
92 This method is called by pytest. 93 Test to decompose a 2-qubit unitary and retrive the corresponding Qiskit circuit 97 from squander
import N_Qubit_Decomposition
103 matrix_size =
int(2**qbit_num)
106 Umtx = unitary_group.rvs(matrix_size)
112 decomp.set_Optimization_Blocks( 20 )
115 decomp.set_Verbose( 3 )
118 decomp.set_Debugfile(
"debugfile.txt" )
121 decomp.Start_Decomposition()
124 quantum_circuit = decomp.get_Qiskit_Circuit()
130 print(quantum_circuit)
132 import numpy.linalg
as LA
137 decomposed_matrix = np.asarray( utils.get_unitary_from_qiskit_circuit( quantum_circuit ) )
138 product_matrix = np.dot(Umtx,decomposed_matrix.conj().T)
139 phase = np.angle(product_matrix[0,0])
140 product_matrix = product_matrix*np.exp(-1j*phase)
142 product_matrix = np.eye(matrix_size)*2 - product_matrix - product_matrix.conj().T
144 decomposition_error = (np.real(np.trace(product_matrix)))/2
146 print(
'The error of the decomposition is ' + str(decomposition_error))
148 assert( decomposition_error < 1e-3 )
def test_N_Qubit_Decomposition_creation(self)
def test_N_Qubit_Decomposition_3qubit(self)
def test_N_Qubit_Decomposition_Qiskit_export(self)
A base class to determine the decomposition of an N-qubit unitary into a sequence of CNOT and U3 gate...