BLAS / dznrm2.f

Fortran project BLAS, source module dznrm2.f.

Source module last modified on Thu, 2 Jul 1998, 23:17;
HTML image of Fortran source automatically generated by for2html on Sun, 23 Jun 2002, 15:10.


      DOUBLE PRECISION FUNCTION DZNRM2( N, X, INCX )
#     .. Scalar Arguments ..
      INTEGER                           INCX, N
#     .. Array Arguments ..
      COMPLEX*16                        X( * )
#     ..
#
#  DZNRM2 returns the euclidean norm of a vector via the function
#  name, so that
#
#     DZNRM2 := sqrt( conjg( x' )*x )
#
#
#
#  -- This version written on 25-October-1982.
#     Modified on 14-October-1993 to inline the call to ZLASSQ.
#     Sven Hammarling, Nag Ltd.
#
#
#     .. Parameters ..
      DOUBLE PRECISION      ONE         , ZERO
      PARAMETER           ( ONE = 1.0D+0, ZERO = 0.0D+0 )
#     .. Local Scalars ..
      INTEGER               IX
      DOUBLE PRECISION      NORM, SCALE, SSQ, TEMP
#     .. Intrinsic Functions ..
      INTRINSIC             ABS, DIMAG, DBLE, SQRT
#     ..
#     .. Executable Statements ..
      IF( N<1 || INCX<1 )THEN
         NORM  = ZERO
      ELSE
         SCALE = ZERO
         SSQ   = ONE
#        The following loop is equivalent to this call to the LAPACK
#        auxiliary routine:
#        CALL ZLASSQ( N, X, INCX, SCALE, SSQ )
#
         DO 10, IX = 1, 1 + ( N - 1 )*INCX, INCX
            IF( DBLE( X( IX ) )!=ZERO )THEN
               TEMP = ABS( DBLE( X( IX ) ) )
               IF( SCALE<TEMP )THEN
                  SSQ   = ONE   + SSQ*( SCALE/TEMP )**2
                  SCALE = TEMP
               ELSE
                  SSQ   = SSQ   +     ( TEMP/SCALE )**2
               END IF
            END IF
            IF( DIMAG( X( IX ) )!=ZERO )THEN
               TEMP = ABS( DIMAG( X( IX ) ) )
               IF( SCALE<TEMP )THEN
                  SSQ   = ONE   + SSQ*( SCALE/TEMP )**2
                  SCALE = TEMP
               ELSE
                  SSQ   = SSQ   +     ( TEMP/SCALE )**2
               END IF
            END IF
   10    CONTINUE
         NORM  = SCALE * SQRT( SSQ )
      END IF
#
      DZNRM2 = NORM
      RETURN
#
#     End of DZNRM2.
#
      END