File: intrinsic_mod_ulo.f90

package info (click to toggle)
gcc-arm-none-eabi 15%3A12.2.rel1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 959,712 kB
  • sloc: cpp: 3,275,382; ansic: 2,061,766; ada: 840,956; f90: 208,513; makefile: 76,132; asm: 73,433; xml: 50,448; exp: 34,146; sh: 32,436; objc: 15,637; fortran: 14,012; python: 11,991; pascal: 6,787; awk: 4,779; perl: 3,054; yacc: 338; ml: 285; lex: 201; haskell: 122
file content (67 lines) | stat: -rw-r--r-- 1,939 bytes parent folder | download | duplicates (3)
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
! Program to test MOD and MODULO intrinsics
subroutine integertest (ops, res)
   implicit none
   integer, dimension(2) :: ops
   integer, dimension(2) :: res

   if ((mod(ops(1), ops(2)) .ne. res(1)) .or. &
       (modulo(ops(1), ops(2)) .ne. res(2))) STOP 1
end subroutine

subroutine real4test (ops, res)
   implicit none
   real(kind=4), dimension(2) :: ops
   real(kind=4), dimension(2) :: res

   if (diff(mod(ops(1), ops(2)), res(1)) .or. &
       diff(modulo(ops(1), ops(2)), res(2))) STOP 2
contains
function diff(a, b)
  real(kind=4) :: a, b
  logical diff

  diff = (abs (a - b) .gt. abs(a * 1e-6))
end function
end subroutine

subroutine real8test (ops, res)
   implicit none
   real(kind=8), dimension(2) :: ops
   real(kind=8), dimension(2) :: res

   if (diff(mod(ops(1), ops(2)), res(1)) .or. &
       diff(modulo(ops(1), ops(2)), res(2))) STOP 3
contains
function diff(a, b)
  real(kind=8) :: a, b
  logical diff

  diff = (abs(a - b) .gt. abs(a * 1e-6))
end function
end subroutine

program mod_modulotest
   implicit none

   call integertest ((/8, 5/), (/3, 3/))
   call integertest ((/-8, 5/), (/-3, 2/))
   call integertest ((/8, -5/), (/3, -2/))
   call integertest ((/-8, -5/), (/-3, -3/))
   call integertest ((/ 2, -1/), (/0, 0/))

   call real4test ((/3.0, 2.5/), (/0.5, 0.5/))
   call real4test ((/-3.0, 2.5/), (/-0.5, 2.0/))
   call real4test ((/3.0, -2.5/), (/0.5, -2.0/))
   call real4test ((/-3.0, -2.5/), (/-0.5, -0.5/))
   call real4test ((/ 2.0, -1.0/), (/ 0.0, 0.0 /))

   call real8test ((/3.0_8, 2.5_8/), (/0.5_8, 0.5_8/))
   call real8test ((/-3.0_8, 2.5_8/), (/-0.5_8, 2.0_8/))
   call real8test ((/3.0_8, -2.5_8/), (/0.5_8, -2.0_8/))
   call real8test ((/-3.0_8, -2.5_8/), (/-0.5_8, -0.5_8/))
   call real8test ((/ 2.0_8, -1.0_8/), (/ 0.0_8, 0.0_8 /))
   
   ! Check large numbers
   call real4test ((/2e34, 1.0/), (/0.0, 0.0/))
   call real4test ((/2e34, 1.5e34/), (/0.5e34, 0.5e34/))
end program