cirq.num_cnots_required
Returns the min number of CNOT/CZ gates required by a two-qubit unitary.
cirq.num_cnots_required(
u: np.ndarray, atol: float = 1e-08
) -> int
See Proposition III.1, III.2, III.3 in Shende et al. “Recognizing Small-
Circuit Structure in Two-Qubit Operators and Timing Hamiltonians to Compute
Controlled-Not Gates”. https://arxiv.org/abs/quant-ph/0308045
Args |
u
|
A two-qubit unitary.
|
atol
|
The absolute tolerance used to make this judgement.
|
Returns |
The number of CNOT or CZ gates required to implement the unitary.
|
Raises |
ValueError
|
If the shape of u is not 4 by 4.
|
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."],[],[]]