dgbbrd - reduce a real general m-by-n band matrix A to upper bidiagonal form B by an orthogonal transformation
SUBROUTINE DGBBRD( VECT, M, N, NCC, KL, KU, AB, LDAB, D, E, Q, LDQ, * PT, LDPT, C, LDC, WORK, INFO) CHARACTER * 1 VECT INTEGER M, N, NCC, KL, KU, LDAB, LDQ, LDPT, LDC, INFO DOUBLE PRECISION AB(LDAB,*), D(*), E(*), Q(LDQ,*), PT(LDPT,*), C(LDC,*), WORK(*)
SUBROUTINE DGBBRD_64( VECT, M, N, NCC, KL, KU, AB, LDAB, D, E, Q, * LDQ, PT, LDPT, C, LDC, WORK, INFO) CHARACTER * 1 VECT INTEGER*8 M, N, NCC, KL, KU, LDAB, LDQ, LDPT, LDC, INFO DOUBLE PRECISION AB(LDAB,*), D(*), E(*), Q(LDQ,*), PT(LDPT,*), C(LDC,*), WORK(*)
SUBROUTINE GBBRD( VECT, [M], [N], [NCC], KL, KU, AB, [LDAB], D, E, * Q, [LDQ], PT, [LDPT], C, [LDC], [WORK], [INFO]) CHARACTER(LEN=1) :: VECT INTEGER :: M, N, NCC, KL, KU, LDAB, LDQ, LDPT, LDC, INFO REAL(8), DIMENSION(:) :: D, E, WORK REAL(8), DIMENSION(:,:) :: AB, Q, PT, C
SUBROUTINE GBBRD_64( VECT, [M], [N], [NCC], KL, KU, AB, [LDAB], D, * E, Q, [LDQ], PT, [LDPT], C, [LDC], [WORK], [INFO]) CHARACTER(LEN=1) :: VECT INTEGER(8) :: M, N, NCC, KL, KU, LDAB, LDQ, LDPT, LDC, INFO REAL(8), DIMENSION(:) :: D, E, WORK REAL(8), DIMENSION(:,:) :: AB, Q, PT, C
#include <sunperf.h>
void dgbbrd(char vect, int m, int n, int ncc, int kl, int ku, double *ab, int ldab, double *d, double *e, double *q, int ldq, double *pt, int ldpt, double *c, int ldc, int *info);
void dgbbrd_64(char vect, long m, long n, long ncc, long kl, long ku, double *ab, long ldab, double *d, double *e, double *q, long ldq, double *pt, long ldpt, double *c, long ldc, long *info);
dgbbrd reduces a real general m-by-n band matrix A to upper bidiagonal form B by an orthogonal transformation: Q' * A * P = B.
The routine computes B, and optionally forms Q or P', or computes Q'*C for a given matrix C.
= 'Q': form Q only;
= 'P': form P' only;
= 'B': form both.
AB(ku+1+i-j,j)
= A(i,j)
for max(1,j-ku)
< =i < =min(m,j+kl).
On exit, A is overwritten by values generated during the
reduction.
max(1,M)
if VECT = 'Q' or 'B'; LDQ > = 1 otherwise.
max(1,N)
if VECT = 'P' or 'B'; LDPT > = 1 otherwise.
max(1,M)
if NCC > 0; LDC > = 1 if NCC = 0.
dimension(MAX(M,N))
= 0: successful exit.
< 0: if INFO = -i, the i-th argument had an illegal value.