summaryrefslogtreecommitdiff
path: root/TESTING/EIG/sbdt03.f
diff options
context:
space:
mode:
authorjason <jason@8a072113-8704-0410-8d35-dd094bca7971>2008-10-28 01:38:50 +0000
committerjason <jason@8a072113-8704-0410-8d35-dd094bca7971>2008-10-28 01:38:50 +0000
commitbaba851215b44ac3b60b9248eb02bcce7eb76247 (patch)
tree8c0f5c006875532a30d4409f5e94b0f310ff00a7 /TESTING/EIG/sbdt03.f
downloadlapack-baba851215b44ac3b60b9248eb02bcce7eb76247.tar.gz
lapack-baba851215b44ac3b60b9248eb02bcce7eb76247.tar.bz2
lapack-baba851215b44ac3b60b9248eb02bcce7eb76247.zip
Move LAPACK trunk into position.
Diffstat (limited to 'TESTING/EIG/sbdt03.f')
-rw-r--r--TESTING/EIG/sbdt03.f194
1 files changed, 194 insertions, 0 deletions
diff --git a/TESTING/EIG/sbdt03.f b/TESTING/EIG/sbdt03.f
new file mode 100644
index 00000000..ac676dba
--- /dev/null
+++ b/TESTING/EIG/sbdt03.f
@@ -0,0 +1,194 @@
+ SUBROUTINE SBDT03( UPLO, N, KD, D, E, U, LDU, S, VT, LDVT, WORK,
+ $ RESID )
+*
+* -- LAPACK test routine (version 3.1) --
+* Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd..
+* November 2006
+*
+* .. Scalar Arguments ..
+ CHARACTER UPLO
+ INTEGER KD, LDU, LDVT, N
+ REAL RESID
+* ..
+* .. Array Arguments ..
+ REAL D( * ), E( * ), S( * ), U( LDU, * ),
+ $ VT( LDVT, * ), WORK( * )
+* ..
+*
+* Purpose
+* =======
+*
+* SBDT03 reconstructs a bidiagonal matrix B from its SVD:
+* S = U' * B * V
+* where U and V are orthogonal matrices and S is diagonal.
+*
+* The test ratio to test the singular value decomposition is
+* RESID = norm( B - U * S * VT ) / ( n * norm(B) * EPS )
+* where VT = V' and EPS is the machine precision.
+*
+* Arguments
+* =========
+*
+* UPLO (input) CHARACTER*1
+* Specifies whether the matrix B is upper or lower bidiagonal.
+* = 'U': Upper bidiagonal
+* = 'L': Lower bidiagonal
+*
+* N (input) INTEGER
+* The order of the matrix B.
+*
+* KD (input) INTEGER
+* The bandwidth of the bidiagonal matrix B. If KD = 1, the
+* matrix B is bidiagonal, and if KD = 0, B is diagonal and E is
+* not referenced. If KD is greater than 1, it is assumed to be
+* 1, and if KD is less than 0, it is assumed to be 0.
+*
+* D (input) REAL array, dimension (N)
+* The n diagonal elements of the bidiagonal matrix B.
+*
+* E (input) REAL array, dimension (N-1)
+* The (n-1) superdiagonal elements of the bidiagonal matrix B
+* if UPLO = 'U', or the (n-1) subdiagonal elements of B if
+* UPLO = 'L'.
+*
+* U (input) REAL array, dimension (LDU,N)
+* The n by n orthogonal matrix U in the reduction B = U'*A*P.
+*
+* LDU (input) INTEGER
+* The leading dimension of the array U. LDU >= max(1,N)
+*
+* S (input) REAL array, dimension (N)
+* The singular values from the SVD of B, sorted in decreasing
+* order.
+*
+* VT (input) REAL array, dimension (LDVT,N)
+* The n by n orthogonal matrix V' in the reduction
+* B = U * S * V'.
+*
+* LDVT (input) INTEGER
+* The leading dimension of the array VT.
+*
+* WORK (workspace) REAL array, dimension (2*N)
+*
+* RESID (output) REAL
+* The test ratio: norm(B - U * S * V') / ( n * norm(A) * EPS )
+*
+* ======================================================================
+*
+* .. Parameters ..
+ REAL ZERO, ONE
+ PARAMETER ( ZERO = 0.0E+0, ONE = 1.0E+0 )
+* ..
+* .. Local Scalars ..
+ INTEGER I, J
+ REAL BNORM, EPS
+* ..
+* .. External Functions ..
+ LOGICAL LSAME
+ INTEGER ISAMAX
+ REAL SASUM, SLAMCH
+ EXTERNAL LSAME, ISAMAX, SASUM, SLAMCH
+* ..
+* .. External Subroutines ..
+ EXTERNAL SGEMV
+* ..
+* .. Intrinsic Functions ..
+ INTRINSIC ABS, MAX, MIN, REAL
+* ..
+* .. Executable Statements ..
+*
+* Quick return if possible
+*
+ RESID = ZERO
+ IF( N.LE.0 )
+ $ RETURN
+*
+* Compute B - U * S * V' one column at a time.
+*
+ BNORM = ZERO
+ IF( KD.GE.1 ) THEN
+*
+* B is bidiagonal.
+*
+ IF( LSAME( UPLO, 'U' ) ) THEN
+*
+* B is upper bidiagonal.
+*
+ DO 20 J = 1, N
+ DO 10 I = 1, N
+ WORK( N+I ) = S( I )*VT( I, J )
+ 10 CONTINUE
+ CALL SGEMV( 'No transpose', N, N, -ONE, U, LDU,
+ $ WORK( N+1 ), 1, ZERO, WORK, 1 )
+ WORK( J ) = WORK( J ) + D( J )
+ IF( J.GT.1 ) THEN
+ WORK( J-1 ) = WORK( J-1 ) + E( J-1 )
+ BNORM = MAX( BNORM, ABS( D( J ) )+ABS( E( J-1 ) ) )
+ ELSE
+ BNORM = MAX( BNORM, ABS( D( J ) ) )
+ END IF
+ RESID = MAX( RESID, SASUM( N, WORK, 1 ) )
+ 20 CONTINUE
+ ELSE
+*
+* B is lower bidiagonal.
+*
+ DO 40 J = 1, N
+ DO 30 I = 1, N
+ WORK( N+I ) = S( I )*VT( I, J )
+ 30 CONTINUE
+ CALL SGEMV( 'No transpose', N, N, -ONE, U, LDU,
+ $ WORK( N+1 ), 1, ZERO, WORK, 1 )
+ WORK( J ) = WORK( J ) + D( J )
+ IF( J.LT.N ) THEN
+ WORK( J+1 ) = WORK( J+1 ) + E( J )
+ BNORM = MAX( BNORM, ABS( D( J ) )+ABS( E( J ) ) )
+ ELSE
+ BNORM = MAX( BNORM, ABS( D( J ) ) )
+ END IF
+ RESID = MAX( RESID, SASUM( N, WORK, 1 ) )
+ 40 CONTINUE
+ END IF
+ ELSE
+*
+* B is diagonal.
+*
+ DO 60 J = 1, N
+ DO 50 I = 1, N
+ WORK( N+I ) = S( I )*VT( I, J )
+ 50 CONTINUE
+ CALL SGEMV( 'No transpose', N, N, -ONE, U, LDU, WORK( N+1 ),
+ $ 1, ZERO, WORK, 1 )
+ WORK( J ) = WORK( J ) + D( J )
+ RESID = MAX( RESID, SASUM( N, WORK, 1 ) )
+ 60 CONTINUE
+ J = ISAMAX( N, D, 1 )
+ BNORM = ABS( D( J ) )
+ END IF
+*
+* Compute norm(B - U * S * V') / ( n * norm(B) * EPS )
+*
+ EPS = SLAMCH( 'Precision' )
+*
+ IF( BNORM.LE.ZERO ) THEN
+ IF( RESID.NE.ZERO )
+ $ RESID = ONE / EPS
+ ELSE
+ IF( BNORM.GE.RESID ) THEN
+ RESID = ( RESID / BNORM ) / ( REAL( N )*EPS )
+ ELSE
+ IF( BNORM.LT.ONE ) THEN
+ RESID = ( MIN( RESID, REAL( N )*BNORM ) / BNORM ) /
+ $ ( REAL( N )*EPS )
+ ELSE
+ RESID = MIN( RESID / BNORM, REAL( N ) ) /
+ $ ( REAL( N )*EPS )
+ END IF
+ END IF
+ END IF
+*
+ RETURN
+*
+* End of SBDT03
+*
+ END