NAG FL Interface
f06sgf (ztbmv)

1 Purpose

f06sgf computes the matrix-vector product for a complex triangular band matrix, its transpose or its conjugate transpose.

2 Specification

Fortran Interface
Subroutine f06sgf ( uplo, trans, diag, n, k, a, lda, x, incx)
Integer, Intent (In) :: n, k, lda, incx
Complex (Kind=nag_wp), Intent (In) :: a(lda,*)
Complex (Kind=nag_wp), Intent (Inout) :: x(*)
Character (1), Intent (In) :: uplo, trans, diag
C Header Interface
#include <nag.h>
void  f06sgf_ (const char *uplo, const char *trans, const char *diag, const Integer *n, const Integer *k, const Complex a[], const Integer *lda, Complex x[], const Integer *incx, const Charlen length_uplo, const Charlen length_trans, const Charlen length_diag)
The routine may be called by the names f06sgf, nagf_blas_ztbmv or its BLAS name ztbmv.

3 Description

f06sgf performs one of the matrix-vector operations
xAx ,   xATx   or   xAHx ,  
where A is an n by n complex triangular band matrix with k subdiagonals or superdiagonals, and x is an n-element complex vector.

4 References

None.

5 Arguments

1: uplo Character(1) Input
On entry: specifies whether A is upper or lower triangular.
uplo='U'
A is upper triangular.
uplo='L'
A is lower triangular.
Constraint: uplo='U' or 'L'.
2: trans Character(1) Input
On entry: specifies the operation to be performed.
trans='N'
xAx.
trans='T'
xATx.
trans='C'
xAHx.
Constraint: trans='N', 'T' or 'C'.
3: diag Character(1) Input
On entry: specifies whether A has nonunit or unit diagonal elements.
diag='N'
The diagonal elements are stored explicitly.
diag='U'
The diagonal elements are assumed to be 1, and are not referenced.
Constraint: diag='N' or 'U'.
4: n Integer Input
On entry: n, the order of the matrix A.
Constraint: n0.
5: k Integer Input
On entry: k, the number of subdiagonals or superdiagonals of the matrix A.
Constraint: k0.
6: alda* Complex (Kind=nag_wp) array Input
Note: the second dimension of the array a must be at least n.
On entry: the n by n triangular band matrix A
The matrix is stored in rows 1 to k+1, more precisely,
  • if uplo='U', the elements of the upper triangle of A within the band must be stored with element Aij in ak+1+i-jj​ for ​max1,j-kij;
  • if uplo='L', the elements of the lower triangle of A within the band must be stored with element Aij in a1+i-jj​ for ​jiminn,j+k.
If diag='U', the diagonal elements of A are assumed to be 1, and are not referenced.
7: lda Integer Input
On entry: the first dimension of the array a as declared in the (sub)program from which f06sgf is called.
Constraint: ldak+1.
8: x* Complex (Kind=nag_wp) array Input/Output
Note: the dimension of the array x must be at least max1, 1+n-1 ×incx .
On entry: the vector x.
If incx>0, xi must be stored in x1+i1×incx , for i=1,2,,n.
If incx<0, xi must be stored in x1ni×incx , for i=1,2,,n.
On exit: the updated vector x stored in the array elements used to supply the original vector x.
9: incx Integer Input
On entry: the increment in the subscripts of x between successive elements of x.
Constraint: incx0.

6 Error Indicators and Warnings

None.

7 Accuracy

Not applicable.

8 Parallelism and Performance

f06sgf is not threaded in any implementation.

9 Further Comments

None.

10 Example

None.