A verifiable quantum advantage towards real world applications: Quantum Echoes 
Learn more
         
     
  
  
  
  
  
    
      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 2025-08-14 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 2025-08-14 UTC."],[],[]]