Decompose a square matrix into a sequence of Givens rotations.
View aliases
Main aliases
openfermion.givens_decomposition_square
, openfermion.linalg.givens_rotations.givens_decomposition_square
openfermion.linalg.givens_decomposition_square(
unitary_matrix, always_insert=False
)
Used in the notebooks
Used in the tutorials |
---|
The input is a square n×n matrix Q. Q can be decomposed as follows:
Q=DU
where U is unitary and D is diagonal. Furthermore, we can decompose U as
U=Gk...G1
where G1,…,Gk are complex Givens rotations. A Givens rotation is a rotation within the two-dimensional subspace spanned by two coordinate axes. Within the two relevant coordinate axes, a Givens rotation has the form
(cos(θ)−eiφsin(θ)sin(θ)eiφcos(θ)).
Returns
decomposition (list[tuple]):
A list of tuples of objects describing Givens
rotations. The list looks like [(G_1, ), (G_2, G_3), ... ].
The Givens rotations within a tuple can be implemented in parallel.
The description of a Givens rotation is itself a tuple of the
form \\((i, j, \theta, \varphi)\\), which represents a
Givens rotation of coordinates
\\(i\\) and \\(j\\) by angles \\(\theta\\) and
\\(\varphi\\).
diagonal (ndarray):
A list of the nonzero entries of \\(D\\).