cirq.bidiagonalize_unitary_with_special_orthogonals
Finds orthogonal matrices L, R such that L @ matrix @ R is diagonal.
cirq.bidiagonalize_unitary_with_special_orthogonals(
mat: np.ndarray,
*,
rtol: float = 1e-05,
atol: float = 1e-08,
check_preconditions: bool = True
) -> Tuple[np.ndarray, np.ndarray, np.ndarray]
Args |
mat
|
A unitary matrix.
|
rtol
|
Relative numeric error threshold.
|
atol
|
Absolute numeric error threshold.
|
check_preconditions
|
If set, verifies that the input is a unitary matrix
(to the given tolerances). Defaults to set.
|
Returns |
A triplet (L, d, R) such that L @ mat @ R = diag(d). Both L and R will
be orthogonal matrices with determinant equal to 1.
|
Raises |
ValueError
|
Matrices don't meet preconditions (e.g. not real).
|
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."],[],[]]