當前位置: 首頁>>代碼示例>>Python>>正文


Python qiskit.transpile方法代碼示例

本文整理匯總了Python中qiskit.transpile方法的典型用法代碼示例。如果您正苦於以下問題:Python qiskit.transpile方法的具體用法?Python qiskit.transpile怎麽用?Python qiskit.transpile使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在qiskit的用法示例。


在下文中一共展示了qiskit.transpile方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_parameter_setter_from_automatic_repetition

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_parameter_setter_from_automatic_repetition(self, params):
        """Test getting and setting of the nlocal parameters."""
        circuit = QuantumCircuit(2)
        circuit.ry(Parameter('a'), 0)
        circuit.crx(Parameter('b'), 0, 1)

        # repeat circuit and check that parameters are duplicated
        reps = 3
        nlocal = NLocal(2, entanglement_blocks=circuit, reps=reps)
        nlocal.assign_parameters(params, inplace=True)

        param_set = set(p for p in params if isinstance(p, ParameterExpression))
        with self.subTest(msg='Test the parameters of the non-transpiled circuit'):
            # check the parameters of the final circuit
            self.assertEqual(nlocal.parameters, param_set)

        with self.subTest(msg='Test the parameters of the transpiled circuit'):
            basis_gates = ['id', 'u1', 'u2', 'u3', 'cx']
            transpiled_circuit = transpile(nlocal, basis_gates=basis_gates)
            self.assertEqual(transpiled_circuit.parameters, param_set) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:22,代碼來源:test_library.py

示例2: test_parameters_setter

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_parameters_setter(self, params):
        """Test setting the parameters via list."""
        # construct circuit with some parameters
        initial_params = ParameterVector('p', length=6)
        circuit = QuantumCircuit(1)
        for i, initial_param in enumerate(initial_params):
            circuit.ry(i * initial_param, 0)

        # create an NLocal from the circuit and set the new parameters
        nlocal = NLocal(1, entanglement_blocks=circuit, reps=1)
        nlocal.assign_parameters(params, inplace=True)

        param_set = set(p for p in params if isinstance(p, ParameterExpression))
        with self.subTest(msg='Test the parameters of the non-transpiled circuit'):
            # check the parameters of the final circuit
            self.assertEqual(nlocal.parameters, param_set)

        with self.subTest(msg='Test the parameters of the transpiled circuit'):
            basis_gates = ['id', 'u1', 'u2', 'u3', 'cx']
            transpiled_circuit = transpile(nlocal, basis_gates=basis_gates)
            self.assertEqual(transpiled_circuit.parameters, param_set) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:23,代碼來源:test_library.py

示例3: setup

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def setup(self, rb_pattern, _, __):
        length_vector = np.arange(1, 200, 4)
        nseeds = 1
        self.seed = 10
        self.circuits = build_rb_circuit(nseeds=nseeds,
                                         length_vector=length_vector,
                                         rb_pattern=rb_pattern,
                                         seed=self.seed)
        self.sim_backend = Aer.get_backend('qasm_simulator')
        trans_circ = transpile(self.circuits, backend=self.sim_backend,
                               seed_transpiler=self.seed)
        self.qobj = assemble(trans_circ, backend=self.sim_backend) 
開發者ID:Qiskit,項目名稱:qiskit-aer,代碼行數:14,代碼來源:randomized_benchmarking.py

示例4: equivalent_transpile

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def equivalent_transpile(self, backend, opt_level):
        """Simulate, transpile and simulate the present circuit. Verify that the
        counts are not significantly different before and after transpilation.

        """

        print('Evaluating circuit at level {} on {}:\n{}'.format(
            opt_level, backend, self.qc.qasm()))

        assume(backend is None or backend.configuration().n_qubits >= len(self.qc.qubits))

        shots = 4096

        aer_counts = execute(self.qc, backend=self.backend,
                             shots=shots).result().get_counts()

        try:
            xpiled_qc = transpile(self.qc, backend=backend, optimization_level=opt_level)
        except Exception as e:
            failed_qasm = 'Exception caught during transpilation of circuit: \n{}'.format(
                self.qc.qasm())
            raise RuntimeError(failed_qasm) from e

        xpiled_aer_counts = execute(xpiled_qc, backend=self.backend,
                                    shots=shots).result().get_counts()

        count_differences = dicts_almost_equal(aer_counts, xpiled_aer_counts, 0.05 * shots)

        assert count_differences == '', 'Counts not equivalent: {}\nFailing QASM: \n{}'.format(
            count_differences, self.qc.qasm()) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:32,代碼來源:test_transpiler_equivalence.py

