Code source de qiskit.circuit.library.templates.rzx.rzx_xz

# This code is part of Qiskit.
#
# (C) Copyright IBM 2021.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
#
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals.

"""
RZX based template for CX - RXGate - CX
.. parsed-literal::
     β”Œβ”€β”€β”€β”         β”Œβ”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Β»
q_0: ─ X β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€ X β”œβ”€ RZ(Ο€/2) β”œβ”€ RX(Ο€/2) β”œβ”€ RZ(Ο€/2) β”œβ”€0         β”œΒ»
     β””β”€β”¬β”€β”˜β”Œβ”€β”€β”€β”€β”€β”€β”€β”β””β”€β”¬β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β”‚  RZX(-Ο΄) β”‚Β»
q_1: ──■─── RX(Ο΄) β”œβ”€β”€β– β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€1         β”œΒ»
          β””β”€β”€β”€β”€β”€β”€β”€β”˜                                      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜Β»
Β«     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
Β«q_0: ─ RZ(Ο€/2) β”œβ”€ RX(Ο€/2) β”œβ”€ RZ(Ο€/2) β”œ
Β«     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
Β«q_1: ─────────────────────────────────
Β«
"""

from __future__ import annotations

import numpy as np

from qiskit.circuit import Parameter, QuantumCircuit
from qiskit.circuit.parameterexpression import ParameterValueType


[docs]def rzx_xz(theta: ParameterValueType | None = None): """Template for CX - RXGate - CX.""" if theta is None: theta = Parameter("Ο΄") qc = QuantumCircuit(2) qc.cx(1, 0) qc.rx(theta, 1) qc.cx(1, 0) qc.rz(np.pi / 2, 0) qc.rx(np.pi / 2, 0) qc.rz(np.pi / 2, 0) qc.rzx(-1 * theta, 0, 1) qc.rz(np.pi / 2, 0) qc.rx(np.pi / 2, 0) qc.rz(np.pi / 2, 0) return qc