cirq.two_qubit_matrix_to_diagonal_and_cz_operations
Decomposes a 2-qubit unitary to a diagonal and the remaining operations.
cirq.two_qubit_matrix_to_diagonal_and_cz_operations(
q0: 'cirq.Qid',
q1: 'cirq.Qid',
mat: np.ndarray,
allow_partial_czs: bool = False,
atol: float = 1e-08,
clean_operations: bool = True
) -> Tuple[np.ndarray, List['cirq.Operation']]
For a 2-qubit unitary V, return ops, a list of operations and
D diagonal unitary, so that:
V = cirq.Circuit(ops) @ D
Args |
q0
|
The first qubit being operated on.
|
q1
|
The other qubit being operated on.
|
mat
|
the input unitary
|
allow_partial_czs
|
Enables the use of Partial-CZ gates.
|
atol
|
A limit on the amount of absolute error introduced by the
construction.
|
clean_operations
|
Enables optimizing resulting operation list by
merging operations and ejecting phased Paulis and Z operations.
|
Returns |
tuple
|
ops,D
operations ops , and the diagonal D
|
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2024-06-27 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2024-06-27 UTC."],[],[]]