示例5: test_cz_optimization

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_cz_optimization(self):
        """ Test that KAK does not run on a cz gate """
        qr = QuantumRegister(2)
        qc = QuantumCircuit(qr)

        qc.cz(qr[0], qr[1])

        cz_circ = transpile(qc, None, coupling_map=[[0, 1], [1, 0]],
                            basis_gates=['u1', 'u2', 'u3', 'id', 'cx'],
                            optimization_level=3)
        ops = cz_circ.count_ops()
        self.assertEqual(ops['u2'], 2)
        self.assertEqual(ops['cx'], 1)
        self.assertFalse('u3' in ops.keys()) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:16,代碼來源:test_kak_over_optimization.py

示例6: test_cu1_optimization

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_cu1_optimization(self):
        """ Test that KAK does run on a cu1 gate and
        reduces the cx count from two to one.
        """
        qr = QuantumRegister(2)
        qc = QuantumCircuit(qr)

        qc.cu1(np.pi, qr[0], qr[1])

        cu1_circ = transpile(qc, None, coupling_map=[[0, 1], [1, 0]],
                             basis_gates=['u1', 'u2', 'u3', 'id', 'cx'],
                             optimization_level=3)
        ops = cu1_circ.count_ops()
        self.assertEqual(ops['cx'], 1) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:16,代碼來源:test_kak_over_optimization.py

示例7: test_max_number_cnots

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_max_number_cnots(self):
        """
        Check if the number of cnots <= 2^(n+1) - 2n (arXiv:quant-ph/0406176)
        """
        num_qubits = 4
        _optimization_level = 0

        vector = np.array(
            [0.1314346 + 0.j, 0.32078572 - 0.01542775j, 0.13146466 + 0.0945312j,
             0.21090852 + 0.07935982j, 0.1700122 - 0.07905648j, 0.15570757 - 0.12309154j,
             0.18039667 + 0.04904504j, 0.22227187 - 0.05055569j, 0.23573255 - 0.09894111j,
             0.27307292 - 0.10372994j, 0.24162792 + 0.1090791j, 0.3115577 + 0.1211683j,
             0.1851788 + 0.08679141j, 0.36226463 - 0.09940202j, 0.13863395 + 0.10558225j,
             0.30767986 + 0.02073838j])

        vector = vector / np.linalg.norm(vector)

        qr = QuantumRegister(num_qubits, 'qr')
        circuit = QuantumCircuit(qr)
        circuit.initialize(vector, qr)

        b = transpile(circuit, basis_gates=['u1', 'u2', 'u3', 'cx'],
                      optimization_level=_optimization_level)

        number_cnots = b.count_ops()['cx']
        max_cnots = 2 ** (num_qubits + 1) - 2 * num_qubits

        self.assertLessEqual(number_cnots, max_cnots) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:30,代碼來源:test_initializer.py

示例8: assertCircuitEqual

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def assertCircuitEqual(self, qc1, qc2, visual=False, transpiled=True):
        """An equality test specialized to circuits."""
        if transpiled:
            basis_gates = ['id', 'u1', 'u3', 'cx']
            qc1_transpiled = transpile(qc1, basis_gates=basis_gates, optimization_level=0)
            qc2_transpiled = transpile(qc2, basis_gates=basis_gates, optimization_level=0)
            qc1, qc2 = qc1_transpiled, qc2_transpiled

        if visual:
            self.assertEqual(qc1.draw(), qc2.draw())
        else:
            self.assertEqual(qc1, qc2) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:14,代碼來源:test_library.py

示例9: time_transpile_simulator_ripple_adder

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def time_transpile_simulator_ripple_adder(self, _, level):
        transpile(self.circuit, self.sim_backend,
                  optimization_level=level) 
