openfermion.linalg.givens_decomposition_square

Decompose a square matrix into a sequence of Givens rotations.

Main aliases

openfermion.givens_decomposition_square, openfermion.linalg.givens_rotations.givens_decomposition_square

Used in the notebooks

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(θ)).

unitary_matrix A numpy array with orthonormal rows, representing the matrix Q.

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\\).