f06tmf performs the transformation
where
is an
by
complex Hermitian matrix, and
is a complex unitary matrix defined as a sequence of plane rotations,
, applied in planes
to
.
The
by
plane rotation part of
is assumed to have the form
with
real.
None.
-
1:
– Character(1)
Input
-
On entry: specifies whether the upper or lower triangular part of
is stored.
- The upper triangular part of is stored.
- The lower triangular part of is stored.
Constraint:
or .
-
2:
– Character(1)
Input
-
On entry: specifies the plane rotated by
.
- (variable pivot)
- rotates the plane.
- (top pivot)
- rotates the plane.
- (bottom pivot)
- rotates the plane.
Constraint:
, or .
-
3:
– Character(1)
Input
-
On entry: specifies the sequence direction.
- (forward sequence)
- .
- (backward sequence)
- .
Constraint:
or .
-
4:
– Integer
Input
-
On entry: , the order of the matrix .
Constraint:
.
-
5:
– Integer
Input
-
6:
– Integer
Input
-
On entry: the values
and
.
If or or , an immediate return is effected.
-
7:
– Real (Kind=nag_wp) array
Input
-
Note: the dimension of the array
c
must be at least
.
On entry: must hold , the cosine of the rotation , for .
-
8:
– Complex (Kind=nag_wp) array
Input
-
Note: the dimension of the array
s
must be at least
.
On entry: must hold , the sine of the rotation , for .
-
9:
– Complex (Kind=nag_wp) array
Input/Output
-
Note: the second dimension of the array
a
must be at least
.
On entry: the
by
Hermitian matrix
.
- If , the upper triangular part of must be stored and the elements of the array below the diagonal are not referenced.
- If , the lower triangular part of must be stored and the elements of the array above the diagonal are not referenced.
On exit: the transformed matrix . The imaginary parts of the diagonal elements are set to zero.
-
10:
– Integer
Input
-
On entry: the first dimension of the array
a as declared in the (sub)program from which
f06tmf is called.
Constraint:
.
None.
Not applicable.
None.
None.