nag_zunglq (f08awc) generates all or part of the complex unitary matrix
from an
factorization computed by
nag_zgelqf (f08avc).
nag_zunglq (f08awc) is intended to be used after a call to
nag_zgelqf (f08avc), which performs an
factorization of a complex matrix
. The unitary matrix
is represented as a product of elementary reflectors.
Usually
is determined from the
factorization of a
by
matrix
with
. The whole of
may be computed by:
nag_zunglq(order,n,n,p,&a,pda,tau,&fail)
(note that the array
a must have at least
rows) or its leading
rows by:
nag_zunglq(order,p,n,p,&a,pda,tau,&fail)
The rows of
returned by the last call form an orthonormal basis for the space spanned by the rows of
; thus
nag_zgelqf (f08avc) followed by nag_zunglq (f08awc) can be used to orthogonalise the rows of
.
The information returned by the
factorization functions also yields the
factorization of the leading
rows of
, where
. The unitary matrix arising from this factorization can be computed by:
nag_zunglq(order,n,n,k,&a,pda,tau,&fail)
or its leading
rows by:
nag_zunglq(order,k,n,k,&a,pda,tau,&fail)
- NE_ALLOC_FAIL
Dynamic memory allocation failed.
- NE_BAD_PARAM
On entry, argument had an illegal value.
- NE_INT
On entry, .
Constraint: .
On entry, .
Constraint: .
- NE_INT_2
On entry, and .
Constraint: .
On entry, and .
Constraint: .
On entry, and .
Constraint: .
On entry, and .
Constraint: .
- NE_INTERNAL_ERROR
An internal error has occurred in this function. Check the function call and any array sizes. If the call is correct then please contact
NAG for assistance.
The computed matrix
differs from an exactly unitary matrix by a matrix
such that
where
is the
machine precision.
The real analogue of this function is
nag_dorglq (f08ajc).
This example forms the leading
rows of the unitary matrix
from the
factorization of the matrix
, where
The rows of
form an orthonormal basis for the space spanned by the rows of
.