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 @author: Peter Rakyta, Ph.D. 26 from scipy.stats
import unitary_group
27 from squander
import utils
34 This method is called to create custom gate structure for the decomposition on IBM QX2 38 from squander
import Circuit
42 Circuit_ret = Circuit( qbit_num )
46 disentangle_qbit = qbit_num - 1
51 for qbit
in range(0, disentangle_qbit ):
55 Layer = Circuit( qbit_num )
64 Layer.add_U3( 0, Theta, Phi, Lambda )
65 Layer.add_U3( disentangle_qbit, Theta, Phi, Lambda )
68 Layer.add_CNOT( 0, disentangle_qbit)
77 Layer.add_U3( 0, Theta, Phi, Lambda )
78 Layer.add_U3( 1, Theta, Phi, Lambda )
91 Layer.add_U3( 2, Theta, Phi, Lambda )
92 Layer.add_U3( disentangle_qbit, Theta, Phi, Lambda )
95 Layer.add_CNOT( 2, disentangle_qbit )
99 Circuit_ret.add_Circuit( Layer )
107 from squander
import N_Qubit_Decomposition
116 matrix_size =
int(2**qbit_num)
119 Umtx = unitary_group.rvs(matrix_size)
124 decomp = N_Qubit_Decomposition( Umtx.conj().T )
129 reordered_qbits = (0,1,3,2)
132 decomp.Reorder_Qubits( reordered_qbits )
141 decomp.set_Gate_Structure( gate_structure )
146 decomp.set_Max_Layer_Num( {4: 60, 3:16} )
151 decomp.set_Optimization_Blocks( 20 )
156 decomp.Start_Decomposition()
161 revert_qbits = (1,0,2,3)
164 decomp.Reorder_Qubits( revert_qbits )
174 quantum_circuit = decomp.get_Qiskit_Circuit()
177 import numpy.linalg
as LA
180 decomposed_matrix = utils.get_unitary_from_qiskit_circuit( quantum_circuit )
181 product_matrix = np.dot(Umtx,decomposed_matrix.conj().T)
182 phase = np.angle(product_matrix[0,0])
183 product_matrix = product_matrix*np.exp(-1j*phase)
185 product_matrix = np.eye(matrix_size)*2 - product_matrix - product_matrix.conj().T
187 decomposition_error = (np.real(np.trace(product_matrix)))/2
189 print(
'The error of the decomposition is ' + str(decomposition_error))
def create_custom_gate_structure_QX2(qbit_num)