LAPACK  3.4.1
LAPACK: Linear Algebra PACKage
zla_syrcond_c.f
Go to the documentation of this file.
00001 *> \brief \b ZLA_SYRCOND_C
00002 *
00003 *  =========== DOCUMENTATION ===========
00004 *
00005 * Online html documentation available at 
00006 *            http://www.netlib.org/lapack/explore-html/ 
00007 *
00008 *> \htmlonly
00009 *> Download ZLA_SYRCOND_C + dependencies 
00010 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/zla_syrcond_c.f"> 
00011 *> [TGZ]</a> 
00012 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/zla_syrcond_c.f"> 
00013 *> [ZIP]</a> 
00014 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/zla_syrcond_c.f"> 
00015 *> [TXT]</a>
00016 *> \endhtmlonly 
00017 *
00018 *  Definition:
00019 *  ===========
00020 *
00021 *       DOUBLE PRECISION FUNCTION ZLA_SYRCOND_C( UPLO, N, A, LDA, AF,
00022 *                                                LDAF, IPIV, C, CAPPLY,
00023 *                                                INFO, WORK, RWORK )
00024 * 
00025 *       .. Scalar Arguments ..
00026 *       CHARACTER          UPLO
00027 *       LOGICAL            CAPPLY
00028 *       INTEGER            N, LDA, LDAF, INFO
00029 *       ..
00030 *       .. Array Arguments ..
00031 *       INTEGER            IPIV( * )
00032 *       COMPLEX*16         A( LDA, * ), AF( LDAF, * ), WORK( * )
00033 *       DOUBLE PRECISION   C( * ), RWORK( * )
00034 *       ..
00035 *  
00036 *
00037 *> \par Purpose:
00038 *  =============
00039 *>
00040 *> \verbatim
00041 *>
00042 *>    ZLA_SYRCOND_C Computes the infinity norm condition number of
00043 *>    op(A) * inv(diag(C)) where C is a DOUBLE PRECISION vector.
00044 *> \endverbatim
00045 *
00046 *  Arguments:
00047 *  ==========
00048 *
00049 *> \param[in] UPLO
00050 *> \verbatim
00051 *>          UPLO is CHARACTER*1
00052 *>       = 'U':  Upper triangle of A is stored;
00053 *>       = 'L':  Lower triangle of A is stored.
00054 *> \endverbatim
00055 *>
00056 *> \param[in] N
00057 *> \verbatim
00058 *>          N is INTEGER
00059 *>     The number of linear equations, i.e., the order of the
00060 *>     matrix A.  N >= 0.
00061 *> \endverbatim
00062 *>
00063 *> \param[in] A
00064 *> \verbatim
00065 *>          A is COMPLEX*16 array, dimension (LDA,N)
00066 *>     On entry, the N-by-N matrix A
00067 *> \endverbatim
00068 *>
00069 *> \param[in] LDA
00070 *> \verbatim
00071 *>          LDA is INTEGER
00072 *>     The leading dimension of the array A.  LDA >= max(1,N).
00073 *> \endverbatim
00074 *>
00075 *> \param[in] AF
00076 *> \verbatim
00077 *>          AF is COMPLEX*16 array, dimension (LDAF,N)
00078 *>     The block diagonal matrix D and the multipliers used to
00079 *>     obtain the factor U or L as computed by ZSYTRF.
00080 *> \endverbatim
00081 *>
00082 *> \param[in] LDAF
00083 *> \verbatim
00084 *>          LDAF is INTEGER
00085 *>     The leading dimension of the array AF.  LDAF >= max(1,N).
00086 *> \endverbatim
00087 *>
00088 *> \param[in] IPIV
00089 *> \verbatim
00090 *>          IPIV is INTEGER array, dimension (N)
00091 *>     Details of the interchanges and the block structure of D
00092 *>     as determined by ZSYTRF.
00093 *> \endverbatim
00094 *>
00095 *> \param[in] C
00096 *> \verbatim
00097 *>          C is DOUBLE PRECISION array, dimension (N)
00098 *>     The vector C in the formula op(A) * inv(diag(C)).
00099 *> \endverbatim
00100 *>
00101 *> \param[in] CAPPLY
00102 *> \verbatim
00103 *>          CAPPLY is LOGICAL
00104 *>     If .TRUE. then access the vector C in the formula above.
00105 *> \endverbatim
00106 *>
00107 *> \param[out] INFO
00108 *> \verbatim
00109 *>          INFO is INTEGER
00110 *>       = 0:  Successful exit.
00111 *>     i > 0:  The ith argument is invalid.
00112 *> \endverbatim
00113 *>
00114 *> \param[in] WORK
00115 *> \verbatim
00116 *>          WORK is COMPLEX*16 array, dimension (2*N).
00117 *>     Workspace.
00118 *> \endverbatim
00119 *>
00120 *> \param[in] RWORK
00121 *> \verbatim
00122 *>          RWORK is DOUBLE PRECISION array, dimension (N).
00123 *>     Workspace.
00124 *> \endverbatim
00125 *
00126 *  Authors:
00127 *  ========
00128 *
00129 *> \author Univ. of Tennessee 
00130 *> \author Univ. of California Berkeley 
00131 *> \author Univ. of Colorado Denver 
00132 *> \author NAG Ltd. 
00133 *
00134 *> \date November 2011
00135 *
00136 *> \ingroup complex16SYcomputational
00137 *
00138 *  =====================================================================
00139       DOUBLE PRECISION FUNCTION ZLA_SYRCOND_C( UPLO, N, A, LDA, AF,
00140      $                                         LDAF, IPIV, C, CAPPLY,
00141      $                                         INFO, WORK, RWORK )
00142 *
00143 *  -- LAPACK computational routine (version 3.4.0) --
00144 *  -- LAPACK is a software package provided by Univ. of Tennessee,    --
00145 *  -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
00146 *     November 2011
00147 *
00148 *     .. Scalar Arguments ..
00149       CHARACTER          UPLO
00150       LOGICAL            CAPPLY
00151       INTEGER            N, LDA, LDAF, INFO
00152 *     ..
00153 *     .. Array Arguments ..
00154       INTEGER            IPIV( * )
00155       COMPLEX*16         A( LDA, * ), AF( LDAF, * ), WORK( * )
00156       DOUBLE PRECISION   C( * ), RWORK( * )
00157 *     ..
00158 *
00159 *  =====================================================================
00160 *
00161 *     .. Local Scalars ..
00162       INTEGER            KASE
00163       DOUBLE PRECISION   AINVNM, ANORM, TMP
00164       INTEGER            I, J
00165       LOGICAL            UP, UPPER
00166       COMPLEX*16         ZDUM
00167 *     ..
00168 *     .. Local Arrays ..
00169       INTEGER            ISAVE( 3 )
00170 *     ..
00171 *     .. External Functions ..
00172       LOGICAL            LSAME
00173       EXTERNAL           LSAME
00174 *     ..
00175 *     .. External Subroutines ..
00176       EXTERNAL           ZLACN2, ZSYTRS, XERBLA
00177 *     ..
00178 *     .. Intrinsic Functions ..
00179       INTRINSIC          ABS, MAX
00180 *     ..
00181 *     .. Statement Functions ..
00182       DOUBLE PRECISION CABS1
00183 *     ..
00184 *     .. Statement Function Definitions ..
00185       CABS1( ZDUM ) = ABS( DBLE( ZDUM ) ) + ABS( DIMAG( ZDUM ) )
00186 *     ..
00187 *     .. Executable Statements ..
00188 *
00189       ZLA_SYRCOND_C = 0.0D+0
00190 *
00191       INFO = 0
00192       UPPER = LSAME( UPLO, 'U' )
00193       IF( .NOT.UPPER .AND. .NOT.LSAME( UPLO, 'L' ) ) THEN
00194          INFO = -1
00195       ELSE IF( N.LT.0 ) THEN
00196          INFO = -2
00197       ELSE IF( LDA.LT.MAX( 1, N ) ) THEN
00198          INFO = -4
00199       ELSE IF( LDAF.LT.MAX( 1, N ) ) THEN
00200          INFO = -6
00201       END IF
00202       IF( INFO.NE.0 ) THEN
00203          CALL XERBLA( 'ZLA_SYRCOND_C', -INFO )
00204          RETURN
00205       END IF
00206       UP = .FALSE.
00207       IF ( LSAME( UPLO, 'U' ) ) UP = .TRUE.
00208 *
00209 *     Compute norm of op(A)*op2(C).
00210 *
00211       ANORM = 0.0D+0
00212       IF ( UP ) THEN
00213          DO I = 1, N
00214             TMP = 0.0D+0
00215             IF ( CAPPLY ) THEN
00216                DO J = 1, I
00217                   TMP = TMP + CABS1( A( J, I ) ) / C( J )
00218                END DO
00219                DO J = I+1, N
00220                   TMP = TMP + CABS1( A( I, J ) ) / C( J )
00221                END DO
00222             ELSE
00223                DO J = 1, I
00224                   TMP = TMP + CABS1( A( J, I ) )
00225                END DO
00226                DO J = I+1, N
00227                   TMP = TMP + CABS1( A( I, J ) )
00228                END DO
00229             END IF
00230             RWORK( I ) = TMP
00231             ANORM = MAX( ANORM, TMP )
00232          END DO
00233       ELSE
00234          DO I = 1, N
00235             TMP = 0.0D+0
00236             IF ( CAPPLY ) THEN
00237                DO J = 1, I
00238                   TMP = TMP + CABS1( A( I, J ) ) / C( J )
00239                END DO
00240                DO J = I+1, N
00241                   TMP = TMP + CABS1( A( J, I ) ) / C( J )
00242                END DO
00243             ELSE
00244                DO J = 1, I
00245                   TMP = TMP + CABS1( A( I, J ) )
00246                END DO
00247                DO J = I+1, N
00248                   TMP = TMP + CABS1( A( J, I ) )
00249                END DO
00250             END IF
00251             RWORK( I ) = TMP
00252             ANORM = MAX( ANORM, TMP )
00253          END DO
00254       END IF
00255 *
00256 *     Quick return if possible.
00257 *
00258       IF( N.EQ.0 ) THEN
00259          ZLA_SYRCOND_C = 1.0D+0
00260          RETURN
00261       ELSE IF( ANORM .EQ. 0.0D+0 ) THEN
00262          RETURN
00263       END IF
00264 *
00265 *     Estimate the norm of inv(op(A)).
00266 *
00267       AINVNM = 0.0D+0
00268 *
00269       KASE = 0
00270    10 CONTINUE
00271       CALL ZLACN2( N, WORK( N+1 ), WORK, AINVNM, KASE, ISAVE )
00272       IF( KASE.NE.0 ) THEN
00273          IF( KASE.EQ.2 ) THEN
00274 *
00275 *           Multiply by R.
00276 *
00277             DO I = 1, N
00278                WORK( I ) = WORK( I ) * RWORK( I )
00279             END DO
00280 *
00281             IF ( UP ) THEN
00282                CALL ZSYTRS( 'U', N, 1, AF, LDAF, IPIV,
00283      $            WORK, N, INFO )
00284             ELSE
00285                CALL ZSYTRS( 'L', N, 1, AF, LDAF, IPIV,
00286      $            WORK, N, INFO )
00287             ENDIF
00288 *
00289 *           Multiply by inv(C).
00290 *
00291             IF ( CAPPLY ) THEN
00292                DO I = 1, N
00293                   WORK( I ) = WORK( I ) * C( I )
00294                END DO
00295             END IF
00296          ELSE
00297 *
00298 *           Multiply by inv(C**T).
00299 *
00300             IF ( CAPPLY ) THEN
00301                DO I = 1, N
00302                   WORK( I ) = WORK( I ) * C( I )
00303                END DO
00304             END IF
00305 *
00306             IF ( UP ) THEN
00307                CALL ZSYTRS( 'U', N, 1, AF, LDAF, IPIV,
00308      $            WORK, N, INFO )
00309             ELSE
00310                CALL ZSYTRS( 'L', N, 1, AF, LDAF, IPIV,
00311      $            WORK, N, INFO )
00312             END IF
00313 *
00314 *           Multiply by R.
00315 *
00316             DO I = 1, N
00317                WORK( I ) = WORK( I ) * RWORK( I )
00318             END DO
00319          END IF
00320          GO TO 10
00321       END IF
00322 *
00323 *     Compute the estimate of the reciprocal condition number.
00324 *
00325       IF( AINVNM .NE. 0.0D+0 )
00326      $   ZLA_SYRCOND_C = 1.0D+0 / AINVNM
00327 *
00328       RETURN
00329 *
00330       END
 All Files Functions