File: openmp_10.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 (33 lines) | stat: -rw-r--r-- 691 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
subroutine increment_ctr(n, ctr)
    use omp_lib
    implicit none
    integer, intent(in) :: n
    double precision, intent(out) :: ctr
    
    double precision :: local_ctr
    
    integer :: i
    
    local_ctr = 0
    !$omp parallel private(i) reduction(+:local_ctr)
    !$omp do
    do i = 1, n
        local_ctr = local_ctr + 1.5
    end do
    !$omp end do
    !$omp end parallel
    
    ctr = ctr + local_ctr
end subroutine
    
program openmp_06
    use omp_lib
    integer, parameter :: n = 1000000
    double precision :: ctr

    call omp_set_num_threads(8)
    ctr = 0
    call increment_ctr(n, ctr)
    print *, ctr
    if(abs(ctr - 1.5e6) > 0.0002 ) error stop
end program