DGSVTS
   Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd..
November 2006
November 2006
Purpose
DGSVTS tests DGGSVD, which computes the GSVD of an M-by-N matrix A
and a P-by-N matrix B:
U'*A*Q = D1*R and V'*B*Q = D2*R.
and a P-by-N matrix B:
U'*A*Q = D1*R and V'*B*Q = D2*R.
Arguments
| M | 
(input) INTEGER
 
The number of rows of the matrix A.  M >= 0. | 
| P | 
(input) INTEGER
 
The number of rows of the matrix B.  P >= 0. | 
| N | 
(input) INTEGER
 
The number of columns of the matrices A and B.  N >= 0. | 
| A | 
(input) DOUBLE PRECISION array, dimension (LDA,M)
 
The M-by-N matrix A. | 
| AF | 
(output) DOUBLE PRECISION array, dimension (LDA,N)
 
Details of the GSVD of A and B, as returned by DGGSVD, see DGGSVD for further details. | 
| LDA | 
(input) INTEGER
 
The leading dimension of the arrays A and AF. LDA >= max( 1,M ). | 
| B | 
(input) DOUBLE PRECISION array, dimension (LDB,P)
 
On entry, the P-by-N matrix B. | 
| BF | 
(output) DOUBLE PRECISION array, dimension (LDB,N)
 
Details of the GSVD of A and B, as returned by DGGSVD, see DGGSVD for further details. | 
| LDB | 
(input) INTEGER
 
The leading dimension of the arrays B and BF. LDB >= max(1,P). | 
| U | 
(output) DOUBLE PRECISION array, dimension(LDU,M)
 
The M by M orthogonal matrix U. | 
| LDU | 
(input) INTEGER
 
The leading dimension of the array U. LDU >= max(1,M). | 
| V | 
(output) DOUBLE PRECISION array, dimension(LDV,M)
 
The P by P orthogonal matrix V. | 
| LDV | 
(input) INTEGER
 
The leading dimension of the array V. LDV >= max(1,P). | 
| Q | 
(output) DOUBLE PRECISION array, dimension(LDQ,N)
 
The N by N orthogonal matrix Q. | 
| LDQ | 
(input) INTEGER
 
The leading dimension of the array Q. LDQ >= max(1,N). | 
| ALPHA | 
(output) DOUBLE PRECISION array, dimension (N)
 | 
| BETA | 
(output) DOUBLE PRECISION array, dimension (N)
 
The generalized singular value pairs of A and B, the ``diagonal'' matrices D1 and D2 are constructed from ALPHA and BETA, see subroutine DGGSVD for details. | 
| R | 
(output) DOUBLE PRECISION array, dimension(LDQ,N)
 
The upper triangular matrix R. | 
| LDR | 
(input) INTEGER
 
The leading dimension of the array R. LDR >= max(1,N). | 
| IWORK | 
(workspace) INTEGER array, dimension (N)
 | 
| WORK | 
(workspace) DOUBLE PRECISION array, dimension (LWORK)
 | 
| LWORK | 
(input) INTEGER
 
The dimension of the array WORK, LWORK >= max(M,P,N)*max(M,P,N). | 
| RWORK | 
(workspace) DOUBLE PRECISION array, dimension (max(M,P,N))
 | 
| RESULT | 
(output) DOUBLE PRECISION array, dimension (6)
 
The test ratios: RESULT(1) = norm( U'*A*Q - D1*R ) / ( MAX(M,N)*norm(A)*ULP) RESULT(2) = norm( V'*B*Q - D2*R ) / ( MAX(P,N)*norm(B)*ULP) RESULT(3) = norm( I - U'*U ) / ( M*ULP ) RESULT(4) = norm( I - V'*V ) / ( P*ULP ) RESULT(5) = norm( I - Q'*Q ) / ( N*ULP ) RESULT(6) = 0 if ALPHA is in decreasing order; = ULPINV otherwise. |