Code source de qiskit.circuit.library.templates.rzx.rzx_zz1
# 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 - phase - CX
.. parsed-literal::
Β»
q_0: βββ βββββββββββββββββββββββββββββββββββββββββββββ βββββββββββββββββββββββΒ»
βββ΄βββββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββΒ»
q_1: β€ X ββ€ RZ(Ο΄) ββ€ βX ββ€ RZ(Ο) ββ€ βX ββ€ RZ(3Ο) ββ€ X ββ€ RZ(-Ο΄) ββ€ RZ(Ο/2) βΒ»
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββΒ»
Β« ββββββββββββ Β»
Β«q_0: ββββββββββββββββββββββββββββββββ€0 βββββββββββββββββββββββΒ»
Β« ββββββββββββββββββββββββββββββββ RZX(-Ο΄) βββββββββββββββββββββββΒ»
Β«q_1: β€ RX(Ο/2) ββ€ RZ(Ο/2) ββ€ RX(Ο΄) ββ€1 ββ€ RZ(Ο/2) ββ€ RX(Ο/2) βΒ»
Β« βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββΒ»
Β«
Β«q_0: βββββββββββ
Β« βββββββββββ
Β«q_1: β€ RZ(Ο/2) β
Β« βββββββββββ
"""
from __future__ import annotations
import numpy as np
from qiskit.circuit import Parameter, QuantumCircuit
from qiskit.circuit.parameterexpression import ParameterValueType
[docs]def rzx_zz1(theta: ParameterValueType | None = None):
"""Template for CX - RZGate - CX."""
if theta is None:
theta = Parameter("Ο΄")
qc = QuantumCircuit(2)
qc.cx(0, 1)
qc.rz(theta, 1)
qc.sx(1)
qc.rz(np.pi, 1)
qc.sx(1)
qc.rz(3 * np.pi, 1)
qc.cx(0, 1)
qc.rz(-1 * theta, 1)
# Hadamard
qc.rz(np.pi / 2, 1)
qc.rx(np.pi / 2, 1)
qc.rz(np.pi / 2, 1)
qc.rx(theta, 1)
qc.rzx(-1 * theta, 0, 1)
# Hadamard
qc.rz(np.pi / 2, 1)
qc.rx(np.pi / 2, 1)
qc.rz(np.pi / 2, 1)
return qc