File: openmp_09.f90

package info (click to toggle)
lfortran 0.45.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 46,332 kB
  • sloc: cpp: 137,068; f90: 51,260; python: 6,444; ansic: 4,277; yacc: 2,285; fortran: 806; sh: 524; makefile: 30; javascript: 15
file content (38 lines) | stat: -rw-r--r-- 857 bytes parent folder | download
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
subroutine parallel_factorial(n, ctr)
    use omp_lib
    use iso_fortran_env
    implicit none
    integer, intent(in) :: n
    integer(kind =int64), intent(inout) :: ctr
    
    integer(kind =int64) :: local_ctr
    
    integer :: i
    
    local_ctr = 1
    !$omp parallel private(i) reduction(*:local_ctr)
    !$omp do
    do i = 1, n   
        local_ctr = local_ctr * i
    end do
    !$omp end do
    !$omp end parallel
    
    ctr = ctr + local_ctr
    end subroutine
    
    program openmp_09
    use omp_lib
    use iso_fortran_env
    integer, parameter :: n = 20    
    integer(kind =int64) :: ctr
    integer(kind =int64) :: res 
    res =  2432902008176640000_int64 ! Factorial of 20
    
    call omp_set_num_threads(8)
    ctr = 0
    call parallel_factorial(n, ctr)
    
    print *, ctr
    if(ctr /= res) error stop
    end program