numeric-linalg
Educational material on the SciPy implementation of numerical linear algebra algorithms
Name | Size | Mode | |
.. | |||
lapack/SRC/la_xisnan.F90 | 1143B | -rw-r--r-- |
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
module LA_XISNAN interface LA_ISNAN module procedure SISNAN module procedure DISNAN end interface contains logical function SISNAN( x ) use LA_CONSTANTS, only: wp=>sp #ifdef USE_IEEE_INTRINSIC use, intrinsic :: ieee_arithmetic #elif USE_ISNAN intrinsic :: isnan #endif real(wp) :: x #ifdef USE_IEEE_INTRINSIC sisnan = ieee_is_nan(x) #elif USE_ISNAN sisnan = isnan(x) #else sisnan = SLAISNAN(x,x) contains logical function SLAISNAN( x, y ) use LA_CONSTANTS, only: wp=>sp real(wp) :: x, y SLAISNAN = ( x.ne.y ) end function SLAISNAN #endif end function SISNAN logical function DISNAN( x ) use LA_CONSTANTS, only: wp=>dp #ifdef USE_IEEE_INTRINSIC use, intrinsic :: ieee_arithmetic #elif USE_ISNAN intrinsic :: isnan #endif real(wp) :: x #ifdef USE_IEEE_INTRINSIC DISNAN = ieee_is_nan(x) #elif USE_ISNAN DISNAN = isnan(x) #else DISNAN = DLAISNAN(x,x) contains logical function DLAISNAN( x, y ) use LA_CONSTANTS, only: wp=>dp real(wp) :: x, y DLAISNAN = ( x.ne.y ) end function DLAISNAN #endif end function DISNAN end module LA_XISNAN