開發者ID:Qiskit,項目名稱:qiskit,代碼行數:5,代碼來源:ripple_adder.py

示例10: peakmem_transpile_simulator_ripple_adder

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def peakmem_transpile_simulator_ripple_adder(self, _, level):
        transpile(self.circuit, self.sim_backend,
                  optimization_level=level) 
開發者ID:Qiskit,項目名稱:qiskit,代碼行數:5,代碼來源:ripple_adder.py

示例11: track_depth_transpile_simulator_ripple_adder

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def track_depth_transpile_simulator_ripple_adder(self, _, level):
        return transpile(self.circuit, self.sim_backend,
                         optimization_level=level).depth() 
開發者ID:Qiskit,項目名稱:qiskit,代碼行數:5,代碼來源:ripple_adder.py

示例12: time_transpile_square_grid_ripple_adder

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def time_transpile_square_grid_ripple_adder(self, _, level):
        transpile(self.circuit,
                  coupling_map=self.coupling_map,
                  basis_gates=['u1', 'u2', 'u3', 'cx', 'id'],
                  optimization_level=level) 
開發者ID:Qiskit,項目名稱:qiskit,代碼行數:7,代碼來源:ripple_adder.py

示例13: peakmem_transpile_square_grid_ripple_adder

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def peakmem_transpile_square_grid_ripple_adder(self, _, level):
        transpile(self.circuit,
                  coupling_map=self.coupling_map,
                  basis_gates=['u1', 'u2', 'u3', 'cx', 'id'],
                  optimization_level=level) 
開發者ID:Qiskit,項目名稱:qiskit,代碼行數:7,代碼來源:ripple_adder.py

示例14: test_after_transpile

# 需要導入模塊: import qiskit [as 別名]
# 或者: from qiskit import transpile [as 別名]
def test_after_transpile(self):
        """After transpile, the drawing should include the layout"""
        expected = '\n'.join([
            "                 ┌──────────┐┌──────────┐┌───┐┌──────────┐┌─┐   ",
            "   userqr_0 -> 0 ┤ U2(0,pi) ├┤ U2(0,pi) ├┤ X ├┤ U2(0,pi) ├┤M├───",
            "                 ├──────────┤├──────────┤└─┬─┘├──────────┤└╥┘┌─┐",
            "   userqr_1 -> 1 ┤ U2(0,pi) ├┤ U2(0,pi) ├──■──┤ U2(0,pi) ├─╫─┤M├",
            "                 └──────────┘└──────────┘     └──────────┘ ║ └╥┘",
            "  ancilla_0 -> 2 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_1 -> 3 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_2 -> 4 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_3 -> 5 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_4 -> 6 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_5 -> 7 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_6 -> 8 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "  ancilla_7 -> 9 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            " ancilla_8 -> 10 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            " ancilla_9 -> 11 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "ancilla_10 -> 12 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "ancilla_11 -> 13 ──────────────────────────────────────────╫──╫─",
            "                                                           ║  ║ ",
            "           c0_0: ══════════════════════════════════════════╩══╬═",
            "                                                              ║ ",
            "           c0_1: ═════════════════════════════════════════════╩═",
            "                                                                "])

        qr = QuantumRegister(2, 'userqr')
        cr = ClassicalRegister(2, 'c0')
        qc = QuantumCircuit(qr, cr)
        qc.h(qr)
        qc.cx(qr[0], qr[1])
        qc.measure(qr, cr)

        coupling_map = [[1, 0], [1, 2], [2, 3], [4, 3], [4, 10], [5, 4], [5, 6], [5, 9], [6, 8],
                        [7, 8], [9, 8], [9, 10], [11, 3], [11, 10], [11, 12], [12, 2], [13, 1],
                        [13, 12]]
        qc_result = transpile(qc, basis_gates=['u1', 'u2', 'u3', 'cx', 'id'],
                              coupling_map=coupling_map, optimization_level=0, seed_transpiler=0)
        self.assertEqual(qc_result.draw(output='text', cregbundle=False).single_string(), expected) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:52,代碼來源:test_circuit_text_drawer.py


注:本文中的qiskit.transpile方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。