1 2 3 4 5 6 7 8 9 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 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
! Test ieee_support_* inquiry functions
program test_ieee_support
use, intrinsic :: ieee_arithmetic
use, intrinsic :: iso_fortran_env, only: real32, real64
implicit none
real(real32) :: x_sp
real(real64) :: x_dp
logical :: result
print *, "Testing ieee_support_* functions..."
! Test ieee_support_denormal
result = ieee_support_denormal(x_sp)
print *, "ieee_support_denormal(real32) = ", result
if (.not. result) error stop "Should support denormals"
result = ieee_support_denormal(x_dp)
print *, "ieee_support_denormal(real64) = ", result
if (.not. result) error stop "Should support denormals"
! Test ieee_support_divide
result = ieee_support_divide(x_sp)
print *, "ieee_support_divide(real32) = ", result
if (.not. result) error stop "Should support divide"
result = ieee_support_divide(x_dp)
print *, "ieee_support_divide(real64) = ", result
if (.not. result) error stop "Should support divide"
! Test ieee_support_sqrt
result = ieee_support_sqrt(x_sp)
print *, "ieee_support_sqrt(real32) = ", result
if (.not. result) error stop "Should support sqrt"
result = ieee_support_sqrt(x_dp)
print *, "ieee_support_sqrt(real64) = ", result
if (.not. result) error stop "Should support sqrt"
! Test ieee_support_standard
result = ieee_support_standard(x_sp)
print *, "ieee_support_standard(real32) = ", result
if (.not. result) error stop "Should support standard"
result = ieee_support_standard(x_dp)
print *, "ieee_support_standard(real64) = ", result
if (.not. result) error stop "Should support standard"
! Test ieee_support_io
result = ieee_support_io(x_sp)
print *, "ieee_support_io(real32) = ", result
if (.not. result) error stop "Should support I/O"
result = ieee_support_io(x_dp)
print *, "ieee_support_io(real64) = ", result
if (.not. result) error stop "Should support I/O"
! Test ieee_support_rounding
result = ieee_support_rounding(ieee_nearest, x_sp)
print *, "ieee_support_rounding(ieee_nearest, real32) = ", result
if (.not. result) error stop "Should support rounding"
result = ieee_support_rounding(ieee_to_zero, x_dp)
print *, "ieee_support_rounding(ieee_to_zero, real64) = ", result
if (.not. result) error stop "Should support rounding"
! Test ieee_support_datatype
result = ieee_support_datatype(x_sp)
print *, "ieee_support_datatype(real32) = ", result
if (.not. result) error stop "Should support datatype"
result = ieee_support_datatype(x_dp)
print *, "ieee_support_datatype(real64) = ", result
if (.not. result) error stop "Should support datatype"
print *, "All ieee_support_* tests passed!"
end program test_ieee_support
|